上代码
代码如下 | 复制代码 |
<?php header('Content-type: text/html; charset=utf-8'); $str = "dasdadsfsadASDSADS"; if (preg_match('/^[a-zA-Z]+$/',$str)) ?> |
这个就是代码
代码如下 | 复制代码 |
preg_match('/^[a-zA-Z]+$/',$str) |
如果是字母则返回TRUE,否则返回FALSE
其它的判断
代码如下 | 复制代码 |
if(preg_match("/^d*$/", "4312")) if(preg_match("/^[a-z]*$/i", "fdsFDfd")) if(preg_match("/^[a-zd]*$/i", "fd4fd34")) |
parse_url函数
我们先来了解一下parse_url函数,官方解决
说明
mixed parse_url ( string $url [, int $component = -1 ] )
本函数解析一个 URL 并返回一个关联数组,包含在 URL 中出现的各种组成部分。
本函数不是用来验证给定 URL 的合法性的,只是将其分解为下面列出的部分。不完整的 URL 也被接受, parse_url() 会尝试尽量正确地将其解析。
要解析的 URL。无效字符将使用 _ 来替换。
实例
代码如下 | 复制代码 |
$url = "http://www.111cn.net.net/welcome/"; $parts = parse_url($url); print_r($parts);
|
也可以自己去写一个算法!如下
代码如下 | 复制代码 |
|
调用方法
代码如下 | 复制代码 |
$arr = getParams(); |
结果
结果: Array ( [_p] => index [_a] => show [x] => 12 [y] => 23 )
下面是我收藏的一些PHP判断字符串是纯英文、纯汉字或汉英混合 实例,大家可参考。纯英文
代码如下 | 复制代码 |
if(preg_match("/^[a-z]*$/i", "fdsFDfd")) { echo "全字母 "; } |
纯汉字
代码如下 | 复制代码 |
比如: |
汉英混合
用户名:包括英文小写、汉字、数字、下划线,不能全部是数字,下划线不能在末尾
代码如下 | 复制代码 |
/^[a-z0-9_u4e00-u9fa5]+[^_]$/g utf-8下 preg_match("/^[a-z0-9_x80-xff]+[^_]$/g",$a);gbk下: preg_match("/^[a-z0-9_".chr(0xa1)."-".chr(0xff)."]+[^_]$/",$a) |
utf-8编码
代码如下 | 复制代码 |
|
gbk编码
代码如下 | 复制代码 |
function gbk_str($str){ |
数字中文汉字
代码如下 | 复制代码 |
$username=$_REQUEST['username']; |
is_null(), empty(), isset(),这几个函数以及 == ” , == array() 会在实际操作中经常用到。因为功能很类似,可能会忽视了他们的区别,一不小心就会给工作带来很大的麻烦。下面将这几种结构列出来,供自己和大家参考,鉴于表述的准确性,部分解释来自英文原版手册,避免中文手册的更新不及时以及翻译不当等问题。
is_null()
is_null(),bool,当参数满足 null 的三种情况时, is_null() 将返回 TRUE。
null类型,以下情况将被认定为 NULL:
it has been assigned the constant NULL.
it has not been set to any value yet.
it has been unset().
source:http://cn2.php.net/manual/en/language.types.null.php
isset()
isset(),bool,用于判定参数是否被设定并且不是 NULL。参数只能是变量。
如果没有设置变量,或者变量被 unset() 掉,或者变量值为 NULL ,返回 FALSE,其它情况返回 TRUE。即如果不是 NULL 就属于 isset 的范畴了,这一点和 is_null() 函数正好相反。
如果传递多个参数,将取交集。即所有参数全部符合 isset() 时才返回 TRUE。
ps:defined(),bool,用于检查常量是否被设置。
source:http://cn2.php.net/manual/en/function.isset.php
empty()
empty(),bool, 主要用于判断变量是否为空。参数只能是变量。
如下情况将被判定位空:
代码如下 | 复制代码 |
“” (an empty string) 0 (0 as an integer) 0.0 (0 as a float) “0″ (0 as a string) NULL FALSE array() (an empty array) var $var; (a variable declared, but without a value in a class) |
注:如果参数是未设置的变量,变量将被认定为 NULL,不会报错,返回 TRUE。
但是注意在 5.0.0 之后,Objects with no properties are no longer considered empty.
source:http://cn2.php.net/manual/en/function.empty.php
判定是否为空的方式还有 == ”,== array() 等,比较有局限性,都没什么好说的。
测试的类型如下:
代码如下 | 复制代码 |
<?php ?> empty() 首先是empty的var_dump输出:
程序输出为: 从代码中可以看出,只要数据类型是否为空或假,empty()就输出true。 再看看isset的输出: // 输出 可以看出isset()只能用来判断是否为NULL和未定义。 最后是is_null的输出: // 输出 |
is_null 字面意思了。
由此可见 empty() 可以用来判定所有的数据类型是否为空或假,而 is_null 与 isset 基本一样,只能用来判断是否为NULL和未定义。
概括总结isset,empty,is_null区别:
刚才介绍的:检查变量,以及参数类型,这个是这3个函数不同之处的基础,也是最容易被忽视的。看到网上有很多对这个3个函数进行比较文章。很少涉及这些。下面我要说的,是在都检查已存在变量情况下,不同之处。
代码如下 | 复制代码 |
<?php $a=100; $b=""; $c=null; //isset检查 echo "isset","$a=$a",isset($a)?"define":"undefine","rn"; echo "isset","$b=$b",isset($b)?"define":"undefine","rn"; echo "isset","$c=$c",isset($c)?"define":"undefine","rn"; unset($b); echo "isset","$b",isset($b)?"define":"undefine","rn"; $b=0; echo "rnrn";
//empty检查 echo "empty","$a=$a",!empty($a)?"no empty":"empty","rn"; echo "empty","$b=$b",!empty($b)?"no empty":"empty","rn"; echo "empty","$c=$c",!empty($c)?"no empty":"empty","rn"; unset($b); echo "empty","$b",!empty($b)?"no empty":"empty","rn"; $b=0; echo "rnrn";
//is_null检查 echo "is_null","$a=$a",!is_null($a)?"no null":"null","rn"; echo "is_null","$b=$b",!is_null($b)?"no null":"null","rn"; echo "is_null","$c=$c",!is_null($c)?"no null":"null","rn"; unset($b); echo "is_null","$b",is_null($b)?"no null":"null","rn"; |
原理,就是生成mt_rand随机种子来生成,然后利用相关函数进行读取操作
例1
代码如下 | 复制代码 |
/** /** echo hideString(); |
例2 生成注册码/序列号
以下为引用的内容:
代码如下 | 复制代码 |
<?php /* 配置 */ /* 生成随机数字串 */ /* 过滤重复串并且提取最终需要的CD-Key数量 */ /* 把最终的CD-Key写入文件 */ echo "Create $key_total key succeed!"; /* 随机函数 */ ?> |
执行上面的程序就会生成cd_key.txt文件,里面包含了类似下面的验证码:
以下为引用的内容:
573-225-374-118
691-553-280-280
969-594-607-211
251-575-776-563
280-289-739-533...
这样,就完整的达到了我们的目的,你也可以把以上随机串保存到数据库里,方便调用。灵活设置以上变量,你能够生成16位、20位的验证码。如果你有兴趣,也可以写类似 XDF8F-ADE89-D0J5C-4RTFG之类的验证码