• 中文
    • 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
    • 1.8k
    • zjmarina

      请登录之后再进行评论

      登录

      赞助本站

      • 支付宝
      • 微信
      • QQ

      感谢一直支持本站的所有人!

      单栏布局 侧栏位置: