<?

// 【变量定义规则】:‘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;

}

?>

PHP通用非法字符检测函数集锦的更多相关文章

  1. 总结C语言字符检测函数:isalnum、isalpha...

    前言:最近一直在刷leetcode的题,用到isalnum函数,用man手册查找了一下,总共有13个相关函数如下: #include <ctype.h> int isalnum(int c ...

  2. c字符检测函数

    isalpha(c)    /*判断是否为英文字符*/iscntrl(c)     /*判断是否为控制字符*/ isdigit(c)     /*判断是否为阿拉伯数字0到9*/isgraph(c)   ...

  3. 通用js函数集锦<来源于网络> 【二】

    通用js函数集锦<来源于网络> [二] 1.数组方法集2.cookie方法集3.url方法集4.正则表达式方法集5.字符串方法集6.加密方法集7.日期方法集8.浏览器检测方法集9.json ...

  4. 通用js函数集锦<来源于网络/自己> 【一】

    通用js函数集锦<来源于网络/自己>[一] 1.返回一个全地址2.cookie3.验证用户浏览器是否是微信浏览器4.验证用户浏览器是否是微博内置浏览器5.query string6.验证用 ...

  5. c# 检测是否有Sql非法字符

    /// <summary> /// 检测是否有Sql危险字符 /// </summary> /// <param name="str">要判断字 ...

  6. php检测非法字符方法

    检测非法字符: [第一种]: 自己搞来玩的... 简单测试了下...暂无发现什么问题...日后再多测试下....日后再更>>>

  7. windows文件名非法字符过滤检测-正则表达式

    过滤文件名非法字符 windows现在已知的文件名非法字符有 \ / : * ? " < > | var reg = new RegExp('[\\\\/:*?\"&l ...

  8. JS通用表单验证函数,基于javascript正则表达式

    表单的验证在实际的开发当中是件很烦琐又无趣的事情今天在做一个小项目的时候,需要JS验证,寻找到一个比较好的东西 地址如下: http://blog.csdn.net/goodfunman/archiv ...

  9. ctype.h库函数----字符操作函数

    在c++中使用时:  #include <cctype> 字符判断函数 1.isalnum函数--判断是否是英文字母或数字字符,如果是,则返回非0值,如果不是,则返回0. 函数参数 :可以 ...

随机推荐

  1. Ansible学习记录五:PlayBook学习

    0.介绍 Playbooks 是 Ansible 管理配置.部署应用和编排的语言,可以使用 Playbooks 来描述你想在远程主机执行的策略或者执行的一组步骤过程等 类似于一组任务集,定义好像项目, ...

  2. Android-Volley网络通信框架(二次封装数据请求和图片请求(包含处理请求队列和图片缓存))

    1.回想 上篇 使用 Volley 的 JsonObjectRequest 和 ImageLoader 写了 电影列表的样例 2.重点 (1)封装Volley 内部 请求 类(请求队列,数据请求,图片 ...

  3. HBase-scan API 通过scan读取表中数据

    直接贴代码啦 /** * * @param zkIp * @param zkPort * @param tablename * @param startRow 传null扫全表 * @param st ...

  4. python绘图问题

    论文绘图整理 # coding: utf-8 #来源:https://blog.csdn.net/A_Z666666/article/details/81165123 import matplotli ...

  5. 109.vprintf vfprintf vscanf vfscanf

    vprintf //输出到屏幕 int POUT(char *str, ...) { va_list arg_p=NULL; //读取 va_start(arg_p, str); //接受可变参数 i ...

  6. javascript: with 表单验证

    <html> <head> <script type="text/javascript"> function validate_required ...

  7. v-for一定要与v-bind:key="id"连用

    1. v-for: <div v-for="(item,index) in todolist" v-bind:key="item.id"> < ...

  8. Python 极简教程(四)变量与常量

    变量和常量 在 Python 中没有 常量 与 变量 之分.只有约定成俗的做法: 全大写字母的名称即为 常量: PI = 3.1415926 全小写字母的名称为 变量: name = 'nemo' 变 ...

  9. [appium]-9宫格解锁方法

    from appium.webdriver.common.touch_action import TouchAction TouchAction(self.driver).press(x=228,y= ...

  10. 项目太大tomcat启动不起来

    双击server,Open launch configuration Arguments VM arguments增加参数: -Xms512m -Xmx1024m -Xss4m -XX:PermSiz ...