大家好,欢迎来到IT知识分享网。
问题场景:当项目的前端页面使用ajax请求访问后端时,出现该错误。
我这里是测试接口时,发生了错误。
原因一:请求参数个数不对。
后端接口上明确规定了请求参数的个数。比如:接口(方法)中的值中使用了requestparam注解,requestparam注解中有个require属性,默认为true,意思则是,必须要传该参数的值(该参数不可为空)。
解决办法:
1.如果该参数是可传可不传的,修改require属性为false。
2.检查前端js文件中对应的ajax请求中的请求数据是否为空,或者是否有该参数。
原因二:请求参数的类型不对
常见情况有:前端传时间格式,后端用String接收。或者前端传的不是json数据,后端实体类封装不了。
解决方法:
1.检查前后端对应参数类型是否对应。
2.前端ajax请求如果是post请求,同时contentType属性为
contentType:'application/json;charset=UTF-8'
,这时候前端data传值必须为json字段串,要将对应对象使用JSON.stringify(param)将对象转化成json字段串。
例子如下:
// 创建对象
var person = new Object()
// 添加属性
person.name = '张三'
person.sex = '男'
$.ajax({
url: ctxPath + '/save', //请求路径
data: JSON.stringify(person), //请求参数,将对象转json字符串
type:'POST', //请求类型
contentType: 'application/json;charset=UTF-8', //请求数据类型
dataType:'text', //返回数据类型 如果后端返回一个消息对象 这里为json
success : function (result) {
console.log(result);
},
error: function (err) {
console.log(result);
}
});
原因三:Get请求的url长度超过浏览器或web服务器限制。
浏览器对url的长度限制自行上网搜索。这里简单说一下常用的两个浏览器对url长度的限制。
1.谷歌(chrome)浏览器:8182字节
2.火狐(Firefox)浏览器:65536字节
服务器对url的限制
Tomcat:长度限制为8192字节
nginx:可以通过设置属性来扩展url长度
large_client_header_buffers 4 1m (请求行(url)+请求头的数据为4*1024k)
例如
http {
include mime.types;
default_type application/octet-stream;
large_client_header_buffers 4 1k; // http请求行(url)最大为1k
server {
listen 80;
server_name 192.168.1.100;
}
server {
listen 80 default; // 当有多个server模块时,会优先使用default server 的属性配置
server_name 192.168.1.100;
large_client_header_buffers 4 1m;
}
}
Nginx配置学习:https://www.jianshu.com/p/20a687873bf0
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/22626.html