Отправка в Redux-Thunk

#javascript #reactjs #redux-thunk

#javascript #reactjs #redux-thunk

Вопрос:

Не перехваченный (в обещании) Ошибка: запрос не выполнен с кодом состояния 400

Мне нужно сделать запрос страницы к базе данных для входа в систему, но я уже слишком запутался и не знаю, как устранить эту ошибку. До этого была ошибка «Действия должны быть простыми объектами. Используйте настраиваемое промежуточное программное обеспечение для асинхронных действий «. После этого я подключил Redux-Thunk, и появилась текущая ошибка.

Действия

 export const auth = (email, password, isLogin) => {
  return async(dispatch) => {
    dispatch(authData())
    
    let url = 'https://identitytoolkit.googleapis.com/v1/accounts:signUp?key=AIzaSyAU8gNE0fGG8z9zqUyh68Inw9_RzljhCCs'

    if (isLogin) {
      url = 'https://identitytoolkit.googleapis.com/v1/accounts:signInWithPassword?key=AIzaSyAU8gNE0fGG8z9zqUyh68Inw9_RzljhCCs'
    }
    const response = await axios.post(url, authData)
    console.log(response.data)
  }
}

const authData = (email, password, returnSecureToken = true) => ({
  type: 'LOGIN',
  email,
  password,
  returnSecureToken
})
 

Компонент

 loginHandler = () => {
  this.props.auth(
    this.props.AuthMail,
    this.props.AuthPass,
    true
  )
}

registerHandler = () => {
  this.props.auth(
    this.props.AuthRegMail,
    this.props.AuthRegPass,
    false
  )
}

const mapDispatchToProps = dispatch => {
  return {
    auth: (email, password, isLogin) => dispatch(auth(email, password, isLogin))
  }
}
 

Ответ №1:

 // You forgot to add the arguments to authData function
dispatch(authData())
// Here you are passing in a function as the second argument
const response = await axios.post(url, authData)
 

Вероятно, должно быть что-то вроде этого:

 export const auth = (email, password, isLogin) => {
  return async (dispatch) => {    
    const url = isLogin ? 'example.com/login' : 'example.com/signup';
    const response = await axios.post(url, {
      email,
      password,
      returnSecureToken: true,
    });
    console.log(response.data);
    // Handle this action somewhere to store the signed in user data in redux
    dispatch({
      type: "LOGIN",
      payload: response.data
    })
  }
}