백엔드 개발 PHP 튜토리얼 初识PHP(二)常用函数

初识PHP(二)常用函数

Jun 23, 2016 pm 01:11 PM

在此记录一些常用库函数和常用语法以便查阅

一、PHP手册

   php手册中文地址 http://php.net/manual/zh

二、一些常用操作

  2.1字符串操作

  2.1.1 strpos — 查找字符串首次出现的位置

  mixed strpos ( string $haystack , mixed $needle [, int $offset = 0 ] )

  返回 needle 在 haystack 中首次出现的数字位置。

  haystack

  在该字符串中进行查找。

  needle

  如果 needle 不是一个字符串,那么它将被转换为整型并被视为字符的顺序值。

  offset

  如果提供了此参数,搜索会从字符串该字符数的起始位置开始统计。和 strrpos()、 strripos()不一样,这个偏移量不能是负数。

 

  2.1.2 substr — 返回字符串的子串

   string  substr ( string $string , int $start [, int $length ] )

   返回字符串  string 由 start 和 length 参数指定的子字符串。

   string  

  输入字符串。

   start

   如果  start 是非负数,返回的字符串将从 string 的 start 位置开始,从 0 开始计算。例如,在字符串 “abcdef” 中,在位置 0 的字符是 “a”,位置 2 的字符串是 “c” 等等。

  返回值:

  如果 start 是负数,返回的字符串将从 string 结尾处向前数第 start 个字符开始。

  如果 string 的长度小于或等于 start,将返回 FALSE

 

  2.1.3  str_split — 将字符串转换为数组

  array split ( string $pattern , string $string [, int $limit ] )

  将一个字符串转换为数组。  

  string   输入字符串。   split_length   每一段的长度。

  返回值:

  如果指定了可选的 split_length 参数,返回数组中的每个元素均为一个长度为 split_length 的字符块,否则每个字符块为单个字符。

  如果 split_length 小于 1,返回 FALSE。如果 split_length 参数超过了 string 超过了字符串 string 的长度,整个字符串将作为数组仅有的一个元素返回。

 

  2.1.4  explode — 使用一个字符串分割另一个字符串

  array explode ( string $delimiter , string $string [, int $limit ] )

  此函数返回由字符串组成的数组,每个元素都是 string 的一个子串,它们被字符串 delimiter 作为边界点分割出来。

  delimiter

  边界上的分隔字符。

  string

  输入的字符串。

  limit

  如果设置了 limit 参数并且是正数,则返回的数组包含最多 limit 个元素,而最后那个元素将包含 string的剩余部分。

  如果 limit 参数是负数,则返回除了最后的 -limit 个元素外的所有元素。

  如果 limit 是 0,则会被当做 1。

  

  此函数返回由字符串组成的 array,每个元素都是 string 的一个子串,它们被字符串 delimiter 作为边界点分割出来。

  返回值:如果 delimiter 为空字符串(""),explode() 将返回 FALSE。 如果 delimiter 所包含的值在 string 中找不到,并且使用了负数的 limit , 那么会返回空的 array, 否则返回包含 string 单个元素的数组。

 

  2.1.5  preg_split — 通过一个正则表达式分隔字符串

  array preg_split ( string $pattern , string $subject [, int $limit = -1 [, int $flags = 0 ]] )

  通过一个正则表达式分隔给定字符串.

  pattern

  用于搜索的模式,字符串形式。

  subject

  输入字符串

  limit

  如果指定,将限制分隔得到的子串最多只有limit个,返回的最后一个 子串将包含所有剩余部分。limit值为-1, 0或null时都代表"不限制", 作为php的标准,你可以使用null跳过对flags的设置。

  flags

  flags 可以是任何下面标记的组合(以位或运算 | 组合):

  PREG_SPLIT_NO_EMPTY   如果这个标记被设置,  preg_split() 将进返回分隔后的非空部分。   PREG_SPLIT_DELIM_CAPTURE   如果这个标记设置了,用于分隔的模式中的括号表达式将被捕获并返回。   PREG_SPLIT_OFFSET_CAPTURE   如果这个标记被设置, 对于每一个出现的匹配返回时将会附加字符串偏移量. 注意:这将会改变返回数组中的每一个元素, 使其每个元素成为一个由第 0  个元素为分隔后的子串,第1个元素为该子串在subject中的偏移量组成的数组。   返回值:返回一个使用 pattern 边界分隔 subject 后得到 的子串组成的数组。

  

  2.2 数组操作

  2.2.1  array — 新建一个数组

  array array ([ mixed $... ] )

  创建一个数组。

  语法“index => values”,用逗号分开,定义了索引和值。索引可以是字符串或数字。如果省略了索引,会自动产生从 0 开始的整数索引。如果索引是整数,则下一个产生的索引将是目前最大的整数索引 + 1。注意如果定义了两个完全一样的索引,则后面一个会覆盖前一个。

  返回值:返回根据参数建立的数组。参数可以用 => 运算符给出索引。

 

  2.2.2  array_push — 将一个或多个单元压入数组的末尾(入栈)

  int array_push ( array &$array , mixed $var [, mixed $... ] )

  array_push() 将 array 当成一个栈,并将传入的变量压入 array 的末尾。array 的长度将根据入栈变量的数目增加。  

  array   输入的数组。   var   要压入的值。   返回值:返回处理之后数组的元素个数。

   2.3  索引制定文件/添加头文件

  

  2.3.1 include 语句包含并运行指定文件

  被包含文件先按参数给出的路径寻找,如果没有给出目录(只有文件名)时则按照   include_path 指定的目录寻找。如果在  include_path 下没找到该文件则 include 最后才在调用脚本文件所在的目录和当前工作目录下寻找。如果最后仍未找到文件则 include 结构会发出一条 警告;这一点和  require 不同,后者会发出一个 致命错误。

  如果定义了路径——不管是绝对路径(在 Windows 下以盘符或者 \ 开头,在 Unix/Linux 下以 / 开头)还是当前目录的相对路径(以 . 或者 .. 开头)——include_path 都会被完全忽略。例如一个文件以 ../ 开头,则解析器会在当前目录的父目录下寻找该文件。

  当一个文件被包含时,其中所包含的代码继承了 include 所在行的变量范围。从该处开始,调用文件在该行处可用的任何变量在被调用的文件中也都可用。不过所有在包含文件中定义的函数和类都具有全局作用域。

 

  2.3.2 require 语句包含并运行指定文件

  require 和 include 几乎完全一样,除了处理失败的方式不同之外。require 在出错时产生 E_COMPILE_ERROR 级别的错误。换句话说将导致脚本中止而 include 只产生警告(E_WARNING),脚本会继续运行。

 

 

三、常用库函数

  3.1 时间

  3.1.1  time — 返回当前的 Unix 时间戳

  int time ( void )

  返回自从 Unix 纪元(格林威治时间 1970 年 1 月 1 日 00:00:00)到当前时间的秒数。

 

  3.1.2  date — 格式化一个本地时间/日期

  string date ( string $format [, int $timestamp ] )

  返回将整数 timestamp 按照给定的格式字串而产生的字符串。如果没有给出时间戳则使用本地当前时间。换句话说,timestamp 是可选的,默认值为 time()。

  format 具体格式:http://php.net/manual/zh/function.date.php

 

  3.1.3  date_default_timezone_get — 取得一个脚本中所有日期时间函数所使用的默认时区

  string date_default_timezone_get ( void )

  本函数返回默认时区

 

  3.1.4  date_default_timezone_set — 设定用于一个脚本中所有日期时间函数的默认时区

  bool date_default_timezone_set ( string $timezone_identifier )

  设定用于所有日期时间函数的默认时区。

  timezone_identifier

  时区标识符,例如 UTC 或 Asia/Shanghai(中国大陆选这个)。合法标识符列表见http://php.net/manual/zh/timezones.php

  返回值:如果 timezone_identifier 参数无效则返回 FALSE,否则返回 TRUE

 

 

  3.2 JSON格式操作

 

  3.2.1  json_encode — 对变量进行 JSON 编码

  string json_encode ( mixed $value [, int $options = 0 [, int $depth = 512 ]] )

  返回 value 值的 JSON 形式

  value

  待编码的 value ,除了resource 类型之外,可以为任何数据类型。该函数只能接受 UTF-8 编码的数据

  options

  二进制掩码常量。具体见http://php.net/manual/zh/json.constants.php

  depth

  设置最大深度。 必须大于0。

  返回值:成功则返回 JSON 编码的 string 或者在失败时返回 FALSE 。

   

  3.2.2  json_decode — 对 JSON 格式的字符串进行解码

   mixed  json_decode ( string $json [, bool $assoc = false [, int $depth = 512 [, int $options = 0]]] )

  接受一个 JSON 格式的字符串并且把它转换为 PHP 变量 

  json   待解码的  json  string 格式的字符串。该函数只能接受 UTF-8 编码的数据   assoc   当该参数为   TRUE 时,将返回  array 而非  object 。   depth   设置最大深度。 必须大于0。   options   二进制掩码常量。只支持 JSON_BIGINT_AS_STRING

 

  3.3文件操作

  3.3.1  fopen — 打开文件或者 URL

  resource fopen ( string $filename , string $mode [, bool $use_include_path = false [, resource$context ]] )

  fopen() 将 filename 指定的名字资源绑定到一个流上。

  filename

  如果 filename 是 "scheme://..." 的格式,则被当成一个 URL,PHP 将搜索协议处理器(也被称为封装协议)来处理此模式。如果该协议尚未注册封装协议,PHP 将发出一条消息来帮助检查脚本中潜在的问题并将filename 当成一个普通的文件名继续执行下去。

  如果 PHP 认为 filename 指定的是一个本地文件,将尝试在该文件上打开一个流。该文件必须是 PHP 可以访问的,因此需要确认文件访问权限允许该访问。如果激活了安全模式或者 open_basedir 则会应用进一步的限制。

  mode

  mode 参数指定了所要求到该流的访问类型。可以是以下:

fopen() 中 mode 的可能值列表 mode 说明
'r' 只读方式打开,将文件指针指向文件头。
'r+' 读写方式打开,将文件指针指向文件头。
'w' 写入方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之。
'w+' 读写方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之。
'a' 写入方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建之。
'a+' 读写方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建之。
'x' 创建并以写入方式打开,将文件指针指向文件头。如果文件已存在,则 fopen() 调用失败并返回FALSE,并生成一条 E_WARNING 级别的错误信息。如果文件不存在则尝试创建之。这和给 底层的open(2) 系统调用指定 O_EXCL|O_CREAT 标记是等价的。
'x+' 创建并以读写方式打开,其他的行为和 'x' 一样。

 

  use_include_path

  如果也需要在 include_path 中搜寻文件的话,可以将可选的第三个参数 use_include_path 设为 '1' 或TRUE

  context

  上下文

  返回值:

  成功时返回文件指针资源,如果打开失败,本函数返回 FALSE

  错误提示:如果打开失败,会产生一个 E_WARNING 错误。可以通过 @ 来屏蔽错误。

 

  3.3.2  fgets — 从文件指针中读取一行

  string fgets ( resource $handle [, int $length ] )

  从文件指针中读取一行。

  handle

  文件指针必须是有效的,必须指向由 fopen() 或 fsockopen() 成功打开的文件(并还未由 fclose() 关闭)。

  length

  从 handle 指向的文件中读取一行并返回长度最多为 length - 1 字节的字符串。碰到换行符(包括在返回值中)、EOF 或者已经读取了 length - 1 字节后停止(看先碰到那一种情况)。如果没有指定 length,则默认为 1K,或者说 1024 字节。

  返回值:

  从指针 handle 指向的文件中读取了 length - 1 字节后返回字符串。 如果文件指针中没有更多的数据了则返回FALSE

  错误发生时返回 FALSE

 

  3.3.3  fread — 读取文件(可安全用于二进制文件)

    string  fread ( resource $handle , int $length )

  fread() 从文件指针 handle 读取最多 length 个字节。 该函数在遇上以下几种情况时停止读取文件:

  • 读取了 length 个字节
  • 到达了文件末尾(EOF)
  •   handle

      文件系统指针,是典型地由 fopen() 创建的 resource(资源)。

      length

      最多读取 length 个字节。

      返回值:返回所读取的字符串, 或者在失败时返回 FALSE

      

      3.3.4   fwrite — 写入文件(可安全用于二进制文件)

        int  fwrite ( resource $handle , string $string [, int $length ] )

      fwrite() 把 string 的内容写入 文件指针 handle 处。

      handle

      文件系统指针,是典型地由 fopen() 创建的 resource(资源)。

      string

      将要写入的字符串

      ength

      如果指定了 length,当写入了 length 个字节或者写完了 string 以后,写入就会停止,视乎先碰到哪种情况。

      返回值:fwrite() 返回写入的字符数,出现错误时则返回 FALSE 。

      

      3.3.5  fclose — 关闭一个已打开的文件指针

      bool fclose ( resource $handle )

      将 handle 指向的文件关闭。

      handle

      文件指针必须有效,并且是通过 fopen() 或 fsockopen() 成功打开的。

      返回值:成功时返回 TRUE, 或者在失败时返回 FALSE

      

       3.3.6  file_get_contents —  将整个文件读入一个字符串

       string  file_get_contents ( string $filename [, bool $use_include_path = false [, resource$context [, int $offset = -1 [, int $maxlen ]]]] )

      和   file() 一样,只除了  file_get_contents() 把文件读入一个字符串。将在参数 offset 所指定的位置开始读取长度为maxlen 的内容。如果失败, file_get_contents() 将返回  FALSE

      该函数无需打开文件和关闭文件流!非常方便。

       file_get_contents() 函数是用来将文件的内容读入到一个字符串中的首选方法。如果操作系统支持还会使用内存映射技术来增强性能。 

      如果要打开有特殊字符的 URL (比如说有空格),就需要使用   urlencode() 进行 URL 编码。

     

      

    参数 描述
    path 必需。规定要读取的文件。
    include_path 可选。如果也想在 include_path 中搜寻文件的话,可以将该参数设为 "1"。
    context

    可选。规定文件句柄的环境。

    context 是一套可以修改流的行为的选项。若使用 null,则忽略。

    start 可选。规定在文件中开始读取的位置。该参数是 PHP 5.1 新加的。
    max_length 可选。规定读取的字节数。该参数是 PHP 5.1 新加的。

       例子:

      

      $homepage = file_get_contents('http://www.example.com/');
    echo $homepage;
    ?>

      


     

      

    본 웹사이트의 성명
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

    핫 AI 도구

    Undresser.AI Undress

    Undresser.AI Undress

    사실적인 누드 사진을 만들기 위한 AI 기반 앱

    AI Clothes Remover

    AI Clothes Remover

    사진에서 옷을 제거하는 온라인 AI 도구입니다.

    Undress AI Tool

    Undress AI Tool

    무료로 이미지를 벗다

    Clothoff.io

    Clothoff.io

    AI 옷 제거제

    AI Hentai Generator

    AI Hentai Generator

    AI Hentai를 무료로 생성하십시오.

    인기 기사

    R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
    1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. 최고의 그래픽 설정
    1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
    Will R.E.P.O. 크로스 플레이가 있습니까?
    1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

    뜨거운 도구

    메모장++7.3.1

    메모장++7.3.1

    사용하기 쉬운 무료 코드 편집기

    SublimeText3 중국어 버전

    SublimeText3 중국어 버전

    중국어 버전, 사용하기 매우 쉽습니다.

    스튜디오 13.0.1 보내기

    스튜디오 13.0.1 보내기

    강력한 PHP 통합 개발 환경

    드림위버 CS6

    드림위버 CS6

    시각적 웹 개발 도구

    SublimeText3 Mac 버전

    SublimeText3 Mac 버전

    신 수준의 코드 편집 소프트웨어(SublimeText3)

    JWT (JSON Web Tokens) 및 PHP API의 사용 사례를 설명하십시오. JWT (JSON Web Tokens) 및 PHP API의 사용 사례를 설명하십시오. Apr 05, 2025 am 12:04 AM

    JWT는 주로 신분증 인증 및 정보 교환을 위해 당사자간에 정보를 안전하게 전송하는 데 사용되는 JSON을 기반으로 한 개방형 표준입니다. 1. JWT는 헤더, 페이로드 및 서명의 세 부분으로 구성됩니다. 2. JWT의 작업 원칙에는 세 가지 단계가 포함됩니다. JWT 생성, JWT 확인 및 Parsing Payload. 3. PHP에서 인증에 JWT를 사용하면 JWT를 생성하고 확인할 수 있으며 사용자 역할 및 권한 정보가 고급 사용에 포함될 수 있습니다. 4. 일반적인 오류에는 서명 검증 실패, 토큰 만료 및 대형 페이로드가 포함됩니다. 디버깅 기술에는 디버깅 도구 및 로깅 사용이 포함됩니다. 5. 성능 최적화 및 모범 사례에는 적절한 시그니처 알고리즘 사용, 타당성 기간 설정 합리적,

    확실한 원칙과 PHP 개발에 적용되는 방법을 설명하십시오. 확실한 원칙과 PHP 개발에 적용되는 방법을 설명하십시오. Apr 03, 2025 am 12:04 AM

    PHP 개발에서 견고한 원칙의 적용에는 다음이 포함됩니다. 1. 단일 책임 원칙 (SRP) : 각 클래스는 하나의 기능 만 담당합니다. 2. Open and Close Principle (OCP) : 변경은 수정보다는 확장을 통해 달성됩니다. 3. Lisch의 대체 원칙 (LSP) : 서브 클래스는 프로그램 정확도에 영향을 미치지 않고 기본 클래스를 대체 할 수 있습니다. 4. 인터페이스 격리 원리 (ISP) : 의존성 및 사용되지 않은 방법을 피하기 위해 세밀한 인터페이스를 사용하십시오. 5. 의존성 반전 원리 (DIP) : 높고 낮은 수준의 모듈은 추상화에 의존하며 종속성 주입을 통해 구현됩니다.

    PHP에서 늦은 정적 결합의 개념을 설명하십시오. PHP에서 늦은 정적 결합의 개념을 설명하십시오. Mar 21, 2025 pm 01:33 PM

    기사는 PHP 5.3에 도입 된 PHP의 LSB (Late STATIC BING)에 대해 논의하여 정적 방법의 런타임 해상도가보다 유연한 상속을 요구할 수있게한다. LSB의 실제 응용 프로그램 및 잠재적 성능

    PHP의 CURL 라이브러리를 사용하여 JSON 데이터가 포함 된 게시물 요청을 보내는 방법은 무엇입니까? PHP의 CURL 라이브러리를 사용하여 JSON 데이터가 포함 된 게시물 요청을 보내는 방법은 무엇입니까? Apr 01, 2025 pm 03:12 PM

    PHP 개발에서 PHP의 CURL 라이브러리를 사용하여 JSON 데이터를 보내면 종종 외부 API와 상호 작용해야합니다. 일반적인 방법 중 하나는 컬 라이브러리를 사용하여 게시물을 보내는 것입니다 ...

    프레임 워크 보안 기능 : 취약점 보호. 프레임 워크 보안 기능 : 취약점 보호. Mar 28, 2025 pm 05:11 PM

    기사는 입력 유효성 검사, 인증 및 정기 업데이트를 포함한 취약점을 방지하기 위해 프레임 워크의 필수 보안 기능을 논의합니다.

    시스템 재시작 후 UnixSocket의 권한을 자동으로 설정하는 방법은 무엇입니까? 시스템 재시작 후 UnixSocket의 권한을 자동으로 설정하는 방법은 무엇입니까? Mar 31, 2025 pm 11:54 PM

    시스템이 다시 시작된 후 UnixSocket의 권한을 자동으로 설정하는 방법. 시스템이 다시 시작될 때마다 UnixSocket의 권한을 수정하려면 다음 명령을 실행해야합니다.

    프레임 워크 사용자 정의/확장 : 사용자 정의 기능을 추가하는 방법. 프레임 워크 사용자 정의/확장 : 사용자 정의 기능을 추가하는 방법. Mar 28, 2025 pm 05:12 PM

    이 기사에서는 프레임 워크에 사용자 정의 기능 추가, 아키텍처 이해, 확장 지점 식별 및 통합 및 디버깅을위한 모범 사례에 중점을 둡니다.

    See all articles