thinkphp过滤xss
发布时间 - 2019-06-13 00:00:00 点击率:次什么是XSS:这里通俗的讲,就像是SQL注入一样,XSS攻击也可以算是对HTML和JS的一种注入。你本来希望得到是从用户那得到一段有用的文本文字,但用户提交给你的却是别有用心的可执行javasc ript或其它脚本(这里并没有把破坏样式或文档文本当作攻击),当你再把这些提交的内容显示到页面上时,XSS攻击就发生了。
关于XSS的攻击方式和场景层出不穷,本文也只是做的普及一些基本的安全防护知识(不涉及flash脚本攻击),如果想彻底研究这种攻击方式推荐一本书>,如果没时间看书的话就把本文看完吧。
本文的需掌握的基础知识:cookie,session工作原理,对TP框架有一定了解。
1:抵御99%的攻击方式,适用于90%的场景.
当网站不涉及复杂的用户交互时,可以对用户所有提交的文本进行htmlspecialchars函数处理。
在THINKPHP3.2版本中的操作步骤是:
一:在项目配置文件中添加配置: 'DEFAULT_FILTER' => 'htmlspecialchars', //默认过滤函数
二: 使用框架带的I方法获取来自用户提交的数据;
例子:M('Member')->save(array('content'=>I('post.content')));这样添加的content内容是经过htmlspecialchars处理过的.
提问:为什么经过htmlspecialchars处理过的文本可以保证是安全的?
回答:纵观XSS各种攻击方式绝大多数依赖'"& 这几个字符中的一个或几个对内容进行注入攻击。而htmlspecialchars函数的作用就是将这些字符转换成无害的HTML 实体;
提问:为什么有这么好的方法,而还有好多网站还是被攻击.
回答:因为好多程序员总会粗心忘记使用这个方法,而遗漏某条数据的过滤。
2:对COOKIE进行IP绑定
cookie里面一般有自动登录信息和session_id,就算对cookie里面的内容全部加了密,cookie的信息一但被别人通过XSS攻击获取后也一样等同于把自己的帐号密码给了别人。
对cookie进行IP绑定,(当然也可以获取用户客户端更多的其它信息进行同时绑定)可以根据用户的IP来判断这个cookie是不是来原始授权用户。
典型的应用示例:
用户设置了自动登录时保存自动登录信息:
$auto=I('post.auto');//用户设置了自动登录 if(!empty($auto)){ cookie('auto',encrypt(serialize($data)));//将登录信息保存到cookie,其中$data里含有加密后的帐号,密码,和用户的IP,这里的cookie已在全局中设置过期日期为一周 }用户关闭浏览器再次访问网站时,进行自动登录
if (!is_login()) {//是否未登录状态? $auth=cookie('auto'); if(!empty($auth)){//是否未有自动登录cookie? $data=unserialize(decrypt($auth)); if(!empty($data) && !empty($data['username']) && !empty($data['password']) && !empty($data['last_login_ip'])){ $user=M('Member')->where(array('username'=>$data['username'],'password'=>$data['password']))->find(); if(!empty($user['id'])&&($user['last_login_ip']==get_client_ip())){//cookie帐号密码是否有效?//IP来源是否相同? login_session($user['id'], $user['username'], $data['last_login_ip']);//用户自动登录成功 } } } }
优点:大多数场景下可使被XSS攻击盗取的cookie失效。缺点:由于IP存在多台电脑共用的可能,对绑定做不到十分精细。
3:为COOKIE添加httponly配置
最新版本的thinkphp已经支持此参数。
此参数可以保证cookie只在http请求中被传输,而不被页面中的脚本获取,现市面上绝大多数浏览器已经支持。
4:H
TML5值得观注的新特性:
为iframe的增加的sandbox属性,可以防止不信任的Web页面执行某些操作.相信这个方法以后会被广泛使用。
5:富文本过滤
富文本过滤是,XSS攻击最令人头疼的话题,不仅是小网站,就连BAT这样的巨头也是三天两头的被其困扰.
更多ThinkPHP相关技术文章,请访问ThinkPHP使用教程栏目进行学习!
# php
# thinkphp
# sql
# html5
# html
# xss
# Array
# Cookie
# Session
# JS
# http
# 自动登录
# 绑定
# 自己的
# 几个
# 却是
# 当你
# 适用于
# 有一定
# 是从
# 帐号
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Android自定义控件实现温度旋转按钮效果
JavaScript如何实现继承_有哪些常用方法
Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】
如何快速搭建虚拟主机网站?新手必看指南
js实现获取鼠标当前的位置
Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】
昵图网官方站入口 昵图网素材图库官网入口
HTML5空格和margin有啥区别_空格与外边距的使用场景【说明】
Laravel Docker环境搭建教程_Laravel Sail使用指南
Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】
Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】
Laravel N+1查询问题如何解决_Eloquent预加载(Eager Loading)优化数据库查询
Laravel如何获取当前用户信息_Laravel Auth门面获取用户ID
Swift中switch语句区间和元组模式匹配
Laravel如何配置和使用缓存?(Redis代码示例)
如何在阿里云服务器自主搭建网站?
如何快速查询域名建站关键信息?
Laravel怎么实现验证码(Captcha)功能
如何登录建站主机?访问步骤全解析
*服务器网站为何频现安全漏洞?
如何利用DOS批处理实现定时关机操作详解
javascript如何操作浏览器历史记录_怎样实现无刷新导航
ChatGPT回答中断怎么办 引导AI继续输出完整内容的方法
如何在Windows服务器上快速搭建网站?
英语简历制作免费网站推荐,如何将简历翻译成英文?
如何在Windows虚拟主机上快速搭建网站?
微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】
如何用ChatGPT准备面试 模拟面试问答与职场话术练习教程
详解CentOS6.5 安装 MySQL5.1.71的方法
如何在服务器上三步完成建站并提升流量?
Win11关机界面怎么改_Win11自定义关机画面设置【工具】
香港服务器租用每月最低只需15元?
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框
Laravel广播系统如何实现实时通信_Laravel Reverb与WebSockets实战教程
nginx修改上传文件大小限制的方法
php增删改查怎么学_零基础入门php数据库操作必知基础【教程】
通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】
制作公司内部网站有哪些,内网如何建网站?
linux top下的 minerd 木马清除方法
Laravel如何创建自定义Facades?(详细步骤)
Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载
javascript读取文本节点方法小结
如何将凡科建站内容保存为本地文件?
北京网站制作的公司有哪些,北京白云观官方网站?
如何正确选择百度移动适配建站域名?
Laravel如何实现用户密码重置功能?(完整流程代码)
iOS正则表达式验证手机号、邮箱、身份证号等
公司网站制作需要多少钱,找人做公司网站需要多少钱?
ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】

