PHP通用非法字符检测函数集锦

<? 

// 【变量定义规则】:‘C_’=字符型,‘I_’=整型,‘N_’=数字型,‘L_’=布尔型,‘A_’=数组型 

 

// ※CheckMoney($C_Money) 检查数据是否是 99999.99格式 

// ※CheckEmailAddr($C_mailaddr) 判断是否为有效邮件地址 

// ※CheckWebAddr($C_weburl) 判断是否为有效网址 

// ※CheckEmpty($C_char) 判断字符串是否为空 

// ※CheckLengthBetween($C_char, $I_len1, $I_len2=100) 判断是否为指定长度内字符串 

// ※CheckUser($C_user) 判断是否为合法用户名 

// ※CheckPassword($C_passwd) 判断是否为合法用户密码 

// ※CheckTelephone($C_telephone) 判断是否为合法电话号码 

// ※CheckValueBetween($N_var, $N_val1, $N_val2) 判断是否是某一范围内的合法值 

// ※CheckPost($C_post) 判断是否为合法邮编(固定长度) 

// ※CheckExtendName($C_filename,$A_extend) 判断上传文件的扩展名 

// ※CheckImageSize($ImageFileName,$LimitSize) 检验上传图片的大小 

// ※AlertExit($C_alert,$I_goback=0) 非法操作警告并退出 

// ※Alert($C_alert,$I_goback=0) 非法操作警告 

// ※ReplaceSpacialChar($C_char) 特殊字符替换函数 

// ※ExchangeMoney($N_money) 资金转换函数 

// ※WindowLocation($C_url,$C_get="",$C_getOther="") PHP中的window.location 函数 

 

// 函数名:CheckMoney($C_Money) 

// 作 用:检查数据是否是99999.99格式 

// 参 数:$C_Money(待检测的数字) 

// 返回值:布尔值 

// 备 注:无 

function CheckMoney($C_Money) 

if (!ereg("^[0-9][.][0-9]$", $C_Money)) return false; 

return true; 

 

// 函数名:CheckEmailAddr($C_mailaddr) 

// 作 用:判断是否为有效邮件地址 

// 参 数:$C_mailaddr(待检测的邮件地址) 

// 返回值:布尔值 

// 备 注:无 

function CheckEmailAddr($C_mailaddr) 

if (!eregi("^[_a-z0-9-]+(.[_a-z0-9-]+)*@[a-z0-9-]+(.[a-z0-9-]+)*$", 

$C_mailaddr)) 

//(!ereg("^[_a-zA-Z0-9-]+(.[_a-zA-Z0-9-]+)*@[_a-zA-Z0-9-]+(.[_a-zA-Z0-9-]+)*$", 

$c_mailaddr)) 

return false; 

return true; 

 

// 函数名:CheckWebAddr($C_weburl) 

// 作 用:判断是否为有效网址 

// 参 数:$C_weburl(待检测的网址) 

// 返回值:布尔值 

// 备 注:无 

function CheckWebAddr($C_weburl) 

if (!ereg("^http://[_a-zA-Z0-9-]+(.[_a-zA-Z0-9-]+)*$", $C_weburl)) 

return false; 

return true; 

 

// 函数名:CheckEmpty($C_char) 

// 作 用:判断字符串是否为空 

// 参 数:$C_char(待检测的字符串) 

// 返回值:布尔值 

// 备 注:无 

function CheckEmptyString($C_char) 

if (!is_string($C_char)) return false; //是否是字符串类型 

if (empty($C_char)) return false; //是否已设定 

if ($C_char=='') return false; //是否为空 

return true; 

 

// 函数名:CheckLengthBetween($C_char, $I_len1, $I_len2=100) 

// 作 用:判断是否为指定长度内字符串 

// 参 数:$C_char(待检测的字符串) 

// $I_len1 (目标字符串长度的下限) 

// $I_len2 (目标字符串长度的上限) 

// 返回值:布尔值 

// 备 注:无 

function CheckLengthBetween($C_cahr, $I_len1, $I_len2=100) 

$C_cahr = trim($C_cahr); 

if (strlen($C_cahr) < $I_len1) return false; 

if (strlen($C_cahr) > $I_len2) return false; 

return true; 

 

// 函数名:CheckUser($C_user) 

// 作 用:判断是否为合法用户名 

// 参 数:$C_user(待检测的用户名) 

// 返回值:布尔值 

// 备 注:无 

function CheckUser($C_user) 

if (!CheckLengthBetween($C_user, 4, 20)) return false; //宽度检验 

 

if (!ereg("^[_a-zA-Z0-9]*$", $C_user)) return false; //特殊字符检验 

return true; 

 

// 函数名:CheckPassword($C_passwd) 

// 作 用:判断是否为合法用户密码 

// 参 数:$C_passwd(待检测的密码) 

// 返回值:布尔值 

// 备 注:无 

function CheckPassword($C_passwd) 

if (!CheckLengthBetween($C_passwd, 4, 20)) return false; //宽度检测 

if (!ereg("^[_a-zA-Z0-9]*$", $C_passwd)) return false; //特殊字符检测 

return true; 

 

// 函数名:CheckTelephone($C_telephone) 

// 作 用:判断是否为合法电话号码 

// 参 数:$C_telephone(待检测的电话号码) 

// 返回值:布尔值 

// 备 注:无 

function CheckTelephone($C_telephone) 

if (!ereg("^[+]?[0-9]+([xX-][0-9]+)*$", $C_telephone)) return false; 

return true; 

 

// 函数名:CheckValueBetween($N_var, $N_val1, $N_val2) 

// 作 用:判断是否是某一范围内的合法值 

// 参 数:$N_var 待检测的值 

// $N_var1 待检测值的上限 

// $N_var2 待检测值的下限 

// 返回值:布尔值 

// 备 注:无 

function CheckValueBetween($N_var, $N_val1, $N_val2) 

 

if ($N_var < $N_var1 ││ $N_var > $N_var2) 

return false; 

return true;

 

// 函数名:CheckPost($C_post) 

// 作 用:判断是否为合法邮编(固定长度) 

// 参 数:$C_post(待check的邮政编码) 

// 返回值:布尔值 

// 备 注:无 

function CheckPost($C_post) 

$C_post=trim($C_post); 

if (strlen($C_post) == 6) 

if(!ereg("^[+]?[_0-9]*$",$C_post)) 

return true;; 

}

else

return false; 

}

else

return false;; 

 

 

// 函数名:CheckExtendName($C_filename,$A_extend) 

// 作 用:上传文件的扩展名判断 

// 参 数:$C_filename 上传的文件名 

// $A_extend 要求的扩展名 

// 返回值:布尔值 

// 备 注:无 

function CheckExtendName($C_filename,$A_extend) 

if(strlen(trim($C_filename)) < 5) 

return 0; //返回0表示没上传图片 

$lastdot = strrpos($C_filename, "."); //取出.最后出现的位置 

$extended = substr($C_filename, $lastdot+1); //取出扩展名

for($i=0;$i<count($A_extend);$i++) //进行检测 

if (trim(strtolower($extended)) == trim(strtolower($A_extend[$i]))) //转换大小写并检测 

$flag=1; //加成功标志 

$i=count($A_extend); //检测到了便停止检测 

}

if($flag<>1) 

 

for($j=0;$j<count($A_extend);$j++) //列出允许上传的扩展名种类 

$alarm .= $A_extend[$j]." "; 

AlertExit(' 只能上传'.$alarm.'文件!而你上传的是'.$extended.'类型的文件'); 

return -1; //返回-1表示上传图片的类型不符 

}

return 1; //返回1表示图片的类型符合要求 

 

// 函数名:CheckImageSize($ImageFileName,$LimitSize) 

// 作 用:检验上传图片的大小 

// 参 数:$ImageFileName 上传的图片名 

// $LimitSize 要求的尺寸 

// 返回值:布尔值 

// 备 注:无 

function CheckImageSize($ImageFileName,$LimitSize) 

$size=GetImageSize($ImageFileName); 

if ($size[0]>$LimitSize[0] ││ $size[1]>$LimitSize[1]) 

AlertExit(' 图片尺寸过大'); 

return false; 

return true; 

 

 

// 函数名:Alert($C_alert,$I_goback=0) 

// 作 用:非法操作警告 

// 参 数:$C_alert(提示的错误信息) 

// $I_goback(返回到那一页) 

// 返回值:字符串 

// 备 注:无 

function Alert($C_alert,$I_goback=0) 

if($I_goback<>0) 

echo "<script>alert('$C_alert');history.go($I_goback);</script>"; 

else

echo "<script>alert('$C_alert');</script>"; 

 

// 函数名:AlertExit($C_alert,$I_goback=0) 

// 作 用:非法操作警告 

// 参 数:$C_alert(提示的错误信息) 

// $I_goback(返回到那一页) 

// 返回值:字符串 

// 备 注:无 

function AlertExit($C_alert,$I_goback=0) 

if($I_goback<>0) 

echo "<script>alert('$C_alert');history.go($I_goback);</script>"; 

exit; 

else

 

echo "<script>alert('$C_alert');</script>"; 

exit; 

 

// 函数名:ReplaceSpacialChar($C_char) 

// 作 用:特殊字符替换函数 

// 参 数:$C_char(待替换的字符串) 

// 返回值:字符串 

// 备 注:无 

function ReplaceSpecialChar($C_char) 

$C_char=HTMLSpecialChars($C_char); //将特殊字元转成 HTML 格式。 

$C_char=nl2br($C_char); //将回车替换为<br> 

$C_char=str_replace(" "," ",$C_char); //替换空格替换为 

$C_char=str_replace("<? ","< ?",$C_char); //替换PHP标记 

return $C_char; 

 

// 函数名:ExchangeMoney($N_money) 

// 作 用:资金转换函数 

// 参 数:$N_money(待转换的金额数字) 

// 返回值:字符串 

// 备 注:本函数示例:$char=ExchangeMoney(5645132.3155) ==> $char='¥5,645,132.31' 

function ExchangeMoney($N_money) 

$A_tmp=explode(".",$N_money ); //将数字按小数点分成两部分,并存入数组$A_tmp 

$I_len=strlen($A_tmp[0]); //测出小数点前面位数的宽度

 

if($I_len%3==0) 

$I_step=$I_len/3; //如前面位数的宽度mod 3 = 0 ,可按,分成$I_step 部分 

}

else

$step=($len-$len%3)/3+1; //如前面位数的宽度mod 3 != 0 ,可按,分成$I_step 部分+1 

}

$C_cur=""; 

//对小数点以前的金额数字进行转换 

while($I_len<>0) 

$I_step--;

if($I_step==0) 

$C_cur .= substr($A_tmp[0],0,$I_len-($I_step)*3); 

}

else

$C_cur .= substr($A_tmp[0],0,$I_len-($I_step)*3).","; 

}

$A_tmp[0]=substr($A_tmp[0],$I_len-($I_step)*3); 

 

$I_len=strlen($A_tmp[0]); 

}

//对小数点后面的金额的进行转换 

if($A_tmp[1]=="") 

$C_cur .= ".00"; 

}

else

$I_len=strlen($A_tmp[1]); 

if($I_len<2) 

$C_cur .= ".".$A_tmp[1]."0"; 

}

else

$C_cur .= ".".substr($A_tmp[1],0,2); 

}

//加上人民币符号并传出 

$C_cur="¥".$C_cur; 

return $C_cur; 

 

// 函数名:WindowLocation($C_url,$C_get="",$C_getOther="") 

// 作 用:PHP中的window.location函数 

// 参 数:$C_url 转向窗口的URL 

// $C_get GET方法参数 

// $C_getOther GET方法的其他参数 

// 返回值: 字符串 

// 备 注:无 

function WindowLocation($C_url,$C_get="",$C_getOther="") 

if($C_get == "" && $C_getOther == "") 

if($C_get == "" && $C_getOther <> "")

{

$C_target=""window.location='$C_url?$C_getOther='+this.value"";

if($C_get <> "" && $C_getOther == "")

{

$C_target=""window.location='$C_url?$C_get'"";

if($C_get <> "" && $C_getOther <> "")

{

$C_target=""window.location='$C_url?$C_get&$C_getOther='+this.value"";

}

return $C_target; 

}

 

?>

posted @ 2015-08-22 11:44  武穆逸仙  阅读(1278)  评论(0编辑  收藏  举报

为天地立心 为生民立命 为往圣继绝学 为万世开太平