Django应用程序应如何处理reactjs表单的发布请求

时间:2019-07-06 05:43:00

标签: python django reactjs django-views

我在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上上传的应用程序的网址。

2 个答案:

答案 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格式。