前后台JSON传值得一个问题和异常处理net.sf.json.JSONException: Unquotted string '"name"'
项目中做导入的时候遇到个bug,用JSON.stringify()序列号json对象传给后台;然后后台通过getPatameter()获取值时,前台的英文引号变成了中文引号。
原来代码如下:(自己排查发现就算是英文的时候也是如此)
//提交事件
$("#submitButton").bind("click",function(){
if($("#addForm").valid()){
var jsonStr = {};
$("#itemTable").find("input[lang='userAdd']").each(function(index,obj){
var nameAttr = $(obj).attr("id").trim();
var valueAttr = $('#'+nameAttr).combobox('getValue').trim();
if (valueAttr != "" && valueAttr != undefined) {
jsonStr[valueAttr] = nameAttr;
}
});
var json = new Object();
json.name = "ss";
json.age = "";
var data = JSON.stringify(json);
var att = {};
att["password"] = $("#text_pwd").val();
att["organization"] = $("#text_organization").combotree("getValue"); $(this).attr("disabled","disabled");
Loading(true,"<s:text name='cems.soft.progress.handling'></s:text>");//遮罩提示
$.doAjax({
url:'${basePath}/user/userAction_userAdd.do',
data:{"data":data,"arrdata":JSON.stringify(att)},
async:true,
success:function(responseText){
在后台获取时,前台的英文引号,在后台变成了中文引号,导致JSON解析出错,报异常:net.sf.json.JSONException: Unquotted string '”ss”'
/**
* 映射字段
*/
public void userAdd(){
log.info("用户批量导入_PBEG");
this.msg=RESULT_FAIL;
long startTime = System.currentTimeMillis();//获取当前时间
String initPassword = "";
File file = null;
List<User> list = new ArrayList<User>();
List<UserCache> userCaches = new ArrayList<UserCache>();
List<String> failedFailName = new ArrayList<String>();
Organization default_org = null;
try {
String data = getRequest().getParameter("data");
String arrdata =getRequest().getParameter("arrdata");
JSONObject jsonData = JSONObject.fromObject(data);
JSONObject jsonArrdata = JSONObject.fromObject(arrdata);
String arrPassword = jsonArrdata.containsKey("password") ? jsonArrdata.getString("password") : "";
String arrOrganization = jsonArrdata.containsKey("organization") ? jsonArrdata.getString("organization") : "";
解决方案:
经过几次json转换的尝试,发现结果均是如此,所以最后决定采用注入的方式处理。
//提交事件
$("#submitButton").bind("click",function(){
if($("#addForm").valid()){
var jsonStr = {};
$("#itemTable").find("input[lang='userAdd']").each(function(index,obj){
var nameAttr = $(obj).attr("id").trim();
var valueAttr = $('#'+nameAttr).combobox('getValue').trim();
if (valueAttr != "" && valueAttr != undefined) {
jsonStr[valueAttr] = nameAttr;
}
});
var data = JSON.stringify(jsonStr);
var att = {};
att["password"] = $("#text_pwd").val();
att["organization"] = $("#text_organization").combotree("getValue"); $(this).attr("disabled","disabled");
Loading(true,"<s:text name='cems.soft.progress.handling'></s:text>");//遮罩提示
$.doAjax({
url:'${basePath}/user/userAction_userAdd.do',
data:{"data":data,"arrdata":JSON.stringify(att)},
async:true,
success:function(responseText){
后台:采用注入方式
private String data;
public String getData() {
return data;
}
public void setData(String data) {
this.data = data;
} private String arrdata;
public String getArrdata() {
return arrdata;
}
public void setArrdata(String arrdata) {
this.arrdata = arrdata;
}
/**
* 映射字段
*/
public void userAdd(){
log.info("用户批量导入_PBEG");
this.msg=RESULT_FAIL;
long startTime = System.currentTimeMillis();//获取当前时间
String initPassword = "";
File file = null;
List<User> list = new ArrayList<User>();
List<UserCache> userCaches = new ArrayList<UserCache>();
List<String> failedFailName = new ArrayList<String>();
Organization default_org = null;
try {
//String data = getRequest().getParameter("data");
//String arrdata =getRequest().getParameter("arrdata");
JSONObject jsonData = JSONObject.fromObject(data);
JSONObject jsonArrdata = JSONObject.fromObject(arrdata);
String arrPassword = jsonArrdata.containsKey("password") ? jsonArrdata.getString("password") : "";
String arrOrganization = jsonArrdata.containsKey("organization") ? jsonArrdata.getString("organization") : ""; String excelPath = getServletContext().getRealPath(USEREXCELTEMPLATE_DOWNLOADPATH+USEREXCELTEMPLATE_FILE);
file = new File(excelPath);
if(!file.exists() && !file.isDirectory()){
this.msg = "readErr";
throw new IllegalStateException("用户批量导入-->用户导入临时文件不存在!");
}
List<UserExport> userExports = new ArrayList<UserExport>();
前后台JSON传值得一个问题和异常处理net.sf.json.JSONException: Unquotted string '"name"'的更多相关文章
- net.sf.json.JSONException: java.lang.NoSuchMethodException
在尝试将json对象转换为list时候出现了如下错误 Exception in thread "main" net.sf.json.JSONException: java.lang ...
- net.sf.json.JSONException: There is a cycle in the hierarchy!
因为项目中使用了AJAX技术,jar包为:json-lib.jar,在开发过程中遇到了一个JSON-LIB和Hibernate有关的问题: 如hibernate延迟加载错误,这都是些老问题了,一看就知 ...
- Java中net.sf.json包关于JSON与对象互转的问题
在Web开发过程中离不开数据的交互,这就需要规定交互数据的相关格式,以便数据在客户端与服务器之间进行传递.数据的格式通常有2种:1.xml:2.JSON.通常来说都是使用JSON来传递数据.本文正是介 ...
- Java中net.sf.json包关于JSON与对象互转的坑
在Web开发过程中离不开数据的交互,这就需要规定交互数据的相关格式,以便数据在客户端与服务器之间进行传递.数据的格式通常有2种:1.xml:2.JSON.通常来说都是使用JSON来传递数据.本文正是介 ...
- net.sf.json.JSONOBJECT.fromObject 与 com.alibaba.fastjson.JSONObject.parseObject
文章待补充,先写写以下知识点好了. NULL值处理之 net.sf.json.JSONObject 和 com.alibaba.fastjson.JSONObject区别 JSON作为一个轻量级的文本 ...
- net.sf.json和 com.fasterxml.jackson中对象转json的区别
近期做项目的时候,发现使用net.sf.json包中的JSONObject或JSONArray将对象转为json数据结构存在一个坑.当对String类型的属性赋值为null情况下,转为json结构为& ...
- net.sf.json JSONObject与JSONArray总结
JSONObject:json对象,就是一个键对应一个值,使用的是大括号{ },如:{key:value} JSONArray:json数组,使用中括号[ ],只不过数组里面的项也是json键值对格式 ...
- net.sf.json.JSONObject 和org.json.JSONObject 的差别
http://my.oschina.net/wangwu91/blog/340721 net.sf.json.JSONObject 和org.json.JSONObject 的差别. 一.创建jso ...
- json解析异常 - net.sf.json.JSONException: java.lang.reflect.InvocationTargetException
注:在项目中, 我使用原生的ajax请求数据的时候, JSONObject没能帮我解析, 当却不给我报错, 我是在junit单元测试中测试的时候, 发现的.发现好多时候, 特别是通过ajax请求, 不 ...
随机推荐
- ubuntu系统更换源
一:问题概述 ubuntu,我们在使用apt新装软件的时候,会使用官方的网站去下载软件,但是会因为国内的转接点太多,而导致下载的速度非常慢 ,我们可以通过换成一些中间的节点来进行下载,比如阿里源,中科 ...
- [bzoj3065] 带插入区间第k小值 [重量平衡树套线段树]
题面 传送门 思路 发现强制在线了...... 本来可以树套树解决的问题,现在外层不能使用线段树了,拿什么替代呢? 我们需要一种支持单点插入.下套数据结构.数据结构上传合并复杂度最多单log,不能旋转 ...
- POJ 1236 Networks of School Tarjan 基础
题目大意: 给一个有向图,一个文件可以从某个点出发传递向他能连的边 现在有两个问题 1.至少需要多少个放文件可以让整个图都有文件 2.可以进行一个操作:给一对点(u,v)连一条u->v的有向边, ...
- SpringBoot Redis序列化配置
Redis配置 #Redis spring.redis.host= spring.redis.port=6379 spring.redis.database=0 # Redis服务器连接密码(默认为空 ...
- SoundPool 播放提示音
SoundPool 一个声音播放的辅助类,从名字可以看出,它具有 “池”的能力,它先加载声音文件到内存,以支持多次播放声音文件. 特点 SoundPool适合 短小的 声音文件 SoundPool适合 ...
- Linux下使用system()函数一定要谨慎
转载自:http://my.oschina.net/renhc/blog/53580 linux尽量避免使用system. 曾经的曾经,被system()函数折磨过,之所以这样,是因为对syste ...
- python2 登录带验证码的页面
#!/usr/bin/python#-*- coding: utf-8 -*- import os,json;import urllib,urllib2;import cookielib; #获取co ...
- 同样的promise,调用方法不一样,执行顺序不一样
在测试两个不同的代码时发现的. 其实也理解,一个是新建一个空的promise,另一个是新建的promise马上执行,去分支resolve状态, 当然就空的在后. <script> //se ...
- win2008通过计划任务定时执行bat文件
前段时间在Windows Server 2008安装了一套基于MySQL数据库的软件,处于数据安全的考虑,希望每天能够自动进行数据库备份.我在别人脚本的基础上自己写了一个数据库备份的bat脚本,双击该 ...
- Ubuntu 14.04LTS+Git
Git是我们常用的代码托管工具,作为程序员,Git是必备的. 安装Git的方法很简单,官网就有写:http://git-scm.com/download/linux 根据官网的说明,用: sudo a ...