> 백엔드 개발 > PHP 튜토리얼 > php v8js 等 javascript 解释器如何才能仅检查 js 代码的语法而不去执行?

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

WBOY
풀어 주다: 2016-06-06 20:49:06
원래의
1276명이 탐색했습니다.

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

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

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

v8js 扩展文档: http://cn2.php.net/manual/zh/class.v8js.php

回复内容:

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

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

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

v8js 扩展文档: http://cn2.php.net/manual/zh/class.v8js.php

试试 javascriptlint 或 jslint

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

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿