最近在公司用 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代码 }", 用这样的方式来校验客户代码而不用去执行它.
立即学习“PHP免费学习笔记(深入)”;
经实验效果不错, 但是问题是, 上面的方式可能被聪明的用户利用, 引起注入的危险. 如客户输入代码"}; 某些危险代码", 这可能会造成大麻烦.
请问有什么办法仅仅校验 JS 代码的语法, 而不去执行 JS 代码吗?
v8js 扩展文档: http://cn2.php.net/manual/zh/class.v8js.php
试试 javascriptlint 或 jslint
跟踪代码发现,PHP的V8扩展中,代码内部是先进行JS校验,然后才开始执行的,所以只要修改代码,让他在校验完后就返回,即可实现仅检查语法而不执行代码了。
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
C++高性能并发应用_C++如何开发性能关键应用
Java AI集成Deep Java Library_Java怎么集成AI模型部署
Golang后端API开发_Golang如何高效开发后端和API
Python异步并发改进_Python异步编程有哪些新改进
C++系统编程内存管理_C++系统编程怎么与Rust竞争内存安全
Java GraalVM原生镜像构建_Java怎么用GraalVM构建高效原生镜像
Python FastAPI异步API开发_Python怎么用FastAPI构建异步API
C++现代C++20/23/26特性_现代C++有哪些新标准特性如modules和coroutines
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号