Обработка входа в систему с помощью 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