mysql> select FROM_UNIXTIME(1156219870,’%y-%m-%d’);
mysql> Select UNIX_TIMESTAMP(’1997-10-04 22:23:00′);
mysql> select FROM_UNIXTIME(1156219870,’%y-%m-%d’);
mysql> Select UNIX_TIMESTAMP(’1997-10-04 22:23:00′);
今天发现在URL中使用GET传输中文时会出现乱码,经搜索得知这是因为PHP的网页中UTF8编码造成的。解决的方法很简单,就是在传输前先使用“urlencode”转换一下。比如把原来要转的文字变成: <?php echo urlencode("汉字汉字")?>
今天遇到了一些PHP中操作日期的问题,经搜索找到了一些有用的总结,现转下
php中对时间日期的处理时相对简单的,php中提供了date/time 函数允许您提取并格式化服务器上的日期和时间。
date/time函数的行为受到 php.ini 中设置的影响。当然我们可以手动更改其中的配置项参数,不过最好不要更改。
php 为我们提供了不少函数来操控时间,虽然多 但用的不多。
<?php
/*
* Created on 2010-8-20
*
* @author wangyalei
*
*/
//1.date() 函数格式化一个本地时间/日期
//format 必需。规定如何返回结果。 timestamp 可选。规定时间戳。默认是当前的日期和时间。
//date(format,timestamp)
// d – 月中的天 (01-31)
// m – 当前月,以数字计 (01-12)
// Y – 当前的年(四位数)
echo date("Y/m/d");
echo "<br />";
echo date("Y.m.d");
echo "<br />";
echo date("Y-m-d");
//输出
//2010/08/20
//2010.08.20
//2010-08-20
//设置时区
date_default_timezone_set("Asia/Shanghai");
$now = getdate();
print "{$now['hours']}:{$now['minutes']}:{$now['seconds']}\t";//22:13:57
$now = localtime();
print "$now[2]:$now[1]:$now[0]";// 22:14:1
//2。mktime() 函数返回一个日期的 Unix 时间戳。
//语法 mktime(hour,minute,second,month,day,year,is_dst)
//参数可以从右到左依次空着,空着的参数会被设为相应的当前 GMT 值。
$then = mktime(23,31,22,8,21,2010);
echo $then;//1282433482 这个就是当前的时间戳
echo "<br>";
//把时间戳 转换为正常时间格式
echo "day is ".date("Y/m/d", $then);//day is 2010/08/21
echo "<br>";
//获取明天的日期
$tomorrow = mktime(0,0,0,date("m"),date("d")+1,date("Y"));
echo "Tomorrow is ".date("Y/m/d", $tomorrow);
//和mktime 一般差不多
echo gmmktime(23,31,22,8,21,2010);//221282433482
//4 strftime() 函数根据区域设置格式化本地时间/日期。
//strftime(format,timestamp) format 可选。规定如何返回结果。timestamp 可选。
$then = mktime(23,31,22,8,21,2010);
print strftime("%c",$then);//08/21/10 23:31:22
$then = gmmktime(23,31,22,8,21,2010);
echo "<br>";
print strftime("%c",$then);//08/21/10 23:31:22
// strftime 和 date 相比 更容易生成内部带有插值的时间和日期值的字符串
date_default_timezone_set("Asia/Shanghai");
print strftime(" 现在时间 %I, %P %B %d,%Y");//现在时间 10, August 22,2010
print "现在时间".date(‘h a ‘).date(‘F d,y’);//现在时间10 am August 22,10
//5计算两个时间差
$now_1 = mktime(0,0,0,8,21,2010);
$now_2 = mktime(0,0,0,8,22,2010);
$diff_seconds = $now_2-$now_1;
//相差 的月
$diff_week = floor($diff_seconds/604800);//60*60*24*7
//相差的天
$diff_day = floor($diff_seconds/86400);//60*60*24
echo "相差 时间为".$diff_week."个月".$diff_day."天";//相差 时间为0个月1天
//6验证日期
//checkdate($month,$day,$year);// return true or false
echo checkdate(2,30,2005) ? "valid" : "invalid";
//看一个例子
function pc_checkdate($month,$day,$year){
$min_age = 18;
$max_age = 250;
if(!checkdate($month,$day,$year)){
return false;
}
list($this_year,$this_month,$this_day) = explode(",",date("Y,m,d"));
$min_year = $this_year – $max_age;
$max_year = $this_year – $min_age;
if(($year>=$min_year)&&($year<=$max_year)){
return true;
}else{
return false;
}
}
if(pc_checkdate(12,3,2001)){
print "0k";
}else{
print "no";
}
//7 从字符串中解析时间
//strtotime() 函数将任何英文文本的日期时间描述解析为 Unix 时间戳。
//strtotime(time,now)
//time 规定要解析的时间字符串。
//now 用来计算返回值的时间戳。如果省略该参数,则使用当前时间。
//成功则返回时间戳,否则返回 FALSE。在 PHP 5.1.0 之前本函数在失败时返回 -1。
echo(strtotime("now"));
echo "<br>";
echo(strtotime("3 October 2005"));
echo "<br>";
echo(strtotime("+5 hours"));
echo "<br>";
echo(strtotime("+1 week"));
echo "<br>";
echo(strtotime("+1 week 3 days 7 hours 5 seconds"));
echo "<br>";
echo(strtotime("next Monday"));
echo "<br>";
echo(strtotime("last Sunday"));
//8 使用正侧表达式 解析时间
//如果要从字符串中解析时间 你不知道其格式 就不能使用 strtotime
$date = ’2008-12-2 12:30:21′;
preg_match(‘/(\d{4})-(\d{2})-(\d{2})(\d{2}):(\d{2}):(\d{2})/’,$date,$datearry);
//分割时间
$date_arry=preg_split("/[-:]/",$date);
var_dump($date_arry);
//array(5) {
// [0]=>
// string(4) "2008"
// [1]=>
// string(2) "12"
// [2]=>
// string(4) "2 12"
// [3]=>
// string(2) "30"
// [4]=>
// string(2) "21"
//}
?>
date – 格式化一个本地时间/日期 的 format 字符 在手册中讲解的非常详细了在这就不多废话了
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>else if语句的应用</title>
</head>
<body>
<?php
$moth = date("n"); //设置月份变量$moth
$today = date("j"); //设置日期变量$today
if ($today >= 1 and $today <= 10){ //判断日期变量是否在1-10之间
echo "今天是".$moth."月".$today."日上旬"; //如果是,说明是上旬
}elseif($today > 10 and $today <= 20){ //否则判
最近在做的系统中要实现一个功能,我将多个用户的u_id插入到了document表中的receiver字段中,并以逗号分隔开。在某个功能上要查询出包含有某个用户的documnet记录。之前一直是将这段string取出,分割成数组然后再用数组包含进行判断,相当的麻烦。但是还是能实现功能,可是今天发现在使用分页类时出现了问题,经过查找终于知道MYSQL有一个 FIND_IN_SET函数可以直接查询出需要的记录。
格式如下:
SELECT * FROM `document` WHERE FIND_IN_SET($u_id,`receiver`)
在wamp环境中修改mysql 的密码需要两步操作:
今天一早想使用Google在线文档,用来记录一些可能需要随时随地打开的信息,可是居然访问不了。上网搜索后有人给出了这样一个链接:http://www.google.com/prc/report.html 这上面记录的是谷歌服务在中国大陆的可用性。很悲剧的看到在线文档有部分无法接入。
今天做已上传文件的删除时,发现网上找到的例子可以删除(包括中文名),可是一用到我做的系统中时却失效。仔细比对后联想到昨天做上传时的情况,终于发现还是因为编码问题。当我们在UTF8的PHP网页中使用unlink做删除时,必须要把编码先转成gb2312才可以成功删除中文文件。关键代码:
iconv("UTF-8","gb2312", $rowfile[att_path] );
unlink($file);
另外,在研究中还发现自己犯了一个低级错误,因为在删除的同时把几个表中相关的记录全删掉,所以习惯性的在前面先写好了删除语句,导致后面写的删除文件语句已经找不到相应的记录了。差点酿成大杯具
在网上找到了一个可以用的PHP多文件上传类,经调试比较好用,对上传的文件进行了一些基本的属性判断。但是后来发现传上去的中文文件会出现乱码,搜索后知道可以先将utf8码转成gb2312再移动到指定位置,然后再转回gb2312这样网页中显示的汉字也不会有问题。
乱码问题关键代码:
$name=iconv("UTF-8","gb2312", $name);
move_uploaded_file($tmpname, $this->final_file_path);
$name=iconv("gb2312","UTF-8", $name);
多文件上传完整代码:
<?php
/**//*
* @(#)UploadFile.php
*
* 可同时处理用户多个上传文件。效验文件有效性后存储至指定目录。
* 可返回上传文件的相关有用信息供其它程序使用。(如文件名、类型、大小、保存路径)
* 使用方法请见本类底部(UploadFile类使用注释)信息。
*
*/
class UploadFile {
var $user_post_file = array(); //用户上传的文件
var $save_file_path; //存放用户上传文件的路径
var $max_file_size; //文件最大尺寸
var $last_error; //记录最后一次出错信息
//默认允许用户上传的文件类型
var $allow_type = array(‘gif’, ‘jpg’, ‘png’, ‘zip’, ‘rar’, ‘txt’, ‘doc’,'xls’, ‘pdf’);
var $final_file_path; //最终保存的文件名
var $save_info = array(); //返回一组有用信息,用于提示用户。
/**//**
* 构造函数,用与初始化相关信息,用户待上传文件、存储路径等
*
* @param Array $file 用户上传的文件
* @param String $path 存储用户上传文件的路径
* @param Integer $size 允许用户上传文件的大小(字节)
* @param Array $type 此数组中存放允计用户上传的文件类型
*/
function UploadFile($file, $path, $size = 2097152, $type = ”) {
$this->user_post_file = $file;
$this->save_file_path = $path;
$this->max_file_size = $size; //如果用户不填写文件大小,则默认为2M.
if ($type != ”)
$this->allow_type = $type;
}
/**//**
* 存储用户上传文件,检验合法性通过后,存储至指定位置。
* @access public
* @return int 值为0时上传失败,非0表示上传成功的个数。
*/
function upload() {
for ($i = 0; $i < count($this->user_post_file['name']); $i++) {
//如果当前文件上传功能,则执行下一步。
if ($this->user_post_file['error'][$i] == 0) {
//取当前文件名、临时文件名、大小、扩展名,后面将用到。
$name = $this->user_post_file['name'][$i];
//$name=iconv("UTF-8","gb2312", $name);//为防止上传的中文名乱码,先转成gb2312,最后再转回
$tmpname = $this->user_post_file['tmp_name'][$i];
$size = $this->user_post_file['size'][$i];
$mime_type = $this->user_post_file['type'][$i];
$type = $this->getFileExt($this->user_post_file['name'][$i]);
//检测当前上传文件大小是否合法。
if (!$this->checkSize($size)) {
$this->last_error = $name."超过允许上传的大小";
$this->halt($this->last_error);
continue;
}
//检测当前上传文件扩展名是否合法。
if (!$this->checkType($type)) {
$this->last_error = $name."不是允许上传的文件类型";
$this->halt($this->last_error);
continue;
}
//检测当前上传文件是否非法提交。
if(!is_uploaded_file($tmpname)) {
$this->last_error = "Invalid post file method. File name is: ".$name;
$this->halt($this->last_error);
continue;
}
$name=iconv("UTF-8","gb2312", $name);
//移动文件后,重命名文件用。
$basename = $this->getBaseName($name, ".".$type);
//移动后的文件名
$saveas = $basename."-".time().rand(100,999).".".$type;
//组合新文件名再存到指定目录下,格式:存储路径 + 文件名 + 时间 + 扩展名
$this->final_file_path = $this->save_file_path."/".$saveas;
if(!move_uploaded_file($tmpname, $this->final_file_path)) {
$this->last_error = $this->user_post_file['error'][$i];
$this->halt($this->last_error);
continue;
}
$name=iconv("gb2312","UTF-8", $name);
$saveas=iconv("gb2312","UTF-8", $saveas);
$this->final_file_path=iconv("gb2312","UTF-8", $this->final_file_path);
//存储当前文件的有关信息,以便其它程序调用。
$this->save_info[] = array("name" => $name, "type" => $type,"mime_type" => $mime_type,
"size" => $size, "saveas" => $saveas,
"path" => $this->final_file_path);
}
}
return count($this->save_info); //返回上传成功的文件数目
}
/**//**
* 返回一些有用的信息,以便用于其它地方。
* @access public
* @return Array 返回最终保存的路径
*/
function getSaveInfo() {
return $this->save_info;
}
/**//**
* 检测用户提交文件大小是否合法
* @param Integer $size 用户上传文件的大小
* @access private
* @return boolean 如果为true说明大小合法,反之不合法
*/
function checkSize($size) {
if ($size > $this->max_file_size) {
return false;
}
else {
return true;
}
}
/**//**
* 检测用户提交文件类型是否合法
* @access private
* @return boolean 如
今天研究PHP文件上传时,发现不能成功上传体积比较大的文件。其实只要对php进行一些设置就行了。
经过搜索得知主要调整 upload_max_filesize 和 post_max_size 的大小就行了。但网上有一篇更详细的文章:
如果配置脚本中激活了内存限制,memory_limit 也会影响文件上传。通常说,memory_limit 应该比 post_max_size 要大。
当使用 integer 类型时,其值以字节为度量单位。还可以用简化符号,说明见此 FAQ。
如果 POST 数据尺寸大于 post_max_size $_POST 和 $_FILES superglobals 便会为空。这可以以多种方式证明,例如,传递 $_GET 变量到脚本以处理数据, 也就是 <form action="edit.php?processed=1">, 然后查看 $_GET['processed'] 是否被设置。
这段代码分为两个文件,一个为upload.html,一个是upload.php
upload.html
<form enctype="multipart/form-data" action="upload.php" method="post">
<input type="hidden" name="max_file_size" value="100000">
<input name="userfile" type="file">
<input type="submit" value="上传文件">
</form>
其中,
请注意<form enctype="multipart/form-data"……>这是一个标签,我们要实现文件的上传,必须指定为multipart/form-data,否则服务器将不知道要干什么。
值得注意的是文件upload.html中表单选项 MAX_FILE_SIZE 的隐藏值域,通过设置其Value(值)可以限制上载文件的大小。
MAX_FILE_SIZE 的值只是对浏览器的一个建议,实际上它可以被简单的绕过。因此不要把对浏览器的限制寄希望于该值。实际上,PHP 设置中的上传文件最大值,是不会失效的。但是最好还是在表单中加上 MAX_FILE_SIZE,因为它可以避免用户在花时间等待上传大文件之后才发现该文件太大了的麻烦。
upload.php
$f=&$HTTP_POST_FILES['Myfile'];
$dest_dir=’uploads’;//设定上传目录
$dest=$dest_dir.’/’.date("ymd")."_".$f['name'];//设置文件名为日期加上文件名避免重复
$r=move_uploaded_file($f['tmp_name'],$dest);
chmod($dest, 0755);//设定上传的文件的属性
或者
<?copy($_FILES[MyFile][tmp_name],$_FILES[MyFile][name]);?>
以上范例中 $_FILES 数组的内容如下所示。我们假设文件上传字段的名称为 userfile(名称可随意命名)
$_FILES['userfile']['name'] 客户端机器文件的原名称。
$_FILES['userfile']['type'] 文件的 MIME 类型,需要浏览器提供该信息的支持,例如“image/gif”。
$_FILES['userfile']['size'] 已上传文件的大小,单位为字节。
$_FILES['userfile']['tmp_name'] 文件被上传后在服务端储存的临时文件名。
$_FILES['userfile']['error'] 和该文件上传相关的错误代码
值:0; 没有错误发生,文件上传成功。
值:1; 上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值。
值:2; 上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。
值:3; 文件只有部分被上传。
值:4; 没有文件被上传。
[编辑]PHP上传文件涉及到的参数
PHP默认的上传限定是最大2M,想上传超过此设定的文件,需要调整PHP、apache等的一些参数. 下面,我们简要介绍一下PHP文件上传涉及到的一些参数:
file_uploads
是否允许通过HTTP上传文件的开关,默认为ON即是开
upload_tmp_dir
upload_tmp_dir用来说明PHP上传的文件放置的临时目录,要想上传文件,得保证服务器没有关闭临时文件和有对文件夹的写权限,如果未指定则PHP使用系统默认值
upload_max_filesize
允许上传文件大小的最大值,默认为2M
post_max_size
控制在采用POST方法进行一次表单提交中PHP所能够接收的最大数据量。如果希望使用PHP文件上传功能,则需要将此值改为比upload_max_filesize要大
max_input_time
以秒为单位对通过POST、GET以及PUT方式接收数据时间进行限制。如果应用程序所运行环境处在低速链路上,则需要增加此值以适应接收数据所需的更多时间
memory_limit
为了避免正在运行的脚本大量使用系统可用内存,PHP允许定义内存使用限额。通过memory_limit变量来指定单个脚本程序可以使用的最大内存容量变量memory_limit的值应当适当大于post_max_size的值
max_execution_time
max_execution_time 设置了在强制终止脚本前PHP等待脚本执行完毕的时间,此时间以秒计算。当脚本进入了一个无限循环状态时此变量非常有用。然而,当存在一个需要很长时间完 成的合法活动时(例如上传大型文件),这项功能也会导致操作失败。在这样的情况下必须考虑将此变量值增加,以避免PHP在脚本正在执行某些重要过程的时候 将脚本关闭
对于linux主机,可能在/etc/httpd/conf.d/access.conf/下面里面还有php.conf 文件,这个文件可能会解决一些系统的文件大小限制问题
[编辑]利用discuz实现PHP大文件上传应用举例
论坛的附件功能当初设计的初衷并不是为了文件管理,由于服务器配置,php,网络等多方面因素,使得通过论坛上传文件并不是一个好方案。
对于确实需要改善论坛附件上传条件的朋友可以尝试将上面提及的参数在php.ini进行设置,以适应大文件上传的需要。同时别忘记在论坛的后台相应做附件限制的地方进行设置。
论坛主要有2个地方可以对附件上传的大小进行限制,级别从高到低依次为:
帖子相关—附件类型尺寸
用户组—附件相关
同时,下面提供一个配置指导,来源一些成功通过http上传大附件的朋友的提供,当然,由于大家的服务器配置情况以及网络情况不同,并不一定适用你的情况,可能很多地方需要参照修改:
打开php.ini,
参数 设置 说明
file_uploads on 是否允许通过HTTP上传文件的开关。默认为ON即是开
upload_tmp_dir – 文件上传至服务器上存储临时文件的地方,如果没指定就会用系统默认的临时文件夹
upload_max_filesize 8m 望文生意,即允许上传文件大小的最大值。默认为2M
post_max_size 8m 指通过表单POST给PHP的所能接收的最大值,包括表单里的所有值。默认为8M
说明
一般地,设置好上述四个参数后,在网络正常的情况下,上传<=8M的文件是不成问题
但如果要上传>8M的大体积文件,只设置上述四项还一定能行的通。除非你的网络真有100M/S的上传高速,否则你还得继续设置下面的参数。
max_execution_time 600 每个PHP页面运行的最大时间值(秒),默认30秒
max_input_time 600 每个PHP页面接收数据所需的最大时间,默认60秒
memory_limit 8m 每个PHP页面所吃掉的最大内存,默认8M
把上述参数修改后,在网络所允许的正常情况下,就可以上传大体积文件了
[编辑]论坛文件上传常见错误类型(不断总结中…)
Warning: Unable to open ‘\\php2′ for reading: Invalid argument in e:\user\web\larksoft.net\upload\upfile.php on line 10
是php的upload_tmp_dir的原因,所指定的目录必须可读可写
Parse error: parse error in c:\program files\apache group\apache\htdocs\mdweb\ftpfile\upload.php on line 14
Parse error一般都是语句的问题,比如象“;”,“’”,“)”等等的匹配问题
网页中内容部分图片大小经常需要进行限制,动易下采用的是Javascript方法。但随着IE对CSS支持的完善,使用CSS也可以很方便的实现限制。但是IE与FireFox使用的CSS代码完全不同,具体代码如下:
img
{
max-width: 200px;
width: expression( ( this.width > 300) ? 300 : this.width );
}
第一行是FireFox版的,第二行是IE版的。
在具体的使用中还应该注意要把这些CSS使用限制在某个容器中,否则网页中所有的图片都会被如上设置。