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

이주호님의 프로필 이미지
이주호

작성한 질문수

React로 NodeBird SNS 만들기

5-12. passport 총정리와 실제 로그인

result를 console로 찍어보니..

작성

·

191

0

게속 프론트에서 nickname 이 없다고해서

result를 console로 찍어보니

  1. Promise {<pending>}
    1. [[PromiseStatus]]"resolved"

답변 4

1

이주호님의 프로필 이미지
이주호
질문자

아.... 감사합니다. ㅠㅠㅠ 이런 중대한 실수를 머가리 박겠습니다.

1

제로초(조현영)님의 프로필 이미지
제로초(조현영)
지식공유자

loginAPI에서 * 빼주세요.

1

제로초(조현영)님의 프로필 이미지
제로초(조현영)
지식공유자

Promise가 pending인데요? saga 코드를 보여주세요.

0

이주호님의 프로필 이미지
이주호
질문자

import { allforktakeLatestcallputtaketakeEverydelay } from "redux-saga/effects";
import { LOG_IN_SUCCESSLOG_IN_FAILURELOG_IN_REQUEST
    SIGN_UP_SUCCESSSIGN_UP_REQUESTSIGN_UP_FAILURE } from '../reducers/user';
import axios from 'axios'

axios.defaults.baseURL = 'http://localhost:8080/api'//증복된거 줄이기

function* loginAPI(loginData) {
    return axios.post('/user/login'loginData); //요청을 보내면 응답을 해주는 애 (SUCCESS인지 FAILURE인지)D
}

function* login(action) {
    try { //call은 *동기호출* loginAPI는 서버 요청을 보내는부분 요청을 보내면 받을때까지 기다림, fork로 하면 비동기여서 요청을 보내면 응답을 받지도않고 바로 그 다음줄들 실행
        const result = yield call(loginAPIaction.data); //call은 함수를 동기적 호출 server에서 로그인 요청을 보내고 로그인이 성공했다면 그 다움줄 실행 
        console.log(result);
        yield put({ //put은 dispatch 랑 똑같은 역할, loginAPI에 요청을 보내고 응답을 받아야지만 이 줄이 실행
            type: LOG_IN_SUCCESS//yied call(loginAPI)가 요청을 보내 로그인이 성공이면 redux에 LOGIN_IN_SUCCESS 실행
            data: result.data //여기에 user정보가들어있음, loginAPI는 로그인이 성공이됬다면 성공이된 user의 데이터를 보내고 그걸 result라는 변수에 담아서 reducer에 보내기
        })
    } catch (e) { // loginAPI 실패일시 여기에 LOG_IN_FAILURE 에러가 남
        console.error(e);
        yield put({
            type: LOG_IN_FAILURE //로그인이 실패면 LOG_IN_FAILURE 실행
        })
    }
}

function* watchLogin() { //watch라고 하는이유는 action이 들어와야 실행이되기때문에 기다린다고해서 watch라고 함 
   yield takeEvery(LOG_IN_REQUESTlogin); //LOG_IN Action 받을때까지 기달림 받으면, login 함수실행 login 함수에서는 loginAPI로 서버와의 통신
}
이주호님의 프로필 이미지
이주호

작성한 질문수

질문하기