xss过滤器无法处理ajax请求_thunkPHP 预防XSS攻击

比如在有人恶意在你的输入框中或文本域中输入<script>标签,如果不做处理的话,输入框中的<script>会保存到我们数据库中,等到将这个数据拿出来展示的时候,就等于将这个内容放入到了html代码中,那么这个<script>就会被解析就会被认为是一段js代码,

做个例子:

32ae65c697c437cb469232a37561b288.png

我的框架还没有防范这个xss攻击,所以会受到影响

87afb80c5c252344681c1a0606f6fad5.png

我们在看看源代码中

eea5d9e1b2c25fb115d8e5f61ede1274.png

可以看出来我们写的script生效了,这个就是xss攻击

这个XSS攻击可以做很多的事情:现在只是弹框,用户看见了就不会继续操作了,那有可能坏人不仅仅是写了个弹框,要是写了一个ajax请求用户看不见,用户继续操作,那么就可能泄露用户的个人信息了

所以我们要预防这种XSS攻击

首先要预防XSS攻击,就应该想起来两种方法,一种是转化,一种是过滤,顾名思义转化就是将用户输入的<script>的<>转化成为html实体字符 转化成 ('&gt >,&lt <') 实体字符,转化后的实体字符就不会被html解析, 详细的看下面!!!

过滤,将用户输入的内容,中的标签全部不要,剩下的出入数据库中,展示的时候,也是没有标签的

下面我们详细的解释用法

在框架中,用转化的方式了解决XSS攻击的话是很简单的,找到 application 下面的 config文件中,寻找一个配置项

182e96d5ad96c475dca59dec1aaeb093.png

框架默认的是空,在后面添加框架自带的方法 “htmlspecialchars”,

'default_filter' => 'htmlspecialchars',

注意要写就要写对,因为写错了,不会报任何的错误,但任何的参数都接受不到

改完后我们在试一下:

3bb2e91a57345cd2d96ae8e50268828b.png

bde9395e5ef1143bce2a5a3f3e850f14.png

在看看源代码

5c593da429ff95b0027c8f69c53ebdc2.png

过滤的思想防范xss攻击

在富文本编辑器中,输入的内容源代码中,包含html标签是正常的。不能使用htmlspecialchars进行处理。如果用户直接在源代码界面输入js代码,也会引起xss攻击。

通常使用htmlpurifier插件进行过滤。

使用composer执行命令,安装 ezyang/htmlpurifier 扩展类库 项目目录下> composer require ezyang/htmlpurifier

使用composer执行命令安装的,会自动加载类文件,不需要手动加载

在application/common.php中定义remove_xss函数

if (!function_exists('remove_xss')) {//使用htmlpurifier防范xss攻击function remove_xss($string){// 生成配置对象$cfg = HTMLPurifier_Config::createDefault();// 以下就是配置:$cfg -> set('Core.Encoding', 'UTF-8');// 设置允许使用的HTML标签$cfg -> set('HTML.Allowed','div,b,strong,i,em,a[href|title],ul,ol,li,br,p[style],span[style],img[width|height|alt|src]');// 设置允许出现的CSS样式属性$cfg -> set('CSS.AllowedProperties', 'font,font-size,font-weight,font-style,font-family,text-decoration,padding-left,color,background-color,text-align');// 设置a标签上是否允许使用target="_blank"$cfg -> set('HTML.TargetBlank', TRUE);// 使用配置生成过滤用的对象$obj = new HTMLPurifier($cfg);// 过滤字符串return $obj -> purify($string);}
} 

说明:htmlpurifier插件,会过滤掉script标签以及标签包含的js代码。

设置全局过滤方法为封装的remove_xss函数:

修改application/config.php

6e179f23f93aac822180d1c301ca279a.png

我们在试一下效果

e82e3ebb0fd9fd9d761b2b016c1c55b8.png

9d064160518c5fca76094ac5670506a2.png

01b76f6e53c26cc6e62b0af2196c6a71.png

b6e78e3a760add08525952cf9a8ae2b8.png

直接就过滤掉了,

以上接受怎么防止XSS攻击的方法:但建议是两种方法混合这用,比较好

建议:使用这个

c845a13933e5c0fde9d9d6926d6d68f9.png

如果遇到,上传富文本的,单独使用htmlpurifier插件处理

f902c7056eec8e83195163455f9a2ff6.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/505817.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql bcmod_nextcloud网盘搭建:Ubuntu18.04+Nginx+Mysql

背景前几天在windows系统上搭建了一个seafile网盘服务器&#xff0c;在试用时对它的功能还是比较满意的&#xff0c;有保存文件&#xff0c;共享文件&#xff0c;小组讨论和小组文件共享等功能&#xff0c;基本上可以满足项目式学习的需求。不过在第一节课上课试用时(一个班大概…

mysql mode_MYSQL中的sql_mode模式

mysql数据库的中有一个环境变量sql_mode,定义了mysql应该支持的sql语法&#xff0c;数据校验等&#xff01;我们可以通过以下方式查看当前数据库使用的sql_mode&#xff1a;mysql>select sql_mode一&#xff0c;sql_mode值的含义ONLY_FULL_GROUP_BY对于GROUP BY聚合操作&…

汇编为什么分段执行总是执行不了_为什么我的计划总是执行不了?这里有你要的答案...

公众号配文&#xff1a;有些计划如泰山一样纹丝不动。说它难吧&#xff0c;又不是很难&#xff0c;奈何动不起来&#xff1f;——————————说起每日计划&#xff0c;很多人觉得&#xff0c;不就是写写行动清单&#xff0c;然后赶紧去做呗。不过&#xff0c;是不是有些计…

mysql unhex乱码_理解和解决MySQL乱码问题

本文将详细介绍MySQL乱码的成因和具体的解决方案在阅读本文之前&#xff0c;强烈建议对字符集编码概念还比较模糊的同学 阅读下博主之前对相关概念的一篇科普&#xff1a;十分钟搞清字符集和字符编码MySQL出现乱码的原因要了解为什么会出现乱码&#xff0c;我们就先要理解&…

单目相机 svd 从图像恢复3维位置_论文学习——VINSMono:一种鲁棒且通用的单目视觉惯性系统...

点击上方“视觉部落”&#xff0c;选择“星标”公众号精选作品&#xff0c;第一时间送达文章同步首发于知乎用户yikang专栏Part 1. 基本信息本文提出了一种基于紧耦合滑动窗口非线性优化方法的单目视觉-惯性系统&#xff0c;来自港科大沈老师实验室。这篇论文的亮点包括提出了效…

识别波峰波谷算法_马丁普林格:波峰-波谷演进法

我们有很多方法来识别趋势&#xff0c;计算机可以轻易地帮助我们实现各种复杂的想法。而在技术允许的条件下&#xff0c;我们还总是有把事物复杂化的倾向。事实也的确如此&#xff0c;目前市面上有无数复杂的方法、指标和程式化黑箱。但很显然&#xff0c;这些复杂的东西除了把…

cru使用教程_显示器刷新率超频教程

嫌显示器刷新率不够高&#xff0c;屏幕有拖影&#xff1f;打FPS游戏总是慢人一步&#xff1f;如果你正在使用的显示器面板素质不错的话&#xff0c;说不定可以将出厂标称的刷新率通过软件得到小幅度提升。此方法对于笔记本显示器有可能无效。本文仅展示在Windows 10操作系统下的…

python三方库打包项目中_将Python库打包到项目中

如果你有一个Python项目需要分发出去&#xff0c;但这个项目用了一些第三方库&#xff0c;而你又不想使用你这个项目的用户自行去安装这些库&#xff0c;这时候就很有必要将这些Python库打包到你的项目中了。下面以Faker这个库举例。1. 下载库源码: https://pypi.python.org/py…

网站本地调试工具_一款Web调试代理工具:Fiddler

前言在移动软件开发工作中&#xff0c;我们经常需要对APP软件进行调试及问题定位。在我们检查定位问题的时候&#xff0c;很多情况下需要查看接口的请求情况&#xff0c;当我们没有在调试模式的情况下&#xff0c;如何才能有效快捷的得到各个接口的请求情况呢&#xff1f;这个时…

plsql无监听程序_详细!看看顶级互联网公司都在研究的无服务器架构!

无服务器计算(Severless computing&#xff0c;简称 Serverless)现在是软件架构圈中的热门话题&#xff0c;国外三大云计算供应商(Amazon、Google 和 Microsoft)都在大力投入这个领域&#xff0c;涌现了不计其数的相关书籍、开源框架、商业产品、技术大会。到底什么是 Serverle…

sqlyog怎么连接mysql错误2003_网站突然连不上,MySQL连接错误经常内存不够宕机

阿里云服务器 MySQL 经常自动停止、挂掉、重启。打开 MySQL 的 error.log 错误信息&#xff0c;在阿里云 CentOS 的路径为 /alidata/log/mysql/error.log,如下&#xff1a;2016-03-13 00:16:37 0[Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use--e…

华为抓截屏_原来这才是华为截屏的正确姿势,今天才知道,千万别不当回事

原标题&#xff1a;原来这才是华为截屏的正确姿势&#xff0c;今天才知道&#xff0c;千万别不当回事大家都知道我们的华为手机有很多好用的功能&#xff0c;截屏就是其中一个&#xff0c;那么你知道华为手机截屏的正确姿势吗&#xff1f;今天小编就带大家一起看看吧&#xff0…

oracle和mysql通用建表语句_mysql建表语句到oracle怎么写?

mysql建表语句到oracle怎么写&#xff1f;CREATE TABLE Advertisment ( AdId int(8) NOT NULL auto_increment, AderId int(8) default NULL, AdName varchar(50) default NULL, AdKind varchar(30) default NULL, CreateMan varchar(30) default NULL, StartDate date d…

onenote快捷键_高效飞快地使用onenote快捷键:快捷键功能架构解析

默认快捷键有近200组&#xff0c;涉及到的功能如此之多&#xff0c;但真正频繁使用的&#xff0c;可能也就几十组。如何从这么多快捷键中选择出自己需要的呢&#xff1f;你需要一张功能架构参考图。1默认快捷键功能架构图官方文档已对快捷键做了初步分类&#xff0c;但比较抽象…

ueditor如何设置上传图片的高度宽度_上百张图片上传并对齐,你加班2小时没搞定,同事简单三步就完成...

Excel除了汇总数据还可以上传保存相片&#xff0c;比如我们在人力信息表中将每个人的相片放到表格里面去&#xff0c;或者我们需要将宠物对应的相片放到表格里面去&#xff0c;这就涉及到图片的批量上传以及对齐的操作。如图所示&#xff0c;我们需要将每个动物对应的图片&…

pdf在线翻译_如何免费快速地翻译pdf英文文档,并保留很好的格式?

对于那些科研工作者&#xff0c;每天阅读外文文献是必须要做的&#xff0c;大家都知道&#xff0c;一份外文的pdf文献内容是很多的&#xff0c;阅读量也是非常大&#xff0c;边看边翻译的话&#xff0c;这个任务还是很艰巨的&#xff0c;面对如此大的阅读量&#xff0c;该怎么快…

服务器具有挂起的重新启动_ESP8266与网络服务器实时通讯

背景知识视频教程Bootstrap 4布局&#xff1a;响应式单页设计​viadean.comNode.js&#xff0c;Express&#xff0c;MongoDB等&#xff1a;2020年完整的训练营 - 国外课栈​viadean.com高级Express - 国外课栈​viadean.com目前&#xff0c;所有已呈现的通信都是基于请求响应方…

java除号_Java的运算符

1.算数运算符 加(正号)  - 减(符号)  * 乘  / 除% 取模(取余)   自增  -- 自减号的几种作用&#xff1a;加法运算  表示为一个正数  还可以用来作字符串的拼接整数相除只能得到整数。如果想得到小数&#xff0c;必须把参与计算的数据变化为浮点类型的数据。自增和…

strace命令_在软件部署中使用 strace 进行调试

我最喜欢的用来解决“为什么这个软件无法在这台机器上运行&#xff1f;”这类问题的工具就是 strace。-- Simon Arneaud&#xff08;作者&#xff09;我的大部分工作都涉及到部署软件系统&#xff0c;这意味着我需要花费很多时间来解决以下问题&#xff1a;这个软件可以在原开发…

procreate 笔刷_Procreate新手漫画入门:笔刷,图层,上色

上个月新入手了一个新的ipad&#xff0c;又打开了一种关于漫画的新的可能性~同时验证了那句话&#xff1a;对生活保持好奇&#xff0c;你将收获更多。于是就有一些喜欢画画的小伙伴有私信这样的漫画怎么画的&#xff1f;这个秘密工具就是&#xff1a;ipad ➕ Apple pencil ➕ a…