inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[리뉴얼] 맛집 지도앱 만들기 (React Native & NestJS)

카카오 로그인 관련 Webview 질문드립니다.

해결된 질문

678

둥둥쓰

작성한 질문수 4

1

안녕하세요. Webview 관련해서 다시 질문드립니다.

 

import axios from 'axios';
import React, {useState} from 'react';
import {
  ActivityIndicator,
  Dimensions,
  Platform,
  StyleSheet,
  Text,
  View,
} from 'react-native';
import {SafeAreaView} from 'react-native-safe-area-context';
import WebView, {
  WebViewMessageEvent,
  WebViewNavigation,
} from 'react-native-webview';
import useAuth from '../../hooks/queries/useAuth';
import Config from 'react-native-config';
import {authNavigations, colors} from '../../constants';
import {AuthStackParamList} from '../../navigations/stack/AuthStackNavigator';
import {NativeStackScreenProps} from '@react-navigation/native-stack';

const REDIRECT_URI = `{배포된 SERVER의 REDIRECT URI}`

type AuthHomeScreenProps = NativeStackScreenProps<AuthStackParamList>;

function KakaoLoginScreen({navigation}: AuthHomeScreenProps) {
  const {kakoLoginMutation} = useAuth();
  const [isLoading, setIsLoading] = useState(false);
  const [isChangeNavigate, setIsChangeNavigate] = useState(true);

  const handleOnMessage = (event: WebViewMessageEvent) => {
    if (event.nativeEvent.url.includes(`${REDIRECT_URI}?code=`)) {
      const code = event.nativeEvent.url.replace(`${REDIRECT_URI}?code=`, '');

      requestToken(code);
      // navigation.navigate(authNavigations.MAINBOTTOMTABNAVIGATOR, {code});
      navigation.navigate(authNavigations.MAINBOTTOMTABNAVIGATOR);
    }
  };

  const requestToken = async (code: string) => {
    const response = await axios({
      method: 'post',
      url: 'https://kauth.kakao.com/oauth/token',
      params: {
        grant_type: 'authorization_code',
        client_id: Config.KAKAO_REST_API_KEY,
        redirect_uri: REDIRECT_URI,
        code,
      },
    });

    console.log('response.data', response.data);
    kakoLoginMutation.mutate(response.data.access_token);
  };

  // 로딩 처리
  const handleNavigationChangeState = (event: WebViewNavigation) => {
    const isMatched = event.url.includes(`${REDIRECT_URI}?code=`);
    setIsLoading(isMatched);
    setIsChangeNavigate(event.loading);
  };

  return (
    <SafeAreaView style={styles.container}>
      {(isLoading || isChangeNavigate) && (
        <View style={styles.kakaoLoadingContainer}>
          <ActivityIndicator size={'small'} color={colors.BLACK} />
        </View>
      )}
      <WebView
        source={{
          uri: `https://kauth.kakao.com/oauth/authorize?response_type=code&client_id=${Config.KAKAO_REST_API_KEY}&redirect_uri=${REDIRECT_URI}`,
        }}
        onMessage={handleOnMessage}
        injectedJavaScript={"window.ReactNativeWebView.postMessage('')"}
        onNavigationStationChange={handleNavigationChangeState}
      />
    </SafeAreaView>
  );
}

const styles = StyleSheet.create({
  container: {
    flex: 1,
  },
  kakaoLoadingContainer: {
    backgroundColor: colors.WHITE,
    height: Dimensions.get('window').height,
    alignItems: 'center',
    justifyContent: 'center',
  },
});

export default KakaoLoginScreen;

위와 같은 KakaologinScreen.tsx 코드에서 Webview 내의 source 부분에 RESTFULAPI_KEY 부분과 REDIRECT_URI를 넣고 강의에서처럼 카카오 로그인을 시도하였는데, 카카오 로그인 창이 뜨지 않고 계속 로딩 중인 상태입니다. 그래서 Webview 컴포넌트 source부분의 uri를 따로 때어서 웹 페이지에서 접속을 해보았는대로 아이디/비밀번호 입력창이 뜨지 않고 하얀색 공백창만 뜨는 상태입니다.
이와 같은 경우, 배보된 서버의 REDIRECT_URI의 문제인가요? 아니면 다른 부분에서 문제가 발생하는지 질문 드립니다.

 

react-native typescript nestjs react-query zustand

답변 2

0

Kyo

navigation.navigate(authNavigations.MAINBOTTOMTABNAVIGATOR); 이부분은 무슨역할인지 모르겠지만, 올려주신 코드만 봐서는 다른부분에는 문제가 없어보입니다.. 다른 코드나, api key, uri 등도 확인해주셔야할것같아요. 서버를 배포하신것 같은데, 해당 uri를 카카오디벨로퍼스에도 추가해주셨나요?

0

둥둥쓰

네 배포 된 서버에 맞게 '{배포된서버uri}/auth/oauth/kakao'를 추가하여 카카오 디벨로퍼 Redirect URI 에도 추가한 상태입니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 쌍둥이님의 카카오 로그인 관련 문제를 해결하기 위해 관련 내용과 유사한 상황에 대한 답변을 찾아보았습니다.

해당 질문의 문제는, 카카오 로그인 시 WebView에서 ID/비밀번호 입력창 대신 하얀색 공백 화면만 나타나는 상황으로 보입니다. 입력하신 코드와 설명을 통해 REDIRECT_URI 설정이나 카카오 로그인 연동 과정에서 문제가 발생했을 가능성을 염두에 두어야 할 것 같습니다.

유사한 문제를 겪었던 다른 수강생의 질문과 그에 대한 답변을 참고하시는 것이 좋을 듯합니다. 아래는 카카오 로그인 구현과 관련하여 Admin Settings Issue (KOE101) 오류로 문제를 겪었던 경우와 그 해결 방법에 대한 답변입니다.

  • [8-2] 카카오 로그인 구현하기 with WebVIew에서 다룬 오류로, 이 경우 ‘App Key’ 설정 문제였습니다. 질문자가 겪고 있는 현상과는 다소 차이가 있지만, 카카오 로그인 구현 시 발생할 수 있는 에러와 해결 과정에 대한 이해를 돕기 위해 링크를 첨부합니다: 카카오 로그인 관련 질문

위 링크에서는 KOE101 오류에 집중되어 있기 때문에, 쌍둥이님의 경우와 정확히 일치하지 않을 수 있습니다. 하지만, WebView를 사용한 카카오 로그인 구현에 있어 기본적인 설정 검토나 문제 해결 과정이 유사할 수 있으므로 참고가 될 만합니다.

문제 해결에 도움이 되는 구체적 내용:
- API key와 REDIRECT_URI 설정이 올바른지 다시 한번 확인
- WebView 내에서의 URL 접근, 요청 처리 과정에서 발생할 수 있는 일반적인 문제를 확인
- 인터넷 연결 상태, 도메인 설정 등의 환경적 요인 검토

쌍둥이님의 경우, 코드 상의 WebView 컴포넌트에서 source 부분의 uri 형식과, REDIRECT_URIConfig.KAKAO_REST_API_KEY 값에 오타 또는 설정 누락이 없는지 재확인해 보시는 것이 좋겠습니다. 또한, 실제 서비스 환경에서의 REDIRECT_URI 설정이 카카오 개발자 사이트에 등록된 Redirect URI와 일치하는지 확인해 주시기 바랍니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

react-native-screens 버전 호환 문제

2

153

1

안드로이드 실행 중 Drawer네비게이션과 MapView 성능 문제

0

103

2

해당 강의 부분은 실제 활용하기에 부족해 제가 해결한 방법입니다.

0

96

1

소스코드가 강의 순서랑 다른가요?

0

72

2

현재 Windows에서 VsCode로 작업 중인데 추후에 IOS도 가능하게 하려면

0

115

2

react-native-fast-image는 react 19 버전에서 설치가 안되나요?

0

208

2

SQL Shell의 역할이 무엇인가요?

0

91

1

혹시 해당 강의에서invalidateQueries를 사용한 이유가 있을까요?

0

79

2

빠르게 실행해보고싶습니다.

0

82

1

강의 수강 순서 관련

0

70

1

애뮬레이터 실행 방법

0

99

2

무료 Apple ID로 실기기 테스트 가능한가요?

0

90

2

ios 실기기 연결

0

70

2

npm run ios에러

0

74

1

10월 삭제 예정인 강의는 이유를 알 수 있을까요?

0

101

1

캘린더 개발 후에 navigation 에 대해서 궁금한 점이 있습니다.

0

51

1

안드로이드 위치 권한 이슈 2가지 문의

0

71

1

지도가 보이려면 음.. 작성해주신 스타일과 다르게

0

74

0

제대로 설치한거같은데 안드로이드랑 ios 둘다 앱실행이 안되는것같아요

0

83

3

강의 내용을 보면 전체적으로 function 함수 키워드를 사용하시는데

0

69

2

강의 3-9 에서 useGetRefreshToken 훅 안에 즉시 함수로 처리하는 이유가 궁금합니다!

0

82

2

사내에서 figma.com 업로드 안되나요?

0

96

1

AWS EC2 + RDS 설정

0

85

2

안드로이드 안켜집니다.

0

91

2