使用PHP的GD库扩展类制作验证码的基本步骤:
启用php.ini配置文件中的extension=php_gd2.dll扩展(打开php.ini配置文件,去掉行首的分号后重启Apache即可);
下面是PHP生成验证码的代码:
代码如下 | 复制代码 |
<?php |
下面是HTML中调用验证码的代码:
代码如下 | 复制代码 |
<html> |
如果出现"图像“XXXX”因其本身有错无法显示"的错误,很可能是漏了ob_clean();这句,或是文件的物理编码出了问题(修改物理编码的方法可以参考PHP创建utf8文件)
如果没有加ob_clean();这句,在本地测试且物理编码为ANSI时没问题,物理编码为UTF-8时则会报错(图像“XXXX”因其本身有错无法显示)
例子。explode
代码如下 | 复制代码 |
function checkstr($str){ |
原理非常的简单:就是以我们要查找的字符为定界,然后我们再利用explode分成函数,如果分切成功之后并且数组长度大于1那不代码是存在你要找到字符了,否则就没有了,这个只适用于判断字符串中是否存在字符,更多深一层就无法操作了。
例子,strpos()
strpos() 函数返回字符串在另一个字符串中第一次出现的位置
代码如下 | 复制代码 |
<?php |
例子,strstr()
strstr() 函数搜索一个字符串在另一个字符串中的第一次出现。
代码如下 | 复制代码 |
<?php |
总结
我觉得最简单的就是这种了 strpos($a, $b) !== false 如果$a 中存在 $b,则为 true ,否则为 false。
用 !== false (或者 === false) 的原因是如果 $b 正好位于$a的开始部分,那么该函数会返回int(0),那么0是false,但$b确实位于$a中,所以要用 !== 判断一下类型,要确保是严格的 false。昨天晚上去中关村图书大厦,看到一本书中用的是 strpos === true 来判断,这是极其不正确的
如果我们直接使用fopen创建会发现文件编码都不是uft-8的了,那么如果要创建uft8文件我们需要进行一些技术处理,下面我搜索了网络上一些通用方法,下面一起来看看吧。使用PHP创建编码格式为utf-8文件的方法:
第一步:新建一个txt文件,打开,文件->另存为xxx.php,并将编码改为UTF-8,保存。
第二部:在php文件中加入如下代码:
代码如下 | 复制代码 |
<?php $filename=rand(100,999).".txt";//定义好要创建的文件名称和文件格式(按需要自己改) $str = "PHP知名网[www.111cn.net]";//待写入新建文件中的内容 if (!$head=fopen($filename, "w+")) {//以读写的方式打开文件,将文件指针指向文件头并将文件大小截为零,如果文件不存在就自动创建 die("尝试打开文件[".$filename."]失败!请检查是否拥有足够的权限!创建过程终止!"); } if (fwrite($head,$str)==false) {//执行写入文件 fclose($head); die("写入内容失败!请检查是否拥有足够的权限!写入过程终止!"); } echo "成功创建UTF-8格式文件[".$filename."],并向该文件中写入了内容:".$str; fclose($head); ?> |
使用这种方法创建UTF-8编码文件的关键点:
保证PHP代码文件本身的编码格式为UTF-8
php代码文件的编码格式是什么则创建出来的文件编码也是什么
显示出现乱码的问题
控制页面显示的因素主要有三个:
1.HTML代码控制:标准HTML网页文件中的head标签内部包含了这一句代码<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />,代码中charset=utf-8这句就是告诉浏览器要以utf-8格式将网页中的内容显示出来。
2.PHP代码控制:如果在PHP文件的开头加上header("content-Type: text/html; charset=utf-8");这句代码,也是为了告诉浏览器要以utf-8格式将网页中的内容显示出来。(注:这句代码之前不能有类似echo的输出)
3.文件物理存储属性控制:用记事本打开一个文件,文件->另存为,你在“编码”中所看到的就是当前文件的真正的编码
补充一个fopen例子
代码如下 | 复制代码 |
<?php $f=fopen("test.txt", "wb"); $text=utf8_encode("a!"); //先用函数utf8_encode将所需写入的数据变成UTF编码格式。 $text="\xEF\xBB\xBF".$text; //"\xEF\xBB\xBF",这串字符不可缺少,生成的文件将成为UTF-8格式,否则依然是ANSI格式。 fputs($f, $text); //写入。 fclose($f); ?> |
这样创建出的文件编码格式确实是utf-8,但是放在文件中的汉字出现了乱码的现象,经过一番调试,代码如下:
代码如下 | 复制代码 |
<?php $ctxtsubmit="好呀"; $f=fopen("../".$file, "wb"); //$text=utf8_encode($ctxtsubmit); //先用函数utf8_encode将所需写入的数据变成UTF编码格式。 $text="\xEF\xBB\xBF".$ctxtsubmit; //"\xEF\xBB\xBF",这串字符不可缺少,生成的文件将成为UTF-8格式,否则依然是ANSI格式。 fputs($f, $text); //写入。 fclose($f); ?> |
至于"\xEF\xBB\xBF"为什么加这字符串,我也不明白
php定时跳转我们需要利用header函数输入html或js代码来实现定时跳转了,下面我来介绍一个简单的例子php代码
代码如下 | 复制代码 |
header("refresh:3;url=http://www.111cn.net"); |
输出的html代码就是
<meta http-equiv="refresh" content="3; url=http://www.111cn.net">一样的效果。
这样就实现了3秒之后自动跳转到http://www.111cn.net了哦
友情提示,如果你文件是uft-8编码的话我们要注意不要在header前有输出或BOM字符哦,这可会导致无法跳转。
直接在php中的多文件上传我有介绍过很多并且也写过专题了,但是在thinkphp中多文件上传还是头一次碰到了,那么这个thinkphp多文件上传与php会有什么区别与共同点呢?下面我来给大家介绍一个Thinkphp框架实现多文件上传吧,希望对各位会有点帮助哦。Thinkphp手册中对于多文件上传描述的很清楚:如果需要使用多个文件,只需要修改表单,把
代码如下 | 复制代码 |
<input type='file' name='photo'> <li><input type='file' name='photo1'></li> <li><input type='file' name='photo[]'></li> |
暂且自己的上传表单域为两个,一个上传图片,一个上传视频。字段名为image、video。
html代码如下
代码如下 | 复制代码 |
图片:<input type="file" name="image[]"> protected $info= ''; |
文章最后我来分析一下多文件上传原理吧,先来看看html代码
<li><input type='file' name='photo[]'></li>
<li><input type='file' name='photo[]'></li>
<li><input type='file' name='photo[]'></li>
这种就是把表单变量定义为数组,在php中数组特殊变量它可以存储多个不定长的内容,所以我们就可以自定多文件上传框了,那么在php处理时我们要如何操作,下面看例子。
protected $_auto = array(
array('image','upload',3,callback),//自动完成方法
array('video','videoupload',3,callback), //自动完成方法
);//自动填充上传图片生成缩略图
这个是告诉thinkphp是数组变量了,并不需要像原生态的php中来判断遍历数组长度再一个个上传的代码了,因为了thinkphp己经做好了。