分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 技术分享

jquery ajax contentType设置

发布时间:2023-09-06 02:29责任编辑:顾先生关键词:暂无标签

  默认get方法没有contentType,post方法的contentType为:application/x-www-form-urlencoded; charset=UTF-8

(1) 设置成application/x-www-form-urlencoded, 后端可以直接用

String username = request.getParameter("username");String password = request.getParameter("password");

getParamter方法获取。

如:

 ???????????$.ajax({ ???????????????type: ‘post‘, ???????????????url:‘/contentType‘, ???????????????contentType:‘application/x-www-form-urlencoded‘, ???????????????data:{ ???????????????????username:‘admin‘, ???????????????????password:‘123123‘ ???????????????}, ???????????????dataType:‘json‘, ???????????????success:function (data) { ???????????????} ???????????}) ???

(2)设置成application/json

这个时候可以看出取不到数据了。

解决办法:

InputStream inputStream = request.getInputStream();String param = IOUtils.toString(inputStream);

如果这样请求:

$.ajax({ ???type: ‘post‘, ???url:‘/contentType‘, ???contentType:‘application/json‘, ???data:{ ???????username:‘admin‘, ???????password:‘123123‘ ???}, ???dataType:‘json‘, ???success:function (data) { ???}})

拿到的是一个&分隔开的键值对

所以前端先做一层json的转化:

var info ={ ???username:‘admin‘, ???password:‘123123‘};$.ajax({ ???type: ‘post‘, ???url:‘/contentType‘, ???contentType:‘application/json‘, ???data: JSON.stringify(info), ???dataType:‘json‘, ???success:function (data) { ???}})

然后就可以得到标准的json的格式了。接下来就是json的转化了

接下来测试:‘application/json‘和‘application/x-www-form-urlencoded‘能携带的数据量的差异:

用application/json:后面‘2’长度几十万,后端都可以接收。

改用另外一个也可以

jquery ajax contentType设置

原文地址:https://www.cnblogs.com/chenmz1995/p/10226683.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved