ajax 发送json 后台接收 遍历保存进数据库
前台怎么拿参数的我就不管了我也不会
反正用这个ajax没错
ajax 代码 一定要写明http请求类型 {
contentType:"application/x-www-form-urlencoded; charset=utf-8",
}这一段很重要(就是因为这个原因我找了整整一下午)
服务器为什么会对表单提交和文件上传做特殊处理,因为表单提交数据是名值对的方式,且Content-Type为application/x-www-form-urlencoded,
而文件上传服务器需要特殊处理,普通的post请求(Content-Type不是application/x-www-form-urlencoded)数据格式不固定,
不一定是名值对的方式,所以服务器无法知道具体的处理方式,所以只能通过获取原始数据流的方式来进行解析。
jquery在执行post请求时,会设置Content-Type为application/x-www-form-urlencoded,所以服务器能够正确解析,
而使用原生ajax请求时,如果不显示的设置Content-Type,那么默认是text/plain,这时服务器就不知道怎么解析数据了,
所以才只能通过获取原始数据流的方式来进行解析请求数据。
function orderFood(){
alert("进来了++++++++++");
final_settle();
/* alert("http://192.168.10.98:8080/jeesite/f/cms/received/submit"); */
console.log(JSON.stringify(globalJsonArray));
$.ajax({
type : "post",
url : "/jeesite/f/received/submit",
dataType:"json",
contentType:"application/x-www-form-urlencoded; charset=utf-8",
data:{orderInfo:jsonStr},//JSON.stringify(globalJsonArray),
success : function(result) {
alert(result.msg);
}
});
}
后面接收的代码 写好方法名称还有请求类型
@Controller
@RequestMapping(value = "${frontPath}/received")
public class FrontReceivedata extends BaseController{ @RequestMapping(value = "submit",method =RequestMethod.POST)
public String submit(HttpServletRequest request,HttpServletResponse response){
String week = request.getParameter("orderInfo");
System.out.println("=====================================");
System.out.println("requestJson:"+week);
System.out.println("=====================================");
定几个全局变量 然后吧json转换成JSONObjcet格式(可以百度下格式)for循环下得到相应的值
最好加个判空的if
获取到了值放进那张表里保存的方法里面
for(int i = ;i<jsonArray.size(); i++){
//转换
//JSONObject list = jsonArray.getJSONObject(i);
JSONObject list = (JSONObject) jsonArray.get(i);
//各变量的if(){}
//测试值 S
System.out.println("orderList:"+orderList);
System.out.println("allpriice:"+allpriice);
System.out.println("num:"+num);
//判断为空
if(list.get("orderlist")!= null){
orderList = (JSONArray)list.get("orderlist");
}
if(list.get("allpriice") != null){
allpriice = (String)list.get("allpriice");
}
if(list.get("num") != null){
num = (String)list.get("num");
}
}
//把数据放进保存方法里面
WOrder worder = new WOrder();
String a="WXDC"; //订单号前缀
Date dt= new Date();
Long time= dt.getTime();//这就是距离1970年1月1日0点0分0秒的毫秒数
String SingleNumber=a+time; //完整订单号
worder.setCid(SingleNumber); //订单号
worder.setAmount(allpriice);//总金额
worder.setOrderNumber(num);//桌号
Worderservice.save(worder);
如果json里面有多个字段 就用两个for循环 循环出来 然后保存进指定的数据库表里
if(orderList.size()!=){
for(int j= ;j<orderList.size();j++){
JSONObject orderInfo = (JSONObject) orderList.get(j);
//判断为空
if(orderInfo.get("number") != null){
number = (String)orderInfo.get("number");
}
if(orderInfo.get("foodid") != null){
foodid = (String)orderInfo.get("foodid");
}
System.out.println("number+++:"+number);
System.out.println("fooddid+++:"+foodid);
//数据保存方法
WChildorder wchildorder = new WChildorder();
wchildorder.setOid(SingleNumber); //订单号
wchildorder.setNumber(number);//分量
wchildorder.setDid(foodid);//菜的id
wchiservice.save(wchildorder);
}
}
最好抛个异常 让前台判断 返回的是一个map 不过返回的map 方法上面需要加@ResponseBody这个注释
result.put("result", "保存成功");
result.put("code", "");
result.put("SingleNumber", SingleNumber);
} catch (Exception e) {
e.printStackTrace();
result.put("result", "保存失败");
result.put("code", "");
}
//返回的
return result;
}
到这就差不多了 自己写的过程中多测试测试 多写几个输出语句看有没有拿到值
还有的前台传过来json的格式一定要写完整规范 不然不好取出来
有的问题实在解决不了的就重启电脑 哈哈哈
ajax 发送json 后台接收 遍历保存进数据库的更多相关文章
- AJAX发送json,SpringMVC 接收JSON,@RequestBody
需求:JQuery ajax前台,采用 POST请求 发送json,后台使用SpringMVC接收json并处理 前台: $.ajax({ url:"请求地址", type:&qu ...
- ajax参数传递与后台接收
目录 ajax参数传递与后台接收 Servlet中读取http参数的方法 使用默认contentType,参数追加到url后传递 使用默认contentType,参数放到data中传递 使用默认con ...
- ajax 发送json数据时为什么需要设置contentType: "application/json”
1. ajax发送json数据时设置contentType: "application/json”和不设置时到底有什么区别? contentType: "application/j ...
- ajax发送json数据时为什么需要设置contentType: "application/json”
1. ajax发送json数据时设置contentType: "application/json”和不设置时到底有什么区别?contentType: "application/js ...
- Django中数据传输编码格式、ajax发送json数据、ajax发送文件、django序列化组件、ajax结合sweetalert做二次弹窗、批量增加数据
前后端传输数据的编码格式(contentType) 提交post请求的两种方式: form表单 ajax请求 前后端传输数据的编码格式 urlencoded formdata(form表单里的) ja ...
- ajax发送json格式与文件数据、django自带的序列化器(了解)
上期内容回顾 聚合查询和分组查询 # 聚合查询 max min sum avg count # 查询关键字:aggregate from django.db.models import Max, Mi ...
- 怎样提交FIREDAC数据集的DELTA到中间件然后保存进数据库
你可以在客户端序列FireDAC数据集的DELTA , 将序列后的STREAM发送给中间件, 中间件的TFDQuery或TFDMemTable调用LOADFROMSTREAM()方法加载流, 然后调用 ...
- Java 读取Excel内容并保存进数据库
读取Excel中内容,并保存进数据库 步骤 建立数据库连接 读取文件内容 (fileInputStream 放进POI的对应Excel读取接口,实现Excel文件读取) 获取文件各种内容(总列数,总行 ...
- python 全栈开发,Day75(Django与Ajax,文件上传,ajax发送json数据,基于Ajax的文件上传,SweetAlert插件)
昨日内容回顾 基于对象的跨表查询 正向查询:关联属性在A表中,所以A对象找关联B表数据,正向查询 反向查询:关联属性在A表中,所以B对象找A对象,反向查询 一对多: 按字段:xx book ----- ...
随机推荐
- salesforce零基础学习(七十九)简单排序浅谈 篇一
我们在程序中经常需要对数据列表进行排序,有时候使用SOQL的order by 不一定能完全符合需求,需要对数据进行排序,排序可以有多种方式,不同的方式针对不同的场景.篇一只是简单的描述一下选择排序,插 ...
- 聊聊GIS中那些坐标系
从第一次上地图学的课开始,对GIS最基本的地图坐标系统就很迷.也难怪,我那时候并不是GIS专业的学生,仅仅是一门开卷考试的专业选修课,就没怎么在意. 等我真正接触到了各种空间数据产品,我才知道万里长征 ...
- 34、锁问题与线程queue
上一篇随笔我们学了全局解释器锁,前面也学了互斥锁,今天学习一些与锁相关的点,例如递归锁,信号量,Event,还会学习我们已经很熟悉的队列,不过这次的队列是作为一个模块出现的. 一.同步锁 1.join ...
- 转每天一个linux命令(2):cd命令
Linux cd 命令可以说是Linux中最基本的命令语句,其他的命令语句要进行操作,都是建立在使用 cd 命令上的. 所以,学习Linux 常用命令,首先就要学好 cd 命令的使用方法技巧. 1 ...
- postman 第1节 安装启动(转)
安装: 1.mac app安装 浏览器访问https://www.getpostman.com/apps,选择Get the Mac App,下载安装即可 2.chrome app安装 浏览器访问ht ...
- Java:用Lambda表达式简化代码一例
之前,调用第3方服务,每个方法都差不多“长”这样, 写起来啰嗦, 改起来麻烦, 还容易改漏. public void authorizeRoleToUser(Long userId, List< ...
- Mycat 设置全局序列号
详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt332 全局序列号介绍 在实现分库分表的情况下,数据库自增主键已无法保证自增主 ...
- oracle 索引失效的情况分析
见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp54 1) 没有查询条件,或者查询条件没有建立索引 2) 在查询条件上 ...
- 全平台轻量级 Verilog 编译器 & 仿真环境
一直苦于 modelsim 没有Mac版本,且其体量过大,在学习verilog 时不方便使用. 终于找到一组轻量级且全平台 ( Linux+Windows+macOS ) 的编译仿真工具组. Icar ...
- SUSE Linux Enterprise 11 离线安装 DLIB python机器学习模块
python机器学习模块安装 环境:SUSE Linux Enterprise 11 sp4 离线安装 说明:在安装dlib时依赖的基础 环境较多,先升级gcc,以适应c++ 11的使用:需要用到c ...