开发者社区> 问答> 正文

php等解释器如何才能仅检查 js 代码的语法而不去执行?

最近在公司用 PHP 做一个小软件, 其中有几处要求对用户提交的 JS 代码校验其语法. 我安装了 v8js 扩展, 将提交的代码包裹在函数里"var x = function() { 用户JS代码 }", 用这样的方式来校验客户代码而不用去执行它.

经实验效果不错, 但是问题是, 上面的方式可能被聪明的用户利用, 引起注入的危险. 如客户输入代码"}; 某些危险代码", 这可能会造成大麻烦.

请问有什么办法仅仅校验 JS 代码的语法, 而不去执行 JS 代码吗?

展开
收起
落地花开啦 2016-06-15 13:48:33 2440 0
1 条回答
写回答
取消 提交回答
  • 喜欢技术,喜欢努力的人

    跟踪代码发现,PHP的V8扩展中,代码内部是先进行JS校验,然后才开始执行的,所以只要修改代码,让他在校验完后就返回,即可实现仅检查语法而不执行代码了。

    2019-07-17 19:39:06
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
JavaScript异步编程 立即下载
Delivering Javascript to World 立即下载
编程语言如何演化-以JS的private为例 立即下载