php跨站ip,简单的 php 防注入、防跨站 函数

function fn_safe($str_string) {

//直接剔除

$_arr_dangerChars = array(

"|", ";", "$", "@", "+", "\t", "\r", "\n", ",", "(", ")", PHP_EOL //特殊字符

);

//正则剔除

$_arr_dangerRegs = array(

/* -------- 跨站 --------*/

//html 标签

"//i",

//html 属性

"/on(afterprint|beforeprint|beforeunload|error|haschange|load|message|offline|online|pagehide|pageshow|popstate|redo|resize|storage|undo|unload|blur|change|contextmenu|focus|formchange|forminput|input|invalid|reset|select|submit|keydown|keypress|keyup|click|dblclick|drag|dragend|dragenter|dragleave|dragover|dragstart|drop|mousedown|mousemove|mouseout|mouseover|mouseup|mousewheel|scroll|abort|canplay|canplaythrough|durationchange|emptied|ended|error|loadeddata|loadedmetadata|loadstart|pause|play|playing|progress|ratechange|readystatechange|seeked|seeking|stalled|suspend|timeupdate|volumechange|waiting)\s*=\s*(\"|')?\S*(\"|')?/i",

//html 属性包含脚本

"/\w+\s*=\s*(\"|')?(java|vb)script:\S*(\"|')?/i",

//js 对象

"/(document|location)\s*\.\s*\S*/i",

//js 函数

"/(eval|alert|prompt|msgbox)\s*\(.*\)/i",

//css

"/expression\s*:\s*\S*/i",

/* -------- sql 注入 --------*/

//显示 数据库 | 表 | 索引 | 字段

"/show\s+(databases|tables|index|columns)/i",

//创建 数据库 | 表 | 索引 | 视图 | 存储过程 | 存储过程

"/create\s+(database|table|(unique\s+)?index|view|procedure|proc)/i",

//更新 数据库 | 表

"/alter\s+(database|table)/i",

//丢弃 数据库 | 表 | 索引 | 视图 | 字段

"/drop\s+(database|table|index|view|column)/i",

//备份 数据库 | 日志

"/backup\s+(database|log)/i",

//初始化 表

"/truncate\s+table/i",

//替换 视图

"/replace\s+view/i",

//创建 | 更改 字段

"/(add|change)\s+column/i",

//选择 | 更新 | 删除 记录

"/(select|update|delete)\s+\S*\s+from/i",

//插入 记录 | 选择到文件

"/insert\s+into/i",

//sql 函数

"/load_file\s*\(.*\)/i",

//sql 其他

"/(outfile|infile)\s+(\"|')?\S*(\"|')/i",

);

$_str_return = $str_string;

//$_str_return = urlencode($_str_return);

foreach ($_arr_dangerChars as $_key=>$_value) {

$_str_return = str_ireplace($_value, "", $_str_return);

}

foreach ($_arr_dangerRegs as $_key=>$_value) {

$_str_return = preg_replace($_value, "", $_str_return);

}

$_str_return = htmlentities($_str_return, ENT_QUOTES, "UTF-8", true);

return $_str_return;

}

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值