PHP防注入安全代码

转载 2006年06月08日 13:52:00

简述:/*************************
说明:
判断传递的变量中是否含有非法字符
如$_POST、$_GET
功能:防注入
**************************/ 

<?php

//要过滤的非法字符
$ArrFiltrate=array("'",";","union");
//出错后要跳转的url,不填则默认前一页
$StrGoUrl="";
//是否存在数组中的值
function FunStringExist($StrFiltrate,$ArrFiltrate){
foreach ($ArrFiltrate as $key=>$value){
  if (eregi($value,$StrFiltrate)){
    return true;
  }
}
return false;
}

//合并$_POST 和 $_GET
if(function_exists(array_merge)){
  $ArrPostAndGet=array_merge($HTTP_POST_VARS,$HTTP_GET_VARS);
}else{
  foreach($HTTP_POST_VARS as $key=>$value){
    $ArrPostAndGet[]=$value;
  }
  foreach($HTTP_GET_VARS as $key=>$value){
    $ArrPostAndGet[]=$value;
  }
}

//验证开始
foreach($ArrPostAndGet as $key=>$value){
  if (FunStringExist($value,$ArrFiltrate)){
    echo "<script language=/"javascript/">alert(/"非法字符/");</script>";
    if (empty($StrGoUrl)){
    echo "<script language=/"javascript/">history.go(-1);</script>";
    }else{
    echo "<script language=/"javascript/">window.location=/"".$StrGoUrl."/";</script>";
    }
    exit;
  }
}
?>

保存为checkpostandget.php
然后在每个php文件前加include(“checkpostandget.php“);即可

方法2

/* 过滤所有GET过来变量 */
foreach ($_GET as $get_key=>$get_var)
{
 if (is_numeric($get_var)) {
  $get[strtolower($get_key)] = get_int($get_var);
 } else {
  $get[strtolower($get_key)] = get_str($get_var);
 }
}

/* 过滤所有POST过来的变量 */
foreach ($_POST as $post_key=>$post_var)
{
 if (is_numeric($post_var)) {
  $post[strtolower($post_key)] = get_int($post_var);
 } else {
  $post[strtolower($post_key)] = get_str($post_var);
 }
}

/* 过滤函数 */
//整型过滤函数
function get_int($number)
{
    return intval($number);
}
//字符串型过滤函数
function get_str($string)
{
    if (!get_magic_quotes_gpc()) {
 return addslashes($string);
    }
    return $string;
}


我们把以上代码放到一个公共的文件里,比如security.inc.php里面,每个文件里都include一下这个文件,那么就能够给任何一个程序进行提交的所有变量进行过滤了,就达到了我们一劳永逸的效果。

PHP防注入安全代码

/*************************    说明:    判断传递的变量中是否含有非法字符    如$_POST、$_GET    功能:防注入    ******...
  • lz0426001
  • lz0426001
  • 2014年12月07日 21:34
  • 224

PHP通用防注入安全代码

************************* 说明: 判断传递的变量中是否含有非法字符 如$_POST、$_GET 功能: 防注入 *************...
  • god_7z1
  • god_7z1
  • 2011年09月07日 17:24
  • 276

通用的PHP防注入漏洞攻击的过滤函数代码

转自:http://www.q3060.com/list3/list117/17015.html //PHP整站防注入程序,需要在公共文件中require_once本文件  //判断magic...
  • u014413032
  • u014413032
  • 2016年10月22日 22:47
  • 640

从360提供的PHP防SQL注入代码改成的一个类

  • u010349417
  • u010349417
  • 2014年01月23日 10:56
  • 1681

比较好用的PHP防注入漏洞过滤函数代码

  • superbirds
  • superbirds
  • 2016年03月15日 19:12
  • 2690

PHP 安全防注入

PHP按照字节处理,因此当遇到如GBK等宽字符集的时候,添加恰当的包含转义字符的特殊字符(如繁体字誠),会拆分形成转义字符,以此为后面的注入形成条件。 若选择二进制形式,可以防止网站的注入风险。...
  • evolone
  • evolone
  • 2015年08月04日 14:37
  • 217

PHP一个防止注入的脚本

02 $root = "root"; 03 $pwd = "root"; 04 $host = "loca...
  • LanSeTianKong12
  • LanSeTianKong12
  • 2016年06月14日 13:54
  • 531

php添加360防护代码,处理网站安全漏洞

360发布通用php防护代码,其实最初是协助phpcms来防护安全用的,现在看来可以加入到任何有漏洞的网站里面,拿phpcmsv9问题,解决方案如下,其他网站以此类推! 1.将360_safe3.p...
  • helin916012530
  • helin916012530
  • 2014年01月18日 10:41
  • 1503

JAVA 安全性转码代码(包括sql注入,跨站脚本)

public class SecurityString { public static String getHtml(String str) { //过滤敏感字符 ...
  • lixiaolin77
  • lixiaolin77
  • 2011年11月11日 16:02
  • 3996

PHP简单代码防止SQL注入

Function inject_check($sql_str) { return preg_match('/select|insert|and|or|update|delete|\'|\/\*|\*...
  • dongsg11200
  • dongsg11200
  • 2014年04月28日 01:13
  • 841
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:PHP防注入安全代码
举报原因:
原因补充:

(最多只允许输入30个字)