代码如下 | 复制代码 |
<body> <form id="form1" name="form1" method="post" action=""> <label for="textfield"></label> <input type="text" name="txt" id="txt" /> <input type="submit" name="button" id="button" value="提交" /> </form> </body> </html> <? if( $_POST ) { $txt = $_POST['txt']; echo $txt.'<br />'; echo str_replace(chr(32),' ',$txt); } ?> |
1.fopen(创建文件和打开文件)
语法:
fopen(filename,mode)filename,规定要打开的文件。mode,打开文件的模式,可能的值见下表。
mode 说明
"r" 只读方式打开,将文件指针指向文件开头。
"r+" 读写方式打开,将文件指针指向文件开头。
"w" 写入方式打开,将文件指针指向文件开头并将文件大小截为零。如果文件不存在则尝试创建。
"w+" 读写方式打开,将文件指针指向文件开头并将文件大小截为零。如果文件不存在则尝试创建。
"a" 写入方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建。
"a+" 读写方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建。
如果成功打开文件,fopen函数的返回值是一个文件指针,如果出错,返回 FALSE。
示例:
代码如下 | 复制代码 |
<?php $fp = fopen("test.txt", "r"); ?> |
2.fclose(关闭文件)
语法:
fclose(filepointer)
filepointer,要关闭的文件指针。如果成功,fclose 函数返回 TRUE,如果失败,fclose 函数返回 FALSE。
示例:
代码如下 | 复制代码 |
<?php $fp = fopen("test.txt", "r"); fclose($fp); ?> |
3.feof(检测是否已到达文件末尾)
语法:
feof(filepointer)
filepointer,要检测的文件指针,该指针必须指向成功打开没有关闭的文件。如果文件指针到了文件末尾或者出错时,feof函数返回 TRUE。
示例:
代码如下 | 复制代码 |
<?php $fp = fopen("test.txt", "r"); while(! feof($fp)) { echo fgets($fp). "<br />"; } fclose($fp); ?> |
4.fgets(从文件指针中读取一行)
语法:
fgets(filepointer)
filepointer,要读取的文件指针。如果成功,从文件中读取一行并返回字符串,如果失败,返回 FALSE。
示例:
代码如下 | 复制代码 |
<?php $fp = fopen("test.txt", "r"); if($fp) { for($i=1;! feof($fp);$i++) { echo "行".$i." : ".fgets($fp). "<br />"; } } else { echo "打开文件失败"; } fclose($fp); ?> |
假设test.txt的内容为:
hello world
hello cnblogs
hello heihaozi
hello everyone
页面输出的结果为:
行1 : hello world
行2 : hello cnblogs
行3 : hello heihaozi
行4 : hello everyone5.fwrite(写入文件)
语法:
fwrite(filepointer,string) filepointer,要写入的文件指针。string,要写入的字符串。如果成功,返回写入的字符数,如果失败,返回 FALSE。
示例:
代码如下 | 复制代码 |
<?php $fp = fopen("test.txt", "w");//文件被清空后再写入 if($fp) { $count=0; for($i=1;$i<=5;$i++) { $flag=fwrite($fp,"行".$i." : "."Hello World!rn"); if(!$flag) { echo "写入文件失败<br>"; break; } $count+=$flag; } echo "共写入".$count."个字符"; } else { echo "打开文件失败"; } fclose($fp); ?> |
页面输出的结果为:
共写入100个字符
test.txt文件会被写入:
行1 : Hello World!
行2 : Hello World!
行3 : Hello World!
行4 : Hello World!
行5 : Hello World!
注:为了简化操作,部分函数的可选参数没有列出。
这个有点像mysql int类型超过了就溢出,而我们只要用bigint就可以了,那么因为php中int数据范围的问题,所以就也有可能出现这类问题。编码过程中遇到个错误,就是在处理json时,数值较大的int值在解码后数据被损坏,比如:
代码如下 | 复制代码 |
$array = array( array(2) { |
但实际在我的电脑上却得到:
代码如下 | 复制代码 |
array(2) { ["id1"]=>int(2147483647) ["id2"]=>int(-2147483646) } |
这是由PHP整数值范围决定的,而这个范围依赖于操作系统。在32位操作系统中,PHP的整数最大值是2147483647,你可以通过输出PHP_INT_MAX看到。
一般情况下,你赋值一个很大的数,PHP会自动判定这个数值的范围并自动转换类型,如:
代码如下 | 复制代码 |
$large_number = 2147483647; var_dump($large_number); // int(2147483647) $large_number = 2147483648; var_dump($large_number); // float(2147483648) $million = 1000000; $large_number = 50000 * $million; var_dump($large_number); // float(50000000000) |
但是在json_decode方法中没有进行这种检测,这是PHP(旧版本)的bug,在5.3以后的版本,就不存在这个问题了。
如果你不想更新你的PHP,那还有个办法,就是将数字转为字符串。还是以上面的代码为例:
代码如下 | 复制代码 |
$array = array( "id1" => 2147483647, "id2" => 2147483648 ); $json = json_encode($array); $json = preg_replace('/("idd":)(d{9,})/i', '${1}"${2}"', $json); $out = json_decode($json, true); var_dump($out); |
当然,这个怎么替换是按需而定的,而且需要比较细致的测试。
在开发时出现uft-8页面中文验证码乱码了,在baidu搜索发现了原因,下面有解决办法有需要的朋友可以参考一下。
代码如下 | 复制代码 |
<?
$im=imagecreatetruecolor(100,30);//画板,新建一个真彩色图像 //设置颜色 //画线条 //画点
//把字符串写在图像左上角 //输出图像
?> |
分析原因与解决办法
代码如下 | 复制代码 |
$str=iconv("gbk","utf-8","新年快乐!");//确定要绘制的中文文字 |
-->>
应该这样的
代码如下 | 复制代码 |
$str=iconv("gbk","utf-8","新年快乐!");//确定要绘制的中文文字 imagettftext($im,12,3,20,20,$te,'msyhbd.ttf',$str); |
<?php
$cahetime=2;//设置过期时间
$cahefile="cahe.txt";//读写文本
if(file_exists($cahefile) && time()-$cahetime< filemtime($cahefile)){
echo file_get_contents($cahefile);
}
else {
file_put_contents($cahefile,date("y-m-d H:i:s",time()));
}
?>