강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

이록기님의 프로필 이미지
이록기

작성한 질문수

React 팀 프로젝트 (로그인 검증 기능)

작성

·

66

·

수정됨

0

Supabase의 DB로 로그인 검증 기능을 만들려고 해요 그런데 로그인 검증을 하기 위해서 예외처리를 테스트 하는데 error 400 (Bad request) 가 발생 합니다. 데이터 값이 있으면 로그인은 됩니다. 하지만 존재 하지 않는 값의 예외처리를 할려 하는데 무조건 error 400 (Bad request) 가 나타나내요 이 문제를 해결해 줄 수 있는분 답변 부탁 드립니다.

  const handleLogin = async (e) => {
    e.preventDefault();

    if (!email || !password) {
      alert('이메일과 비밀번호를 입력해주세요.');
      return;
    }

    // 이메일 형식 확인 (정규식 사용)
    const emailPattern = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
    if (!emailPattern.test(email)) {
      alert('올바른 이메일 형식을 입력해주세요.');
      return;
    }

    if (password.length < 6) {
      alert('비밀번호는 최소 6자 이상이어야 합니다.');
      return;
    }

    try {
      const { data, error } = await supabase.auth.signInWithPassword({
        email,
        password,
      });

      if (error) {
        alert('이메일 또는 비밀번호가 잘못되었습니다.');
        return;
      }

      if (data?.user) {
        alert('로그인이 완료되었습니다.');
        navigate('/');
      } else {
        alert('회원 정보가 존재하지 않습니다.');
      }
    } catch (err) {
      console.error('오류 발생:', err);
      alert('오류가 발생했습니다. 잠시 후 다시 시도해주세요.');
    }
  };

답변 1

0

안녕하세요, 인프런 AI 인턴입니다.
이록기 님의 문제를 해결하기 위해 몇 가지 점검해볼 수 있는 사항을 안내해드리겠습니다.

첫 번째로, 로그인 검증 시 실제로 Supabase에서 반환하는 오류 메시지를 확인하는 것이 중요합니다. 400 Bad Request가 서버로부터 왔다면 주로 요청이 올바르게 구성되지 않았을 가능성이 있습니다.

  1. 오류 객체 확인: console.error()을 사용하여 error 객체의 자세한 내용을 출력해보세요. 예외 처리 블록 내에서 console.log(error)로 오류 메시지를 확인할 수 있습니다.
   if (error) {
     console.error('로그인 오류:', error);
     alert(error.message || '이메일 또는 비밀번호가 잘못되었습니다.');
     return;
   }
  1. API 요청 데이터 검토: supabase.auth.signInWithPassword() 메서드에 전달하는 email과 password가 올바르게 전달되는지 확인해보세요. 콘솔 로그나 디버깅을 통해 값이 올바른지 체크하는 것이 좋습니다.

  2. Supabase 에러 확인 및 문서 참고: Supabase의 공식 문서나 오류 메시지에 대한 정보를 참고하여 구체적인 에러 상황을 파악할 수 있습니다. Supabase Authentication Error Codes를 통해 지원되는 오류 코드와 해결책을 찾아보실 수 있습니다.

위의 방법들을 통해 400 Bad Request가 발생하는 정확한 이유를 파악하는 것이 중요합니다. 오류 메시지를 구체적으로 파악하면 문제 해결에 더 가까워질 것입니다. 도움이 되셨길 바랍니다!

계속해서 문제 발생할 경우, 추가 정보를 제공해주신다면 더 나은 답변을 드릴 수 있도록 하겠습니다. 😊

이록기님의 프로필 이미지
이록기

작성한 질문수

질문하기