页面JSON和字符串之间的转换

来源:互联网 发布:maxdos网络克隆教程 编辑:程序博客网 时间:2024/06/07 01:20

第一种方式:

使用js函数eval();

testJson=eval(testJson);是错误的转换方式。

正确的转换方式需要加(): testJson = eval("(" + testJson + ")");

eval()的速度非常快,但是他可以编译以及执行任何javaScript程序,所以会存在安全问题。在使用eval()。来源必须是值得信赖的。需要使用更安全的json解析器。在服务器不严格的编码在json或者如果不严格验证的输入,就有可能提供无效的json或者载有危险的脚本,在eval()中执行脚本,释放恶意代码。

js代码:
function ConvertToJsonForJs() {            //var testJson = "{ name: 'xx', age: 16 }";(支持)            //var testJson = "{ 'name': 'xx', 'age': 16 }";(支持)            var testJson = '{ "name": "xx", "age": 16 }';            //testJson=eval(testJson);//错误的转换方式            testJson = eval("(" + testJson + ")");            alert(testJson.name);        } 

第二种方式使用jquery.parseJSON()方法对json的格式要求比较高,必须符合json格式

jquery.parseJSON()

js:代码
function ConvertToJsonForJq() {            var testJson = '{ "name": "xx", "age": 16 }';            //不知道            //'{ name: "xx", age: 16 }' (name 没有使用双引号包裹)            //"{ 'name': "xx", 'age': 16 }"(name使用单引号)            testJson = $.parseJSON(testJson);            alert(testJson.name);        }  

0 0