`
literary_fly
  • 浏览: 90173 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

JSON.parse() 与 eval()

 
阅读更多
JSON(JavaScript Object Notation)是一種輕量級的數據格式,采用完全獨立於語言的文本格式,是理想的數據交換格式。同時,JSON是Javascript原生格式,這意味着在javascript中處理JSON數據不需要任何特殊的API或工具包,而且效率非常高。

     JSON的結構如下:

“名稱/值”對的集合(A collection of name/value pairs)。不同的語言中,它被理解为對象(object),紀錄(record),結構(struct),字典(dictionary),哈希表(hash table),有鍵列表(keyed list),或者關聯數組 (associative array)。
值的有序列表(An ordered list of values)。在大部分語言中,它被理解为數組(array)
      一個標准的json格式:

{"name":"jifeng","company":"taobao"}      總體而言,json是相對比較容易的理解和使用的,但同時存在很多的陷阱,如果不注意的話很容易掉進去,本文主要就是講訴它容易讓人犯錯的地方。



      一、json的的解析方法

      json的解析方法共有兩種:1. eval() ; 2.JSON.parse()。具體使用方法如下

var jsonstr = '{"name":"jifeng","company":"taobao"}';//eval functionvar evalJson = eval('(' + jsonstr + ')');// JSON.parse functionvar JSONParseJson = JSON.parse(jsonstr);  

    既然兩者都能達到解析json的結果,但這兩者有什麼區別呢?我用以下的一個例子來進行說明:

    1. 用eval方法:

var parse_json_by_eval = function(str){    return eval('('+str+')');}var value = 1;var jsonstr = '{"name":"jifeng","company":"taobao","value":++value}';var json1 = parse_json_by_eval(jsonstr);console.log(json1);console.log('value: '+ value);    執行結果:

{ name: 'jifeng', company: 'taobao', value: 2 }value: 2    2. 用JSON.parse方法

var parse_json_by_JSON_parse = function(str){    return JSON.parse(str);}value = 1;var jsonstr = '{"name":"jifeng","company":"taobao","value":++value}';var json2 = parse_json_by_JSON_parse(jsonstr);console.log(json2);console.log(value);     執行結果:

     不能順利執行,報錯

    

     前者能順利執行,並修改了全局變量value的值,而後者報錯了。從上例就可以明顯地看出,eval在解析字符串時,會執行該字符串中的代碼(這样的後果是相當惡劣的),如上例中,由於用eval解析一個json字符串而造成原先的value的值改變。《高性能Javascript》一書即指出:

警告:關於JSON和eval需要注意的是:在代碼中使用eval是很危險的,特別是用它執行第三方的JSON數據(其中可能包含惡意代碼)時,盡可能使用JSON.parse()方法解析字符串本身。該方法可以捕捉JSON中的語法錯誤,並允許你傳入一個函數,用來過滤或轉換解析結果。如果此方法以備Firfox 3.5 、IE8 及 Safari 4 原生支持。大多數javascript類庫包含的JSON解析代碼會直接調用原生版本,如果沒有原生支持的話,會調用一個略微不那麼強大的非原生版本來處理。




      一、'\' 對JSON的影響

      由於JSON對象是從字符串解析而來,因此在了解 '\' 對JSON影響之前,我們先來了解 '\' 對字符串的影響。這裏特別要強調的是在javascript中 ' 和 " 在表示字符串時是等價,比如'a' = "a"

      眾所周知,由於String數據類型包含轉義字符,比如 '\n'表示換行,'\b'表示空格等,因此用表示 he say “hello” 這個字符串時,需要用 '\' 這個特殊字符來表示,即"he say \"hello \"" 。在chrome的中console.log()即可明顯的看出。
http://dl.iteye.com/upload/attachment/0062/0247/1e643d33-828d-3665-80f7-cb5adaf7b93d.jpg


     而JSON.parse()又是對字符串的真實含義進行解析,要表示 \ 必須要用"\\\\"表示,具體見下圖:

    http://dl.iteye.com/upload/attachment/0062/0249/dae6c992-ff46-3b6c-8104-af1c6f583271.jpg

    在json中出現'\'時,必須萬分小心,這的確是json中最容易出錯的地方

    在順便提一個小插曲:當我知道在json解析時需要用"\\\\"時表示"\"時,你用JSON.parse('{"a":"a\\b"}'),竟然沒有報錯,難道我理解錯了,細心的朋友應該看出來了,'\b'本身就是個轉義字符,因此這裏的第一個'\'是用來轉義第二個'\' ,這样字符串就編程'a\b'('\b'是個轉義字符),所以JSON.parse()還是可以順利解析的。

      對這個概念還是有點繞的,讀者需要多想想,自己當時也是花了較長的時間來想這個問題。







補充資料:

線上解析json網站:http://json.parser.online.fr/





From:http://www.cnblogs.com/lengyuhong/archive/2012/01/07/2262390.html
  • 大小: 9.8 KB
  • 大小: 5.2 KB
分享到:
评论
1 楼 lls17 2012-05-17  
受教了~  很好~

相关推荐

    JSON2.JS JSON.JS JSON_PARSE.JS

    uses recursive descent instead of eval. json_parse_state: This files contains an alternative JSON parse function that uses a state machine instead of eval. cycle.js: This file contains two functions...

    JSON中key动态设置及JSON.parse和JSON.stringify()的区别

    本文给大家介绍JSON中key动态设置及JSON.parse和JSON.stringify()的区别讲解,具体详情如下所示: var user_info_json = []; user_info_json[user_info_json.length] = eval('('+ '{'+ id +': '+ value +'}' +...

    javascript中JSON.parse()与eval()解析json的区别

    主要介绍了javascript中JSON.parse()与eval()解析json的区别,详细描述了json格式数据的操作技巧,并结合实例形式对比分析了使用JSON.parse()与eval()解析json的区别,需要的朋友可以参考下

    JSON在Javascript中的使用(eval和JSON.parse的区别)详细解析

    主要介绍了JSON在Javascript中的使用以及eval和JSON.parse的区别详细解析,本文对eval()和JSON.parse()的区别介绍的非常详细,需要的朋友可以参考下

    转义字符(\)对JavaScript中JSON.parse的影响概述

    (其实将符合json标准的字符串转化为js对象可以用eval,但是eval性能相对差且存在安全隐患(会执行json字符串中的代码),本文仅写JSON) 本文写的是转义字符对JSON.parse方法的影响。 一般来说在JSON.parse的参数...

    深入浅析JSON.parse()、JSON.stringify()和eval()的作用详解

     今天在这里笔者想简单谈谈jquery里面的JSON.parse()和JSON.stringify()函数,顺便还会提一下原生JS里面的eval()函数 (1)JSON.parse 函数 作用:将 JavaScript 对象表示法 (JSON) 字符串转换为对象。 

    javascript-stringify:将Stringify更改为eval,将JSON.stringify更改为JSON.parse。

    字符串化是eval作为JSON.stringify是JSON.parse 。 安装 npm install javascript-stringify --save 用法 import { stringify } from "javascript-stringify" ; 该API与JSON.stringify类似: value转换为字符串的...

    json2 json

    使用thisfile recommended.json_parse.js:该文件包含替代JSON的parse函数thatuses递归下降而不是eval.json_parse_state.js:此文件包含替代JSON的parse函数thatuses状态机器代替eval.cycle.js:这个文件包含了两个...

    json的介绍 以及 json2.js的用法

    JSON parse解析器只能辨识JSON文本,拒绝所有脚本。提供了本地JSON支持的浏览器的JSON解析 器将远快于eval函数。预计未来的ECMAScript标准将支持本地JSON。 使用格式: var myObject = JSON.parse(myJSONtext, ...

    json字符串和js对象之间的转换

    json字符串和js对象之间的转换,包括eval、parseJSON函数、JSON.parse、$.toJSON、$.parseJSON、复杂的json格式对象使用,让你一分钟理解json的那些事

    JS中对象与字符串的互相转换详解

    在使用 JSON2.JS 文件的 JSON.parse(data) 方法时候,碰到了问题: throw new SyntaxError(‘JSON.parse’); 查询资料,大概意思如下: JSON.parse方法在遇到不可解析的字符串时,会抛出SyntaxError异常。 即:JSON....

    jsenv-uneval:将值转换为可评估的字符串

    使用@jsenv/uneval + eval比JSON.stringify + JSON.parse更强大,更准确。 它支持圆形结构,并保留Date , Infinity , -0 , BigInt等类型。 但是JSON.stringify更快并且更安全(它无法执行任意代码)。 因此,在...

    json基础+实例5(最后几个函数哈parse stringify eval)加油(后面是实例了哈)

    //记住,parse是字符串转换成对象,所以要先写出字符串 var str=’{“name”:“黄菊华”,“dizhi”:“浙江杭州”}’; 记住stringify函数是对象转换成字符串,所以先写出对象 var obj1={“xing”:“黄”,“ming”:...

    使用sessionStorage保存与获取json对象

    将json对象使用JSON.stringify(JsonObject)方式转换...然后从 sessionStorage或localStorage 中取出对应的字符串,使用eval或JSON.parse将字符串转换为json对象。其中使用eval做转换时,需要在字符串的前后加入"("和")

    js解析与序列化json数据(一)json.stringify()的基本用法

    JSON对象有两个方法:stringify()和parse()。在最简单的情况下,这两个方法分别用于把JavaScript对象序列化为JSON字符串和把JSON字符串解析为原生JavaScript。例如: 新建一个HTML:代码如下: 代码如下: <...

    Ajax中解析Json的两种方法对比分析

    JSON.parse(); //推荐方法 一、两种方法的区别 我们先初始化一个json格式的对象:  var jsonDate = '{ "name":"周星驰","age":23 }'  var jsonObj = eval( '(' + jsonDate + ')' ); // eval();...

    Json对象与Json字符串互转(4种转换方式)

    //jQuery.parseJSON(jsonstr),可以将json字符串转换成json对象 2>浏览器支持的转换方式(Firefox,chrome,opera,safari,ie9,ie8)等浏览器: 代码如下: JSON.parse(jsonstr); //可以将json字符串转换成json...

Global site tag (gtag.js) - Google Analytics