小谢第53问:为什么前端要用JSON.parse而不用eval解析后端json

解析json的方式通常用JSON.parse()但是eval()方法也可以解析,这两者之间有什么区别呢?

JSON.parse()之所以可以解析json格式的数据,并且会对要解析的字符串进行格式检查,如果格式不正确则不进行解析,而eval()则可以解析任何字符串,eval是不安全的。

比如下面的字符串:

var str = 'alert(1000.toString())';
eval(str);
JSON.parse(str);

用eval可以解析,并且会弹出对话框,而用JSON.parse()则解析不了。 其实alert并没有什么坏处,可怕的是如果用恶意用户在json字符串中注入了向页面插入木马链接的脚本,用eval也是可以操作的,而用JSON.parse()则不必担心这个问题。

 

自己在工作中碰到的用JSON.parse出现的问题   

 

var str="{'':'','':''}";这种怎么都不行,执行不行,会报错误(报第一行的错误)

 

这时候需要我们找后端更换格式 而不是自己去用eval改

posted @ 2020-09-11 10:52  优雅的小谢  阅读(397)  评论(0编辑  收藏  举报
Live2D