javascript - 如何更加简单验证前端来的数据是否合法
PHP中文网
PHP中文网 2017-04-11 11:55:56
[JavaScript讨论组]

按照正常的观点来说,我们是绝对不能够相信前端来的数据,但是例如表单提交,我前端js要验证过,后端又要验证过,验证的东西少还好,一多(规则复杂)就麻烦了,有没有什么办法确保前端数据一定合法,或者后端只要简单验证下就好(就是有点像表单令牌那玩意,虽然他是用来防止重复提交)

PHP中文网
PHP中文网

认证高级PHP讲师

全部回复(6)
PHP中文网

前端校验只是提升用户体验而已,后端校验才是必须要做的。

关于你这个问题,可以搜一下前后端同构这个话题,大意做法就是利用nodejs做中间层,把前端的校验代码在nodejs也部署一套,避免后端(这里的后端是指与nodejs通信的后端,而不是nodejs本身)再重新实现一遍校验逻辑。

阿神

使用框架,如yii,
每个表单在model层定义一个Form模型,里面定义一些rules方法。自带很多校验规则,如邮箱,字符串长度,枚举等等。当然特殊规则也可以自己定义。

防止重复提交或者机器模拟提交最好的办法还是加验证码。

黄舟

有没有什么办法确保前端数据一定合法,或者后端只要简单验证下就好

题主也说了绝对不能相信前端的数据,那么前端做了任何效验,后端也需要做保持一致的效验。

PHPz

后台一定要校验的,因为可以通过模拟的方式向后端发送请求,这样就跳过了前端的验证

PHPz

就算前端做的校验再怎么好。后端还是要保证完整的校验。而不能简单的验证一下。
你不能保证发送数据的人就是通过你的那套校验发送数据的。
另外,前端校验也算是提升一下用户体验。

阿神

有没有什么办法确保前端数据一定合法
那就要确保后端收到的数据一定是来自校验过的前端,这个在Web上很难做到

所以呢,你写校验的时候问前端要一份他们写的校验代码,改一改(微笑)

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号