json包含单双引号问题解决方案
解决方案:在后台处理 JSONArray.fromObject(list).toString()
转自明明如月小角落:
效果DEMO:
JsonQuotesUtil.js
- /**
- * 解决json传输数据时存在 同时存在单引号和双引号的问题
- *
- * 思路:
- *
- * 1 首选将 双引号转义
- *
- * 2 将 单双引号用不容易在字符串中出现的字符分别替换
- * 在后台 分别用过单双引号替换掉即可
- *
- * 注:可以传入字符串 也可以传入字符串数组
- * author: 明明如月 QQ 605283073
- * time:2015年5月19日15:33:44
- */
- function JsonQuotesUtil()
- {
- var defualtSingleQuotePlaceholder="s%0";//默认单引号占位符
- var defualtDoubleQuotePlaceholder="d%1";//默认双引号占位符
- var singleQuotePlaceholder=defualtSingleQuotePlaceholder;//单引号占位符
- var doubleQuotePlaceholder=defualtDoubleQuotePlaceholder;//双引号占位符
- //设置单引号占位符(建议起不容易出现的字符)
- this.setSingleQuotePlaceholder = function(single)
- {
- singleQuotePlaceholder=single;
- return this;
- }
- //设置双引号占位符(建议起不容易出现的字符)
- this.setDoubleQuotePlaceholder = function(double)
- {
- doubleQuotePlaceholder=double;
- return this;
- }
- //恢复默认单引号和双引号占位符
- this.restoreDefaults = function()
- {
- singleQuotePlaceholder=defualtSingleQuotePlaceholder;
- doubleQuotePlaceholder=defualtDoubleQuotePlaceholder;
- return this;
- }
- //用单引号占位符替换单引号 并返回替换后的字符串
- this.replaceSingleQuote=function (str)
- {
- if(str instanceof Array)//如果是数组分别替换
- {
- for(var i=0;i<str.length;i++)
- {
- str[i]= str[i].replace(/'/g, singleQuotePlaceholder);
- }
- }else
- {
- str= str[i].replace(/'/g, singleQuotePlaceholder);
- }
- return str;
- }
- //用双引号替换符替换双引号 并返回替换后的字符串
- this.replaceDoubleQuote = function (str)
- {
- // return str.replace(/"/g, doubleQuotePlaceholder);
- if(str instanceof Array)//如果是数组分别替换
- {
- for(var i=0;i<str.length;i++)
- {
- str[i]= str[i].replace(/'/g, doubleQuotePlaceholder);
- }
- }else
- {
- str= str[i].replace(/'/g, doubleQuotePlaceholder);
- }
- return str;
- }
- this.replaceSingleAndDoubleQuote = function(str)
- {
- // return str.replace(/'/g,singleQuotePlaceholder).replace(/"/g, doubleQuotePlaceholder);
- if(str instanceof Array)//如果是数组分别替换
- {
- alert("1");
- for(var i=0;i<str.length;i++)
- {
- alert(str[i]);
- str[i]= str[i].replace(/'/g,singleQuotePlaceholder).replace(/"/g, doubleQuotePlaceholder);
- }
- }else
- {
- str= str.replace(/'/g,singleQuotePlaceholder).replace(/"/g, doubleQuotePlaceholder);
- }
- return str;
- }
- //双引号转义
- this.escapeDoubleQuote = function(str)
- {
- if(str instanceof Array)//如果是数组分别替换
- {
- alert("1");
- for(var i=0;i<str.length;i++)
- {
- alert(str[i]);
- str[i]= str[i].replace(/"/g,"\\\"");
- }
- }else
- {
- str= str.replace(/"/g,"\\\"");;
- }
- return str;
- }
- }
demo.js 使用范例:
- /**
- * Created by Administrator on 2015/5/19 0019.
- */
- $(function(){
- //替换单双引号按钮的点击事件
- $("#show").click(function(){
- var sourceStr =$("#sourceStr").val();//获取需要替换字符
- /* 使用方法1 创建对象并自定义 单双引号占位符
- var jsonQuotesUtil = new JsonQuotesUtil().setSingleQuotePlaceholder
- ("%^^").setDoubleQuotePlaceholder("&&");//创建对象(同时自定义单双引占位符)*/
- /* 使用方法2 自定义对象并自定义 单双引号占位符
- var jsonQuotesUtil = new JsonQuotesUtil();//创建对象使用默认单双引号占位符
- jsonQuotesUtil.setSingleQuotePlaceholder("%^^");
- jsonQuotesUtil.setDoubleQuotePlaceholder("##");*/
- // jsonQuotesUtil.restoreDefaults();//恢复默认的单双引号占位符
- /* 使用方法3 自定义对象并自定义 单双引号占位符
- var jsonQuotesUtil = new JsonQuotesUtil();//创建对象使用默认单双引号占位符
- */
- var jsonQuotesUtil = new JsonQuotesUtil();//创建对象使用默认单双引号占位符
- var single =$("#single").val();//获取 单引号占位符
- var double = $("#double").val();//获取输入的双引号占位符
- if($.trim(single)!="")
- {
- jsonQuotesUtil.setSingleQuotePlaceholder(single);//设置单引号占位符
- }
- if($.trim(double)!="")
- {
- jsonQuotesUtil.setDoubleQuotePlaceholder(double);//设置双引号占位符
- }
- var reuslt = jsonQuotesUtil.replaceSingleAndDoubleQuote(sourceStr);//同时替换单双引
- 号
- // var reuslt = jsonQuotesUtil.escapeDoubleQuote(sourceStr)
- $("#replaceResult").html(reuslt);//显示替换后的字符串
- });
- $("#escape").click(function(){
- var sourceStr =$("#sourceStr").val();//获取需要替换字符
- var reuslt = new JsonQuotesUtil().escapeDoubleQuote(sourceStr);
- $("#replaceResult").html(reuslt);//显示替换后的字符串
- });
- function arrayTest()//支持数组每个字符串的替换(没有调用)
- {
- var jsonQuotesUtil = new JsonQuotesUtil();//创建对象使用默认单双引号占位符
- var sourceStr = new Array();
- sourceStr[0]="dfdfd'dfdf";
- sourceStr[1]="dfdfd\"sfdsfsd";
- alert("sourceStr"+sourceStr);
- var reuslt = jsonQuotesUtil.replaceSingleAndDoubleQuote(sourceStr);//同时替换单双引
- 号
- alert( "after:"+reuslt);
- }
- });
JsonQuotesUtil Demo.html
- <!DOCTYPE html>
- <html>
- <head lang="en">
- <meta charset="UTF-8">
- <title>JsonQuotesUtil Demo</title>
- <script type="text/javascript" src="libs/js/jquery.js"></script>
- <script type="text/javascript" src="libs/js/JsonQuotesUtil.js"></script>
- <script type="text/javascript" src="libs/js/demo.js"></script>
- </head>
- 请输入带有单双引号的字符串:<br/>
- <textarea rows="10" cols="65" id="sourceStr">This is a simple solution for SingleQuote( ') and DoubleQuote(") in json </textarea>
- <br/><br/>
- 单引号占位符:<input id="single" type="text" placeholder="s%0"/> 双引号占位符:<input id="double" type="text" placeholder="d%1"/>
- <br/> <br/>
- <input type="button" id="show" value="替换单双引号"> <input type="button" id="escape" value="转义双引号">
- <br/>
- <span id="replaceResult"></span>
- </form>
- </body>
- </html>
后台解析Util:
- package reg;
- /**
- * 解决json传输数据时存在 同时存在单引号和双引号的问题
- *
- * 思路:
- * 将 单双引号用不容易在字符串中出现的字符分别替换
- * 在后台 分别用过单双引号替换掉即可
- * 注:可以传入字符串 也可以传入字符串数组
- *
- * author: 明明如月 QQ 605283073
- * time:2015年5月19日15:33:44
- */
- public class JsonQuotesUtil
- {
- private String defualtSingleQuotePlaceholder="s%0";//默认单引号占位符
- private String defualtDoubleQuotePlaceholder="d%1";//默认双引号占位符
- public JsonQuotesUtil()
- {
- super();
- }
- public JsonQuotesUtil(String defualtSingleQuotePlaceholder,
- String defualtDoubleQuotePlaceholder)
- {
- super();
- this.defualtSingleQuotePlaceholder = defualtSingleQuotePlaceholder;
- this.defualtDoubleQuotePlaceholder = defualtDoubleQuotePlaceholder;
- }
- //恢复单引号(字符串)
- public String restoreSingleQuotes(String str)
- {
- return str.replaceAll(defualtSingleQuotePlaceholder, "\'");
- }
- public String[] restoreSingleQuotes(String[] strs)//恢复单引号(数组)
- {
- for(int i =0;i<strs.length;i++)
- {
- strs[i]= strs[i].replaceAll(defualtSingleQuotePlaceholder, "\'");
- }
- return strs;
- }
- //恢复双引号
- public String restoreDoubleQuote(String str)//恢复单引号(数组)
- {
- return str.replaceAll(defualtDoubleQuotePlaceholder, "\"");
- }
- public String[] restoreDoubleQuote(String[] strs)
- {
- for(int i =0;i<strs.length;i++)
- {
- strs[i]= strs[i].replaceAll(defualtSingleQuotePlaceholder, "\'");
- }
- return strs;
- }
- //恢复单双引号
- public String restoreSingleAndDoubleQuote(String str)
- {
- return str.replaceAll(defualtSingleQuotePlaceholder, "\'").replaceAll(defualtDoubleQuotePlaceholder, "\"");
- }
- public String[] restoreSingleAndDoubleQuote(String[] strs)//恢复单双引号(数组)
- {
- for(int i =0;i<strs.length;i++)
- {
- strs[i]= strs[i].replaceAll(defualtSingleQuotePlaceholder, "\'").replaceAll(defualtDoubleQuotePlaceholder, "\"");
- }
- return strs;
- }
- public String getDefualtSingleQuotePlaceholder()
- {
- return defualtSingleQuotePlaceholder;
- }
- public void setDefualtSingleQuotePlaceholder(String defualtSingleQuotePlaceholder)
- {
- this.defualtSingleQuotePlaceholder = defualtSingleQuotePlaceholder;
- }
- public String getDefualtDoubleQuotePlaceholder()
- {
- return defualtDoubleQuotePlaceholder;
- }
- public void setDefualtDoubleQuotePlaceholder(String defualtDoubleQuotePlaceholder)
- {
- this.defualtDoubleQuotePlaceholder = defualtDoubleQuotePlaceholder;
- }
- }
Util使用方法:
- package reg;
- public class JsonQuotesUtilDemo
- {
- public static void main(String args[])
- {
- //获取前台传入的参数
- String str="This is a simple solution for SingleQuote(s%0) and DoubleQuote(d%1) in json This is a simple solution for SingleQuote(s%0) and DoubleQuote(d%1) in json";
- JsonQuotesUtil jsonQuotesUtil = new JsonQuotesUtil("s%0","d%1");
- System.out.println(jsonQuotesUtil.restoreSingleAndDoubleQuote(str));
- }
- }
json包含单双引号问题解决方案的更多相关文章
- php单双引号嵌套解决方案
代码如下: <?php $path = "./"; function show_files($path){ //下面是单双引号嵌套解决方案 //echo "< ...
- python笔记22-literal_eval函数处理返回json中的单双引号
前言 在做接口测试的时候,最常见的接口返回数据就是json类型,json类型数据实际上就是字串,通常标准的json格式是可以转化成python里面的对应的数据类型的 有时候开发返回的数据比较坑,不按常 ...
- python 单双引号交替的json串
单双引号交替的json串 1.常见的json串,类似于这种{"isSucess":true, "name":"yoyo", "st ...
- php单双引号
1.定义字符串 定义字符串时,只有一种引号被视为定义符,即单引号或双引号.于是,如果一个字符串由双引号开始,那么只有双引号被分析器解析.这样,你就可以在双引号串中包含任何其他字符,甚至单引号.下面的引 ...
- sql语句的单双引号问题
$current_account_url='<a class="mini-button" iconcls="icon-edit" onclick=&quo ...
- JS中反斜杠和单双引号的配合使用效果
<div id="tag"></div> <div id="tag1"></div> <div id=&q ...
- php中alert弹出时单双引号问题
php代码中单双引号问题是个很重要的问题,使用不当会造成很多麻烦.先记录一下今天写alert遇到的麻烦.我做登录的时候,成功时想弹出个提示说登录成功.写alert语句时不显示.其实就是单双引号弄得不对 ...
- JS中字符串拼装 单双引号的处理 字符转义
js中可能会用到动态追加元素,可能数据也是从后台传过来的,当然有两种思路, 1.在后台拼装好直接返回; 2.在前台js里面拼装, 如果拼装大量的html时可能单双引号就容易出问题;那么如何解决呢?最近 ...
- 单双引号的区别,defined容易疏忽的小地方
单双引号的区别(面试题) 1.双引号可以解析变量,单引号不行 2.双引号解析转义字符,单引号不解析转义字符.但是单引号能解析 ...
随机推荐
- python中的对象
一.python对象 python使用对象模型来存储数据.构造任何类型的值都是一个对象. 所有python对象都拥有三个特性:身份.类型.值 身份:每个对象都有一个唯一的身份标识自己,任何对象的身份可 ...
- snapshot相关
概述 Specify the number of days of snapshots to choose from Entering the number of days (n) will resul ...
- slf4j简单使用
一 slf4j+log4j 1.添加依赖 <!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-log4j12 --> <d ...
- 2018-2019-2 网络对抗技术 20165202 Exp5 MSF基础应用
博客目录 一.实践目标 二.实践内容 一个主动攻击实践,ms08_067(成功).ms03_026(成功且唯一); 一个针对浏览器的攻击,如ms11_050(成功)ms11_03(失败.唯一)ms10 ...
- css 兼容 各类手机的写法 待续
@media (device-height:480px) and (-webkit-min-device-pixel-ratio:2){/* 兼容iphone4/4s */ .class{} } @m ...
- Android中Parcel的分析以及使用
简单点来说:Parcel就是一个存放读取数据的容器, Android系统中的binder进程间通信(IPC)就使用了Parcel类来进行客户端与服务端数据的交互,而且AIDL的数据也是通过Parcel ...
- 一款经典的 jQuery Lightbox 灯箱效果
一个灯箱效果的图片展示插件. 版本: jQuery v1.2.3+ jQuery Lightbox v2.7.1 github 实例预览 使用方法 载入 CSS 文件 <link rel=&qu ...
- pseudo tty破除无法自动输入密码的限制
没有root权限,没有ssh密钥对,又想自动输入密码咋办? #!/usr/bin/python # simplest builtin python pseudo-tty for ssh passwor ...
- kafka知识点整理总结
kafka知识点整理总结 只不过是敷衍 2017-11-22 21:39:59 kafka知识点整理总结,以备不时之需. 为什么要使用消息系统: 解耦 并行 异步通信:想向队列中放入多少消息就放多少, ...
- 从 0 到 1 合理高效使用 GitHub 的资料
来自:https://github.com/xirong/my-git/blob/master/how-to-use-github.md 说明 作为一名开发者,Github上面有很多东西值得关注学习, ...