Обработка входа в систему с помощью JWT auth в reactjs

я пытаюсь обработать вход с помощью JWT auth и axios в моем приложении reactjs; но каждый раз, когда я отправляю свои данные в бэкенд, я получаю ошибку "'data' is not defined no-undef"...

вот мой код отправки ручки в Login.js:

class Login extends Component{
constructor(props) {
    super(props);
    this.state = {username: "", password: ""};

    this.handleChange = this.handleChange.bind(this);
    this.handleSubmit = this.handleSubmit.bind(this);
}

handleChange(event) {
    this.setState({[event.target.name]: event.target.value});
}

handleSubmit(event) {
    event.preventDefault();
    try {
        const response = axiosInstance.post('/token/obtain/', {
            username: this.state.username,
            password: this.state.password
        });
        axiosInstance.defaults.headers['Authorization'] = "Bearer " + response.data.access;
        localStorage.setItem('access_token', response.data.access);
        localStorage.setItem('refresh_token', response.data.refresh);
        return data;
    } catch (error) {
        throw error;
    }
}

render() {
    return (...

и это в моем файле axiosInstance :

const axiosInstance = axios.create({
baseURL: 'http://127.0.0.1:8000/',
timeout: 5000,
headers: {
    'Authorization': "Bearer " + localStorage.getItem('access_token'),
    'Content-Type': 'application/json',
    'accept': 'application/json'
}
});

как можно справиться с ошибкой "'data' is not defined no-undef" ????

Мне кажется, что вам не хватает await

... await axios.post(...

Или вы можете поступить следующим образом

    axios.post(...).then(response => { //response.data.access can be found here } 

Но, конечно, вам лучше проверить документацию axios и узнать, что такое Promise

Вернуться на верх