• 中文
    • English
  • 注册
  • 查看作者
  • 4:PHP高级教程

    一.  日期

    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() :用于打开文件,该函数第一个参数包含被打开的文件名,第二个参数规定打开文件的模式,常见的打开模式如下:

    4:PHP高级教程

    • 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内容如下(删除之前的):

    4:PHP高级教程

    七.  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

  • 0
  • 0
  • 0
  • 2.1k
  • zjmarina

    请登录之后再进行评论

    登录
    单栏布局 侧栏位置: