一. 日期
PHP Date() 函数把时间戳格式化为更易读的日期和时间。其中format是必需的,用来规定时间戳的格式。timestamp是可选的,规定时间戳,默认是当前时间和日期。
d - 表示月里的某天(01-31) m - 表示月(01-12) Y - 表示年(四位数) 1 - 表示周里的某天 h - 带有首位零的 12 小时小时格式 i - 带有首位零的分钟 s - 带有首位零的秒(00 -59) a - 小写的午前和午后(am 或 pm) <?php date_default_timezone_set("Asia/Shanghai"); # 设置时区 echo date("y/m/d h:i:s:a"); #19/09/18 11:19:02:am $d=mktime(9, 12, 31, 6, 10, 2015); echo "创建日期是 " . date("Y-m-d h:i:sa", $d); $d=strtotime("10:38pm April 15 2015"); echo "创建日期是 " . date("Y-m-d h:i:sa", $d); $d=strtotime("tomorrow"); echo date("Y-m-d h:i:sa", $d) . "<br>"; $d=strtotime("next Saturday"); echo date("Y-m-d h:i:sa", $d) . "<br>"; $d=strtotime("+3 Months"); echo date("Y-m-d h:i:sa", $d) . "<br>"; $d1=strtotime("December 31"); $d2=ceil(($d1-time())/60/60/24); echo "距离十二月三十一日还有:" . $d2 ." 天。"; ?>
其中,time() 函数返回自 Unix 纪元(January 1 1970 00:00:00 GMT)起的当前时间的秒数。
二. include文件
通过 include 或 require 语句,可以将 PHP 文件的内容插入另一个 PHP 文件(在服务器执行它之前)。
include 和 require 语句是相同的,除了错误处理方面:
-
require 会生成致命错误(E_COMPILE_ERROR)并停止脚本(下方的内容都不会输出),一般当文件被应用程序请求时使用。
-
include 只生成警告(E_WARNING),并且脚本会继续(下方的内容会输出),一般当文件不是必需的,且应用程序在文件未找到时应该继续运行时使用。
比如我们一个站点有几十个页面,每个页面都有相同的顶部菜单menu.php
<?php echo '<a href="/index.asp">首页</a> - <a href="/html/index.asp">HTML 教程</a> - <a href="/css/index.asp">CSS 教程</a> - <a href="/js/index.asp">JavaScript 教程</a> - <a href="/php/index.asp">PHP 教程</a>'; ?>
在需要使用顶部菜单的页面,将menu.php导入即可:
<!DOCTYPE html> <html> <body> <div class="menu"> <?php include 'demo1.php';?> </div> <div> 导入的页面名为 <?php echo $name; ?> </div> </body> </html>
require 使用方法相同,将include修改为require即可。
三. 文件打开/读取
文件打开/读取常用函数:
-
readfile():用于读取文件,并把它写入输出缓冲。
-
fopen() :用于打开文件,该函数第一个参数包含被打开的文件名,第二个参数规定打开文件的模式,常见的打开模式如下:
-
fread(): 用于读取打开的文件,该函数第一个参数包含待读取文件的文件名,第二个参数规定待读取的最大字节数,如果第二个参数不写,则直接读取全部
-
fclose(): 用于关闭打开的文件。
-
fgets() : 用于从文件读取单行,调用 fgets() 函数之后,文件指针会移动到下一行。
-
feof() : 用于检查是否已到达 “end-of-file” (EOF)。
-
fgetc() : 用于从文件中读取单个字符。
<?php $myfile = fopen("webdictionary.txt", "r") or die("Unable to open file!"); // 输出单字符直到 end-of-file while(!feof($myfile)) { echo fgetc($myfile); } fclose($myfile); ?>
其中die()函数可以输出一条消息,并退出当前脚本,因为在php中的or和and也有短路功能,所以如果fopen打开成功,则不会输出Unable to open file
四. 文件创建/写入
文件创建/写入常用函数:
-
fopen():该函数也用于创建文件,如果您用 fopen() 打开并不存在的文件,此函数会创建该文件。
-
fwrite():该函数用于写入文件,第一个参数包含要写入的文件的文件名,第二个参数是被写的字符串。
<?php $myfile = fopen("newfile.txt", "w") or die("Unable to open file!"); $txt = "Bill Gates\n"; fwrite($myfile, $txt); $txt = "Steve Jobs\n"; fwrite($myfile, $txt); fclose($myfile); ?>
五. 文件上传
通过使用 PHP 的全局数组 $_FILES,可以从客户计算机向远程服务器上传文件。
第一个参数是表单的 input name,第二个下标可以是 “name”, “type”, “size”, “tmp_name” 或 “error”。就像这样:
-
$_FILES[“file”][“name”] – 被上传文件的名称
-
$_FILES[“file”][“type”] – 被上传文件的类型
-
$_FILES[“file”][“size”] – 被上传文件的大小,以字节为单位
-
$_FILES[“file”][“tmp_name”] – 存储在服务器的文件的临时副本的名称
-
$_FILES[“file”][“error”] – 由文件上传导致的错误代码
我们可以创建一个用于上传文件的脚本:upload_file.php
<?php # 只能上传 .gif 或 .jpeg 文件,文件大小必须小于 20 kb: if ((($_FILES["file"]["type"] == "image/gif") || ($_FILES["file"]["type"] == "image/jpeg") || ($_FILES["file"]["type"] == "image/pjpeg")) && ($_FILES["file"]["size"] < 2000000)) { if ($_FILES["file"]["error"] > 0) { echo "Return Code: " . $_FILES["file"]["error"] . "<br />"; } else { echo "Upload: " . $_FILES["file"]["name"] . "<br />"; # 文件名 echo "Type: " . $_FILES["file"]["type"] . "<br />"; # 文件类型:image/gif echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />"; # 文件大小 echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br />"; if (file_exists("static/" . $_FILES["file"]["name"])) { echo $_FILES["file"]["name"] . " already exists. "; } else { move_uploaded_file($_FILES["file"]["tmp_name"], "static/" . $_FILES["file"]["name"]); echo "Stored in: " . "static/" . $_FILES["file"]["name"]; } } } else { echo "Invalid file"; } ?>
其中move_uploaded_file(file,newloc)函数用于移动文件,file规定要移动的文件,newloc规定文件的新位置。file_exists() 函数检查文件或目录是否存在。
最后在upload.php中选择文件上传即可:
<html> <body> <form action="result1.php" method="post" enctype="multipart/form-data"> <label for="file">Filename:<br /><br /></label> <input type="file" name="file" id="file" /> <br /> <br /> <input type="submit" name="submit" value="Submit" /> </form> </body> </html>
六. Cookies
cookie 是服务器留在用户计算机中的小文件。每当相同的计算机通过浏览器请求页面时,它同时会发送 cookie。通过 PHP,您能够创建并取回 cookie 的值。cookie 常用于识别用户。
-
setcookie():用于设置 cookie。
-
$_COOKIE[“xxx”]:获取指定cookie的值
-
isset():用来确认是否已设置了 cookie
创建一个名为name,value为zhangjia的cookie,并设置过期时间,最后删除setcookie:
<?php setcookie("name", "zhangjia", time()+3600); if(isset($_COOKIE["name"])) { echo "cookie = ".$_COOKIE["name"]; } else { echo "没设置cookie"; } setcookie("name","",time()-3600); ?>
打开浏览器,查看cookie内容如下(删除之前的):
七. Sessions
session 变量用于存储有关用户会话的信息,或更改用户会话的设置。Session 变量保存的信息是单一用户的,并且可供应用程序中的所有页面使用。
session 的工作机制是:为每个访问者创建一个唯一的 id (UID),并基于这个 UID 来存储变量。UID 存储在 cookie 中,亦或通过 URL 进行传导。
在您把用户信息存储到 PHP session 中之前,首先必须通过session_start();启动会话
<?php session_start(); ?>
上面的代码会向服务器注册用户的会话,以便您可以开始保存用户信息,同时会为用户会话分配一个 UID。接下来便可以使用 $_SESSION 变量存储Session信息,
<?php session_start(); $_SESSION['account'] = "zhangjia"; if (isset($_SESSION['views'])) #isset() 函数检测是否已设置 "views" 变量 $_SESSION['views'] = $_SESSION['views'] + 1; else $_SESSION['views'] = 1; echo "Views=" . $_SESSION['views']; # 刷新一次页面+1 ?> <div> 用户名:<?php echo $_SESSION['account'] ?> </div> ?>
删除Session有以下两种方法:
<?php unset($_SESSION['views']); # session_destroy(); 方法二
八. 发送电子邮件
mail() 函数用于从脚本中发送电子邮件。
<?php $to = "zhangjia@188.com"; # 发送给谁 $subject = "邮件验证码"; # 邮件主题 $message = "您好,您的邮件验证码是1234"; # 邮件内容 $from = "122922297@qq.com"; $headers = "From: $from"; # 规定附加的标题 mail($to,$subject,$message,$headers); echo "Mail Sent."; ?>
为防止Email注入,需要使用 过滤器来对输入进行验证:
-
FILTER_SANITIZE_EMAIL 从字符串中删除电子邮件的非法字符
-
FILTER_VALIDATE_EMAIL 验证电子邮件地址
<html> <body> <?php function spamcheck($field) { //filter_var() sanitizes the e-mail //address using FILTER_SANITIZE_EMAIL $field=filter_var($field, FILTER_SANITIZE_EMAIL); //filter_var() validates the e-mail //address using FILTER_VALIDATE_EMAIL if(filter_var($field, FILTER_VALIDATE_EMAIL)) { return TRUE; } else { return FALSE; } } if (isset($_REQUEST['email'])) {//if "email" is filled out, proceed //check if the email address is invalid $mailcheck = spamcheck($_REQUEST['email']); if ($mailcheck==FALSE) { echo "Invalid input"; } else {//send email $email = $_REQUEST['email'] ; $subject = $_REQUEST['subject'] ; $message = $_REQUEST['message'] ; mail("someone@example.com", "Subject: $subject", $message, "From: $email" ); echo "Thank you for using our mail form"; } } else {//if "email" is not filled out, display the form echo "<form method='post' action='mailform.php'> Email: <input name='email' type='text' /><br /> Subject: <input name='subject' type='text' /><br /> Message:<br /> <textarea name='message' rows='15' cols='40'> </textarea><br /> <input type='submit' /> </form>"; } ?> </body> </html>
九. 错误处理
错误处理的常用函数:
-
die() 函数处理基本的错误
-
error_function(error_level,error_message,error_file,error_line,error_context)可以自定义一个函数用于错误处理器
-
set_error_handler()用于处理在脚本运行期间的默认错误,可以有第二个参数为错误等级
-
trigger_error() 用于处理触发错误
-
error_log() 函数向指定的文件或远程目的地发送错误记录。
举例:在本例中,如果 “test” 变量大于 “1”,则发生 E_USER_WARNING 错误。如果发生了 E_USER_WARNING,我们将使用我们的自定义错误处理程序并结束脚本:
<?php //error handler function function customError($errno, $errstr) { echo "<b>Error:</b> [$errno] $errstr<br />"; echo "Ending Script"; die(); } //set error handler set_error_handler("customError",E_USER_WARNING); //trigger error $test=2; if ($test>1) { trigger_error("Value must be 1 or below",E_USER_WARNING); } ?>
十. 异常处理
异常(Exception)用于在指定的错误发生时改变脚本的正常流程,举例:
<html> <?php //创建可抛出一个异常的函数 function checkNum($number) { if ($number > 1) { throw new Exception("Value must be 1 or below"); # 如果¥number大于1,则抛出该异常,否则返回true } return true; } //在 "try" 代码块中触发异常 try { checkNum(2); # 因为该函数可能触发异常,所以用try包裹 echo 'If you see this, the number is 1 or below'; } //捕获异常 catch (Exception $e) { echo 'Message: ' . $e->getMessage(); # exception 对象调用 $e->getMessage(),输出来自该异常的错误消息 #catch可以写多个处理多个异常,并且可以在catch 代码块中再次抛出(re-thrown)异常。 } ?>
set_exception_handler() 函数可设置处理所有未捕获异常的用户自定义函数。
<?php function myException($exception) { echo "<b>Exception:</b> " , $exception->getMessage(); } set_exception_handler('myException'); throw new Exception('Uncaught Exception occurred'); ?>
十一. 过滤器(Filter)
PHP 过滤器用于验证和过滤来自非安全来源的数据。
-
ilter_var() – 通过一个指定的过滤器来过滤单一的变量
-
filter_var_array() – 通过相同的或不同的过滤器来过滤多个变量
-
filter_input – 获取一个输入变量,并对它进行过滤
-
filter_input_array – 获取多个输入变量,并通过相同的或不同的过滤器对它们进行过滤
通过使用 FILTER_CALLBACK 过滤器,可以调用自定义的函数,把它作为一个过滤器来使用
参考资料
以上所有内容均整理自W3school
请登录之后再进行评论