文件类型
    在程序运行时,程序本身和数据一般都存在内存中,当程序运行结束后,存放在内存中的数据被释放。
    如果需要长期保存程序运行所需的原始数据,或程序运行产生的结果,就必须以文件形式存储到外部存储介质上。
    文件一般指存储在外部介质上具有名字(文件名)的一组相关数据集合。用文件可长期保存数据,并实现数据共享。
    PHP是以UNIX的文件系统为模型的。因此在Windows系统中我们只能获得”file”、”dir”或者“unknown”三种文件类型。
    而在UNIX系统中,我们可以获得block、char、dir、fifo、file、link和unknown七种类型。 可以使用函数filetype()获取文件的具体类型。

    UNIX系统中7种文件类型说明
    image.png

    is_dir( ) — 判断给定文件名是否是一个目录
    语法结构:bool is_dir(名称)
    返回类型:文件名存在并且是一个目录则返回 true,否则返回 false
    is_executable( ) — 判断给定文件名是否可执行
    语法结构:bool is_executable(名称)
    返回类型:如果文件存在且可执行则返回 true ,否则返回 false 。
    is_file( ) — 判断给定文件名是否为一个正常的文件
    语法结构:bool is_file(名称)
    返回类型:如果文件存在且为正常的文件则返回 true 。
    is_link( ) — 判断给定文件名是否为一个符号连接
    语法结构:bool is_link(名称)
    返回类型:如果文件存在并且是一个符号连接则返回 true。
    is_readable( ) — 判断给定文件名是否可读
    语法结构:bool is_readable(文件名称)
    返回类型:如果文件存在并且可读则返回 true 。
    is_writable( ) — 判断给定的文件名是否可写
    语法结构:bool is_writable(文件名称) 返回类型:如果文件存在并且可写则返回 true

    文件的属性
    image.png

    解析目录路径
    使用PHP脚本可以方便对目录进行操作,如创建目录、遍历目录、复值目录与删除目录等操作。
    常用的文件目录路径格式:
    $unixPath=”/var/www/html/index.php”; //在UNIX系统中的绝对路径,必须使用”/“分隔 $winPath=”C:\Appserv\www\index.php”; //在Windows系统的绝对路径,默认使用”\”分隔 $winPath2=”C:/Appserv/www/index.php”; //在Windows系统中也可使用“/”分隔。 注意使用绝对路径与相对路径。
    PHP文件路径相关函数
    basename — 返回路径中的文件名部分
    语法:string basename ( string path [, string suffix] ) 给出一个包含有指向一个文件的全路径的字符串,本函数返回基本的文件名。如果文件名是以 suffix 结束的,那这一部分也会被去掉。
    dirname — 返回路径中的目录部分
    语法:string dirname ( string path ) 给出一个包含有指向一个文件的全路径的字符串,本函数返回去掉文件名后的目录名。

    $path = “/home/httpd/html/index.php”;
    $file = basename($path); // $file值:”index.php”
    $file = basename($path, “.php”); // $file值:”index “
    $file = dirname($path); // $file值:”/home/httpd/html”
    image.png
    image.png

    pathinfo — 返回文件路径的信息 语法:array pathinfo ( string path [, int options] ) pathinfo() 返回一个联合数组包含有 path 的信息。包括以下的数组单元:dirname,basename 和 extension
    realpath — 返回规范化的绝对路径名 语法:string realpath ( string path ) realpath() 扩展所有的符号连接并且处理输入的 path 中的 ‘/./‘, ‘/../‘ 以及多余的 ‘/‘ 并返回规范化后的绝对路径名。返回的路径中没有符号连接,’/./‘ 或 ‘/../‘ 成分

    image.png
    image.png

    遍历目录
    opendir — 打开目录句柄
    语法:resource opendir ( string path [, resource context] ) 打开一个目录句柄,可用于之后的 closedir(),readdir() 和 rewinddir() 调用中。
    readdir — 从目录句柄中读取条目
    语法:string readdir ( resource dir_handle ) 返回当前目录指针位置的文件名,没有返回false,并将指针向下移动一位。文件名以在文件系统中的排序返回。 、
    closedir — 关闭目录句柄
    语法:void closedir ( resource dir_handle ) 关闭由 dir_handle 指定的目录流。流必须之前被 opendir() 所打开。
    rewinddir — 倒回目录句柄
    语法:void rewinddir ( resource dir_handle ) 将 dir_handle 指定的目录流重置到目录的开头
    统计目录大小
    opendir — 打开目录句柄
    语法:resource opendir ( string path [, resource context] )
    打开一个目录句柄,可用于之后的 closedir(),readdir() 和 rewinddir() 调用中。
    readdir — 从目录句柄中读取条目
    语法:string readdir ( resource dir_handle )
    返回当前目录指针位置的文件名,没有返回false,并将指针向下移动一位。文件名以在文件系统中的排序返回。
    closedir — 关闭目录句柄
    语法:void closedir ( resource dir_handle )
    关闭由 dir_handle 指定的目录流。流必须之前被 opendir() 所打开。
    rewinddir — 倒回目录句柄
    语法:void rewinddir ( resource dir_handle ) 将 dir_handle 指定的目录流重置到目录的开头。

    建立与删除目录
    mkdir — 新建目录
    语法:bool mkdir (string pathname [,int mode]) 尝试新建一个由 pathname 指定的目录。
    rmdir — 删除目录
    语法:bool rmdir ( string dirname ) 尝试删除 dirname 所指定的目录。 该目录必须是空的,而且要有相应的权限。如果成功则返回 TRUE,失败则返回 FALSE。
    unlink — 删除文件
    语法:bool unlink ( string filename ) 删除 filename。和 Unix C 的 unlink() 函数相似。如果成功则返回 TRUE,失败则返回 FALSE。

    文件的打开与关闭
    fopen — 打开文件或者 URL
    语法:resource fopen ( string filename, string mode [, bool use_include_path [, resource zcontext]] ) filename参数需要提供要被打开文件的URL。这个URL可以是脚本所在的服务器中的绝对路径,也可以是相对路径,还可以是网络资源用的文件。
    mode 参数指定了所要求到该流的访问类型,(强烈建议附加b模式)。
    如果也需要在 include_path中搜寻文件的话,可以将可选的第三个参数 use_include_path 设为 ‘1’ 或 TRUE。 如果打开失败,本函数返回 FALSE。
    fclose — 关闭一个已打开的文件指针
    语法:bool fclose ( resource $handle )
    将 handle 指向的文件关闭。 成功时返回 TRUE, 或者在失败时返回 FALSE.
    //使用绝对路径打开file.txt文件,选择只读模式,并返回资源$handle
    $handle = fopen(“/home/rasmus/file.txt”, “r”);
    //访问文档根目录下的文件,也以只读模式打开
    $handle = fopen(“{$_SERVER[‘DOCUMENT_ROOT’]}/data/info.txt”, “r”);
    //在 Windows 平台上,转义文件路径中的每个反斜线,或者用斜线,以二进制和只写模式组合 $handle = fopen(“c:\data\file.gif”, “wb”); //使用相对路径打开file.txt文件,选择只读模式,并返回资源$handle

    $handle = fopen(“../data/info.txt”, “r”);
    //打开远程文件, 使用HTTP协议只能以只读的模式打开 $handle = fopen(“http://www.example.com/“, “r”);
    //使用FTP协议打开远程文件,如果FTP服务器可写,则可以以写的模式打开
    $handle = fopen(“ftp://user:password@example.com/somefile.txt”, “w”);

    image.png

    写入文件
    write — 写入文件(可安全用于二进制文件)
    语法:int fwrite ( resource handle, string string [, int length] )
    fwrite() 把 string 的内容写入 文件指针 handle 处。 如果指定了 length,当写入了 length 个字节或者写完了 string 以后,写入就会停止,视乎先碰到哪种情况。 返回写入的字符数,出现错误时则返回 FALSE 。

    读取文件内容
    image.png

    客户端上传设置
    在B/S程序中文件上传已经成为一个常用功能。
    其目的是客户可以通过浏览器(Browser)将文件上传到服务器(Server)上的指定目录。
    PHP中文件上传的基础知识:
    客户端form表单
    服务器端对上传文件的操作

    客户端文件上传的form表单
    image.png

    注意几个特征属性:
    POST方法: 表单最常用的功能,向目标页面传递变量,我们在上传文件的时候,会在表单中设置相应的属性,来完成文件的传递 enctype=”multipart/form-data” 这样服务器就会知道,我们要传递一个文件,这样服务器可以知道上载的文件带有常规的表单信息。 MAX_FILE_SIZE 此字段必须在文件输入字段之前,控制最大的传递文件的大小(字节) 设置浏览器文件输入浏览按钮

    在服务器端通过PHP处理上传
    上传文件的接收和处理是通过PHP脚本来处理的,具体需要通过以下三个方面信息:
    设置PHP配置文件中的指令:用于精细地调节PHP的文件上传功能。
    $_FILES多维数组:用于存储各种与上传文件有关的信息,其他数据还是使用$_POST获取。
    PHP的文件上传处理函数:用于上传文件的后续处理。

    PHP配置文件中与文件上传有关的选项
    image.png

    $_FILES多维数组
    超级全局数组$_FILES
    1、$_FILES[“myfile”][“name”]中的值是: 客户端文件系统的文件的名称
    2、$_FILES[“myfile”][“type”]中的值是: 客户端传递的文件的类型
    3、$_FILES[“myfile”][“size”]中的值是: 文件的字节的大小
    4、$_FILES[“myfile”][“tmp_name”]中的值是: 文件被上传后在服务器存储的临时全路径 5、$_FILES[“myfile”][“error”]中的值是: 文件上传的错误代码-php 4.2以后增加的功能

    常见数据格式(MIME)

    image.png

    PHP的文件上传处理函数

    上传成功的文件会被放置到服务器端临时目录下,文件名是随机生成的临时文件名。 注:该文件在程序执行完后将自动被删除掉。在删除前可以像本地文件一样操作。
    文件上传处理函数:
    is_uploaded_file —判断文件是否是通过 HTTP POST 上传的
    格式:bool is_uploaded_file ( string $filename )
    move_uploaded_file — 将上传的文件移动到新位置
    格式:bool move_uploaded_file ( string $filename , string $destination )
    注意:如果目标文件已经存在,将会被覆盖。

    数据库的应用

    数据库是计算机应用系统中的一种专门管理数据资源的系统。数据库就是一组经过计算机整理后的数据,存储在一个或者多个文件中,而管理这个数据库的软件就称为数据库管理系统

    image.png
    数据库的应用
    主流的软件开发中应用数据库有IBM的DB2,Oracle,Informix,Sybase,SQL Server,PostgreSQL,MySQL,Access,FoxPro和Teradata等。

    image.png

    结构化查询语言SQL
    对数据库服务器中数据的管理,必须使用客户机程序成功连接以后,再通过必要的操作指令对其进行操作,这种数据库操作指令被称为SQL(Structured Query Language)语言,即结构化查询语言。
    MySQL支持SQL作为自己的数据库语言,SQL是一种专门用于查询和修改数据库里的数据,以及对数据库进行管理和维护的标准化语言。
    SQL语言结构简洁,功能强大,简单易学,所以自从IBM公司1981年退出以来,SQL语言得到了广泛的应用。
    无论是Oracle,Sybase,Informix,SQL Server这些大型的数据库管理系统,还是像Visual Foxpro,PowerBuilder这些PC上常用的数据库开发系统,都支持SQL语言作为查询语言

    结构化查询语言SQL
    SQL语言包含四个部分:
    数据定义语言(DDL):用于定义和管理数据对象,包括数据库,数据表等。例如:CREATE,DROP,ALTER等。
    数据操作语言(DML):用于操作数据库对象中所包含的数据。例如:INSERT,UPDATE,DELETE语句。
    数据查询语言(DQL):用于查询数据库对象中所包含的数据,能够进行单表查询,连接查询,嵌套查询,以及集合查询等各种复杂程度不同的数据库查询,并将数据返回客户机中显示。例如:SELETE 数据控制。
    语言(DCL):是用来管理数据库的语言,包括管理权限及数据更改。例如:GRANT,REVOKE,COMMIT,ROLLBACK等。

    在PHP脚本中操作MySQL数据库

    在PHP脚本中操作MySQL数据库的的八个步骤如下:
    1.连接MySQL数据库服务器并选择数据库
    2.判断是否连接正确
    3.设置字符集
    4.准备SQL语句
    5.发送SQL语句到MySQL服务器
    6.处理结果集
    7.释放结果集资源
    8.关闭数据库连接

    连接MySQL数据库服务器
    通过PHP脚本程序去管理MySQL服务器中的数据,也必须先建立连接,然后才能通过PHP中的函数向服务器中发送SQL查询语句。PHP可以通过mysqli扩展功能模块去连接MySQL服务器,办法是调用mysqli_connect()函数,和使用MySQL客户机程序连接MySQL服务器类似。 resource mysqli_connect ( [string host [, string username [, string password [, string dbname [, int port [,string socket]]]]] )

    获取错误和信息
    返回最近函数调用的错误代码 int mysqli_errno ( mysqli $link )
    返回最近函数调用的错误信息 string mysqli_error ( mysqli $link )

    选择数据库
    通常数据库的创建工作都是先由数据库管理员(DBA)建立,再由PHP程序员在脚本中使用。在使用PHP脚本建立起与MySQL服务器的连接之后,我们可以使用mysqli_select_db()函数选择一个数据库,这个函数和SQL命令“USE bookstore”功能相似。
    bool mysqli_select_db ( mysqli $link,string $dbname )

    设置字符集
    为了避免读取和写入数据时发生数据乱码,除了要将文件格式设置为utf-8无bom头格式,还要将数据库客户端字读集设置为utf8,所以我们需要在发送sql语句之前,使用mysqli_set_charset()函数来完成数据库字符集的设定!
    bool mysqli_set_charset (mysqli $link , string $charset )

    准备sql语句
    设置字符集完毕之后,我们需要为读取或写入数据设计SQL语句字符串, 例如: $sql = “select username,password from bbs_user”;

    发送SQL语句
    设计好SQL语句之后,我们使用函数mysqli_query()函数,将SQL语句发送到MySQL数据库服务器,由MySQL数据库服务器来执行此SQL语句,这里注意,我们之所以将SQL语句赋值给一个变量是为了出现错误的时候便于排错,我们可以直接输出$sql这个变量。
    int/resource mysqli_query ( mysqli $link,string $query )

    处理结果
    将SQL语句发送到MySQL服务器之后,MySQL服务器会将执行SQL语句之后的结果返回给PHP端,这里的结果分为两种: 1.布尔型 2.结果集资源类型 当我们执行的SQL语句是DML语句,也就是增,删,改三种语句,这时mysqli_query()返回的类型是布尔类型,执行成功返回真,失败返回假,但有时SQL语句执行成功,但不一定有受影响行数,所以我们可以使用mysqli_affected_rows()函数返回

    受影响行数;当我们执行的是DQL语句,也就是查询语句,mysqli_query()函数将返回的是结果集资源类型,我们可以使用mysqli_num_rows($result)函数来获取结果集当中的记录条数,但是我们无法将结果集资源当中的数据得到,因此PHP为我们提供了4个函数,来解析此结果集资源:
    1.mysqli_fetch_array() 返回索引和关联的混合数组
    2.mysqli_fetch_assoc() 返回关联数组
    3.mysqli_fetch_row() 返回索引数组
    4.mysqli_fetch_object() 返回一个对象