Home > Backend Development > PHP Tutorial > PHP's date processing function and uchome's function_Research on the date processing function in coomon_PHP tutorial

PHP's date processing function and uchome's function_Research on the date processing function in coomon_PHP tutorial

WBOY
Release: 2016-07-21 15:32:06
Original
1012 people have browsed it

Copy code The code is as follows:

echo mktime(11,25,0, 9,5,2010);//Same as time
echo microtime();
echo mktime(0,0,0,1,1,1970);
?>

The outputs here are 1283657290, 1283657100, 0.88533200 1283657290, and -25200. Judging from the last value, we know that the timestamp returned here has been adjusted by the time zone, which is 0 o'clock on January 1, 1970 when I was in China. Greenwich has not yet reached 0 o'clock, so the time here will be a negative number. And the whole value is equal to -8*3600.

Look again
Copy the code The code is as follows:

echo date ( "H i l d F" ,1283657100);
echo gmdate("H i l d F",1283657100);
echo strftime("%Hh%M %A %d %b" ,1283657100);
/ /strftime() works no differently than date(), except that special formatting characters must be preceded by a percent sign %.
echo strtotime("2010-9-5 11:25:00");
var_dump(getdate (time()));
?>

Here The output is 11 25 Sunday 05 September, 03 25 Sunday 05 September, 11h25 Sunday 05 Sep, 1283657100, array(11) {
["seconds"]=>
int(9)
["minutes "]=>
int(39)
["hours"]=>
int(11)
["mday"]=>
int(5)
["wday"]=>
int(0)
["mon"]=>
int(9)
["year"]=>
int( 2010)
["yday"]=>
int(247)
["weekday"]=>
string(6) "Sunday"
["month"]= >
string(9) "September"
[0]=>
int(1283657949)
}

Mainly look at the third output, the output here is What is the time in Greenwich at 11:25 on September 5, 2010 in China? The time difference must also be taken into account here. And another strange thing here is that only gmdate does not issue a warning, and the rest have warnings that they cannot rely on the system's time zone. Just imagine, because gmdate only calculates Greenwich time. Even if the system time zone is wrong, one plus and one subtraction will make it normal again.
Copy code The code is as follows:

//Time formatting
function sgmdate($dateformat, $timestamp=' ', $format=0) {
global $_SCONFIG, $_SGLOBAL;
if(empty($timestamp)) {
$timestamp = $_SGLOBAL['timestamp'];
}
$timeoffset = strlen($_SGLOBAL['member']['timeoffset'])>0?intval($_SGLOBAL['member']['timeoffset']):intval($_SCONFIG['timeoffset']);
$result = '';
if($format) {
$time = $_SGLOBAL['timestamp'] - $timestamp;
if($time > 24*3600) {
$result = gmdate($dateformat, $timestamp + $timeoffset * 3600);
} elseif ($time > 3600) {
$result = intval($time/3600).lang('hour ').lang('before');
} elseif ($time > 60) {
$result = intval($time/60).lang('minute').lang('before') ;
} elseif ($time > 0) {
$result = $time.lang('second').lang('before');
} else {
$result = lang ('now');
}
} else {
$result = gmdate($dateformat, $timestamp + $timeoffset * 3600);
}
return $result;
}

Let’s look directly at the things in if($format){}. First, we can find the current time of the system and the time I passed in (usually the time in the database, such as 2010-9-4 21:00:00). If the time difference is within one day, the conclusion is drawn directly, such as two hours ago. If it is greater than 1 day, gmdate is called. I just don't understand it here. Why call this weird function instead of date($timestamp) directly? What the hell does this mean?
gmdate

When run in Finland (GMT +0200), the first line below prints "Jan 01 1998 00:00:00", while the second prints "Dec 31 1997 22:00:00" .
Copy code The code is as follows:

echo date("M d Y H:i: s", mktime(0, 0, 0, 1, 1, 1998));
echo gmdate("M d Y H:i:s", mktime(0, 0, 0, 1, 1, 1998)) ;
?>

That is to say, gmdate takes the time difference into consideration. The standard time format will be output here, not days ago.
Next, focus on the functions in function_common of uhome
Copy the code The code is as follows:

//String time
function sstrtotime($string) {
global $_SGLOBAL, $_SCONFIG;
$time = '';
if($string) {
$time = strtotime($string) ;
if(gmdate('H:i', $_SGLOBAL['timestamp'] + $_SCONFIG['timeoffset'] * 3600) != date('H:i', $_SGLOBAL['timestamp']) ) {
$time = $time - $_SCONFIG['timeoffset'] * 3600;
}
}
return $time;
}

Although there are few functions in this function, it is very difficult for me to see. This is to convert a time string into a timestamp. For example, what I input here is 2010 9 4 21:08, then the value of $time is the time difference from this time to January 1 1970 00:00:00 GMT. Here is the time difference to be considered. The value of $_SGLOBAL[''timestamp] is actually calculated in the same way as $time, but the values ​​may be slightly different. $_SCONFIG['timeoffset'] is in the config table, and its current value is 8. There is a situation where the system time zone is correct or incorrect, which needs to be checked through $_SCONFIG['timeoffset']. gmdate passes the incoming timestamp (the timestamp of the place where the program is run) through the system time zone to get the time in Greenwich at that time. If the system time zone is set correctly, then this is exactly one plus and one minus, which is equal to the latter (in fact, the value of $_SGLOBAL[''timestamp] here is irrelevant). If it is normal, then there is no need to change $time. If it is abnormal, then it needs to be reduced. But again, what the hell does this mean?

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/322864.htmlTechArticleCopy the code as follows: ?php echo time(); echo mktime(11,25,0,9,5 ,2010);//The same as time echo microtime(); echo mktime(0,0,0,1,1,1970); ? The output here is 1283657290,...
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template