关于post请求报错

400

400错误是因为
前端提交的到后台的数据应该是json字符串类型
而前端没有将对象转化为字符串类型;

400解决方法:

<head>
    <script type="text/javascript">
        function regist(){
            $.ajax({
                url:"/",
                <!--使用JSON.stringify(param)来转换json -->
                data:JSON.stringify({ username: $("#username").val(),
                    password: $("#password").val(),
                    })
                dataType:"json",
                type:"POST",
                
            })
        }
    </script>
</head>

403

Cross—Site Request Forgery(跨站点请求伪造)
在springsecurity4.0之后 默认开启CSRF防护
Spring Security CSRF会针对PATCH,POST,PUT和DELETE方法进行防护。
在启用@EnableWebSecurity 之后 CSRF防护便会自动开启
这时候 没有token的post请求就会被拦截

415

415是因为传入数据contentType有误
需要在Ajax中加入contentType:"application/json,

415 403解决方法:

<head>
    <!--CSRF令牌-->
    <meta name="_csrf" th:content="${_csrf.token}"/>
    <meta name="_csrf_header" th:content="${_csrf.headerName}"/>
    <script type="text/javascript">
        function regist(){
            var csrfToken = $("meta[name='_csrf']").attr("content");
            var csrfHeader = $("meta[name='_csrf_header']").attr("content");
            $.ajax({
                url:"",
                data:"",
                dataType:"json",
                type:"POST",
                <!--错误415:加上这一行contentType表单中默认是application/x-www-form-urlencoded-->
                contentType:"application/json;charset=utf-8",

                beforeSend: function(request) {
                    request.setRequestHeader(csrfHeader, csrfToken); // 添加  CSRF Token
                },
            })
        }
    </script>
</head>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值