我在django应用中编写了一个用于注册用户的views函数,其代码如下:
.alert.alert-danger{
display: none;
}
.alert.alert-danger.show{
display: block;
}
reactjs代码为:
def register(request):
if request.method == 'POST':
data1 = json.dumps(request.POST)
data = json.loads(data1)
full_name = data['userName']
company_name = data['agencyName']
phone = data['phoneNumber']
email_id = data['email']
password = data['password']
password2 = data['confirmpassword']
#Check if passwords match
if password == password2:
#Check username
if MyUser.objects.filter(email=email_id).exists():
messages.error(request,'That email is being used')
return redirect('register')
else:
#Looks good
user = MyUser.objects.create_user(password=password,
email=email_id, full_name=full_name,company_name=company_name,phone=phone)
user.save()
messages.success(request,'You are now registered')
return HttpResponse(json.dumps({'success':'success'}), content_type='application/json')
else:
messages.error(request,'Passwords donot match')
return HttpResponse(json.dumps({'error':'password donot match'}), content_type='application/json')
return HttpResponse(json.dumps({'none':'none'}),content_type='application/json')
网站的前端是用reactjs制作的,当我尝试从react应用发送POST请求进行注册时,它不会注册用户。
此外,当我向邮递员发送发帖请求以进行用户注册时,它可以正常工作并创建用户。但是,当我尝试从邮递员发送json对象时,
class SignupForm extends Component {
constructor(props) {
super(props);
this.state = {
userName: null,
agencyName: null,
email: null,
password: null,
confirmpassword: null,
phoneNumber: null,
formErrors: {
userName: "",
agencyName: "",
email: "",
password: "",
confirmpassword:"",
phoneNumber :""
}
};
}
handleSubmit = e => {
e.preventDefault();
if (formValid(this.state)) {
fetch('https://localhost:8000/accounts/register', {
method: 'POST',
body: this.state,
headers:{
// 'Access-Control-Allow-Origin':'*',
'Content-Type':'application/json',
}
});
} else {
console.error("FORM INVALID - DISPLAY ERROR MESSAGE");
}
};
它显示以下错误:
{'userName':'abcdef','phoneNumber':'123456789',email='abc@xyz.com','password':'1234','confirmpassword':'1234','agencyName':'abbb'}
我该如何解决?在React应用中,我可以通过哪些方式在Django中处理POST请求?
此外,后端django应用程序已上传到heroku服务器上,而前端react应用程序正在使用在heroku上上传的应用程序的网址。
答案 0 :(得分:1)
这两行是胡说八道:
data1 = json.dumps(request.POST)
data = json.loads(data1)
将表单数据字典转换为JSON然后再直接返回Python永远不会有任何意义。
但是,您的问题是,您不是首先发送表单数据,而是发送JSON。将这些行替换为:
data = json.loads(request.body)
答案 1 :(得分:0)
如果POST请求与邮递员一起正常工作,那么您从reactjs发送的JSON格式可能有问题。 控制台this.state并检查其是否采用正确的JSON格式。