定义和用法
filesize() 函数返回指定文件的大小。
若成功,则返回文件大小的字节数。若失败,则返回 false 并生成一条 E_WARNING 级的错误。
语法
filesize(filename)
参数 | 描述 |
---|---|
filename | 必需。规定要检查的文件。 |
提示和注释
提示:本函数的结果会被缓存。请使用 clearstatcache() 来清除缓存。
例子
<?php echo filesize("test.txt"); ?>
filesize() 函数返回指定文件的大小。
若成功,则返回文件大小的字节数。若失败,则返回 false 并生成一条 E_WARNING 级的错误。
filesize(filename)
参数 | 描述 |
---|---|
filename | 必需。规定要检查的文件。 |
提示:本函数的结果会被缓存。请使用 clearstatcache() 来清除缓存。
<?php echo filesize("test.txt"); ?>
clearstatcache() 函数清除文件状态缓存。
有时函数会缓存某些函数的返回信息,以便提供更高的性能。但是有时候,比如在一个脚本中多次检查同一个文件,而该文件在此脚本执行期间有被删除或修改的危险时,你需要清除文件状态缓存,以便获得正确的结果。要做到这一点,就需要使用 clearstatcache() 函数。
会进行缓存的函数,即受 clearstatcache() 函数影响的函数:
clearstatcache()
filemtime() 函数返回文件内容上次的修改时间。
若成功,则时间以 Unix 时间戳的方式返回。若失败,则返回 false。
filemtime(filename)
参数 | 描述 |
---|---|
filename | 必需。规定要检查的文件。 |
本函数返回文件中的数据块上次被写入的时间,也就是说,文件的内容上次被修改的时间。
提示:本函数的结果会被缓存。请使用 clearstatcache() 来清除缓存。
$a=filemtime("log.txt"); echo "修改时间:".date("Y-m-d H:i:s",$a).";
使用Ajax技术做动态加载的网站,有时也需要定时拉取服务器信息,比如给登录用户发送消息之类的.这里介绍两个函数,setInterval开始定时执行一个任务,clearInterval终止指定的任务.
setInterval() 方法可按照指定的周期(以毫秒计)来调用函数或计算表达式。
setInterval() 方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭。由 setInterval() 返回的 ID 值可用作 clearInterval() 方法的参数。
setInterval(code,millisec[,"lang"])
参数 | 描述 |
---|---|
code | 必需。要调用的函数或要执行的代码串。 |
millisec | 必须。周期性执行或调用 code 之间的时间间隔,以毫秒计。 |
一个可以传递给 Window.clearInterval() 从而取消对 code 的周期性执行的值。
clearInterval() 方法可取消由 setInterval() 设置的 timeout。
clearInterval() 方法的参数必须是由 setInterval() 返回的 ID 值。
clearInterval(id_of_setinterval)
参数 | 描述 |
---|---|
id_of_setinterval | 由 setInterval() 返回的 ID 值。 |
下面这个例子将每隔 50 毫秒调用 clock() 函数。您也可以使用一个按钮来停止这个 clock:
<html> <body> <input type="text" id="clock" size="35" /> <script language=javascript> var int=self.setInterval("clock()",50) function clock() { var t=new Date() document.getElementById("clock").value=t } </script> <button onclick="int=window.clearInterval(int)">Stop interval</button> </body> </html>
刚开始接触AJAX,先是直接JS写,代码比较多,后来直接用JQ来写方便多了,在写AJAX的时候,发现由AJAX加载的内容却不能响应JS/JQ的事件,百度一下,总算了解了一点…
在需要动态加载的内容绑定事件的时候,可以用.on ,这是jq的方法.
$(document).on('click',"button",function(){ //事件触发后的处理 });
用这样的方式绑定button控件的click事件,即使button控件是ajax动态加载的,也会正常执行.
.on( events [, selector ] [, data ], handler(eventObject) )
以上是.on的描述.
做了一个ajax的站,php后台处理完了数据库后,需要把结果以json数据的方式发到前端由js使用,编程这东西,编码总是会莫名其妙造成影响…
//$result是一个mysql查询的结果集 while($row = mysql_fetch_array($result)){ foreach ( $row as $key => $value ) { $row[$key] = urlencode ( $value ); } $urlencode_result[$i++]=$row; } $json = urldecode(json_encode($urlencode_result));
以上代码,首先把结果集中的每个值都urlencode来解决可能出现的编码问题,然后json_encode,把已经urlencode处理过的转成json数据,最后把json数据中被urlencode的数据恢复.
原理就是PHP的json_encode会把中文转成乱码,但是在json_encode前先urlencode,这样就没有中文了,转为json后没有问题,转换完,要用的时候在urldecode恢复中文数据.
你可能还需要看看PHP读取MYSQL数据后中文乱码的解决方法
做模拟登陆或者后台任务的时候,可能会需要php在后台直接post数据到其他页面,并且获取返回结果来进行下一步处理.可能比较常用的是curl,不过在一些简单的地方使用,感觉有些麻烦,一个post要一大堆代码…
善用搜索引擎,发现了一个比较简单的post数据的方式,封装成一个函数方便调用.
function do_post_request($url, $data, $optional_headers = null) { $params = array('http' => array( 'method' => 'POST', 'content' => $data )); if ($optional_headers !== null) { $params['http']['header'] = $optional_headers; } $ctx = stream_context_create($params); $fp = @fopen($url, 'rb', false, $ctx); if (!$fp) { throw new Exception("Problem with $url, $php_errormsg"); } $response = @stream_get_contents($fp); if ($response === false) { throw new Exception("Problem reading data from $url, $php_errormsg"); } return $response; }
调用方法:
do_post_request($url,$data,$headers); //第一个参数写post的对象,需要写绝对地址,例如"http://www.devsk.com" //第二个参数写要post的数据,例如"a=1&b=2",目标页面$_POST['a']的值就是1,$_POST['b']的值就是2 //第三个参数可以不填,如果需要设置header,则可以在第三个参数输入,比如要传递cookie,可以写"Cookie:ID=123" //函数返回值就是目标页面的输出 //完整的调用实例: $result = do_post_request("http://www.devsk.com","a=1&b=2","Cookie:ID=123"); //向http://www.devsk.com页面post数据,包含两个变量(a=1 b=2)和一个cookie (ID=123).最后http://www.devsk.com页面的输出赋值给变量$result.
JS本身没有直接操作cookie的函数,于是自己写了一个,可以读取,写入,删除cookie.
以下是代码:
setcookie('t','1','10'); //设置cookie,第一个参数是名称,第二个是值,第三个可选,表示有效时间,单位是秒 alert(getcookie('t')); //获取cookie,参数是cookie名称 delcookie('t'); //删除cookie,参数是cookie名称 alert(getcookie('t')); function setcookie(name,value,extime){ var exdate=new Date(); exdate.setTime(exdate.getTime()+extime*1000); document.cookie=name+ "=" +escape(value)+((extime==null) ? "" : ";expires="+exdate.toGMTString()); } function getcookie(name){ var cookies = document.cookie.split("; "); for(var i = 0;i < cookies.length;i ++){ var value = cookies[i].split("="); if(value[0] == name) { var value = unescape(value[1]); return value; } } } function delcookie(name){ var exdate=new Date() exdate.setDate(exdate.getDate()-1); document.cookie=name+ "=;expires="+exdate.toGMTString(); }
有时为了调试程序,需要查看所有POST过来的数据.
file_get_contents("php://input"); echo file_get_contents("php://input");
有些mysql查询返回的结果仅仅是成功或失败.
也许有些查询影响的行数为0,但是这个查询没有错误,那么返回的也是执行成功,然而有的时候是需要知道查询影响了多少条数据的.
PHP有个函数
mysql_affected_rows();
可以取得最近一次 INSERT,UPDATE 或 DELETE 查询所影响的记录行数。
这个函数可以带一个MYSQL连接标识符的参数,如果不加参数,如果没有指定,默认使用最后被 mysql_connect() 打开的连接。
执行成功,则返回受影响的行的数目,如果最近一次查询失败的话,函数返回 -1。
如果最近一次操作是没有任何条件(WHERE)的 DELETE 查询,在表中所有的记录都会被删除,但本函数返回值在 4.1.2 版之前都为 0。
当使用 UPDATE 查询,MySQL 不会将原值与新值一样的列更新。这样使得 mysql_affected_rows() 函数返回值不一定就是查询条件所符合的记录数,只有真正被修改的记录数才会被返回。
REPLACE 语句首先删除具有相同主键的记录,然后插入一个新记录。该函数返回的是被删除的记录数加上被插入的记录数。