PHP 行事准则:PHP 配置文件

2023-10-06 15:26
文章标签 php 准则 配置文件 行事

本文主要是介绍PHP 行事准则:PHP 配置文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 参考
  • 环境
  • PHP 行事准则
      • PHP 配置文件
      • php.ini-production 与 php.ini-development
          • 生产配置文件
          • 开发配置文件
          • 配置文件的应用
          • 版本差异
      • 修改配置的生效
  • PHP 运行时配置
      • ini_set()
      • 布尔配置项
      • 限制
  • phpinfo()
      • phpinfo 页面
      • Core

参考

项目描述
搜索引擎BingGoogle
AI 大模型文心一言通义千问讯飞星火认知大模型ChatGPT
PHP 官方PHP Manual

环境

项目描述
PHP8.0.0
PHP 编辑器PhpStorm 2023.1.1(专业版)

PHP 行事准则

PHP 配置文件

在 PHP 中,配置文件是用来控制 PHP 运行时行为 的重要组成部分。PHP 配置文件包含一系列的配置指令,用于 定义 PHP 的工作方式和行为

php.ini-production 与 php.ini-development

php.ini-productionphp.ini-developerPHP5.3 及后续版本 提供的两个不同的 PHP 配置文件。

生产配置文件

php.ini-production 配置文件的目的是 提供一个适用于生产服务器的配置,该配置文件更加偏向于 安全性性能 的最佳实践。
通常,生产环境需要更严格的安全性和性能优化,因此这个配置文件中的选项可能被调整为更安全和更高性能的设置。例如,错误报告级别可能设置为较低以减少对终端用户的敏感信息泄漏,还可能启用了一些缓存机制以提高性能。

开发配置文件

php.ini-developer 配置文件的目的是为了 方便开发人员,以在开发和调试过程中 提供更多的信息灵活性
开发环境通常需要更多的错误报告和调试信息,以便开发人员更容易发现和修复问题。因此,这个配置文件中的选项可能会设置为内容输出更具详细性的值。例如,开启错误报告和调试日志,以帮助开发人员定位和解决问题。

配置文件的应用

在实际使用中,你可以根据需要选择使用哪个配置文件。在决定选择使用那个配置文件时,将该配置文件重命名为 php.ini 即可。

版本差异

PHP5.3 以后,PHP 官方提供的 PHP 文件中将包含 php.ini-developmentphp.ini-production,分别是 PHP 开发环境的配置文件以及 PHP 生产环境的配置文件。
PHP5.3 以前,PHP 官方也提供 PHP 配置文件,即 php.ini-distphp.ini-recommended,分别与此后的 php.ini-developmentphp.ini-production 相对应。

修改配置的生效

在修改 PHP 配置文件后,被修改配置项的生效条件视具体情况而定。对此,请参考如下条目:

  1. 重启 WEB 服务器
    如果您使用 ApacheNginx 服务来运行 PHP,那么在您修改配置文件后,您 需要重启相应的服务。这是因为 PHP 的配置 在服务启动时加载,并保持在内存中,直到服务停止
  2. CLI
    如果您在命令行界面 (Command Line Interface,CLI) 中使用 PHP,那么 任何新的 CLI 进程都会立即使用最新的配置正在运行的 PHP 进程则不受影响,如需使用最新配置,请将该进程关闭并开启新 PHP 进程。

PHP 运行时配置

ini_set()

除了 php.ini 文件之外,PHP 还允许 在脚本运行过程中通过 ini_set() 函数来动态修改某些配置选项的值,这些更改只在 当前脚本运行时生效,并不会影响全局配置。这为开发者提供了在单个脚本或应用的执行过程中调整配置的灵活性。

ini_set()

function ini_set(string $option,     $value 
): false|string

其中:

$option 用于指定需要修改的配置项,而 $value 则是配置项被修改后的结果值。ini_set() 函数在修改配置项成功时返回 被修改配置项的原有值,否则,返回 false。对此,请参考如下示例:

<?php# ini_get() 函数可用于获取特定配置项的配置值。
var_dump(ini_get('display_errors'));# 配置项的值若为 Off 则无论何种大小写形式,
# 该配置项都将被关闭。On 同理可得
var_dump(ini_set('display_errors', 'Off'));var_dump(ini_get('display_errors'));# 尝试通过 ini_get() 修改一个不存在的配置项
# 则该函数将因为修改配置项失败而返回 false。
var_dump(ini_set('Fantasy', 1));

执行效果

string(1) "1"
string(1) "1"
string(3) "Off"
bool(false)

布尔配置项

大多数配置项的取值只有 OnOff,分别表示开启该配置或关闭该配置,这些配置项被称为布尔配置项。$value 的取值的数据类型不仅仅局限于某一种,因此当某一配置项为布尔配置项时,该配置项(除 On、Off 外)作为字符串转化为布尔值的结果将决定这些配置是否被开启(在配置文件 php.ini 中亦是如此)

限制

在 PHP 中,不同配置项所能够采取的配置方法可能是不同的,并不是所有的选项都可以在运行时通过 ini_set() 函数来修改。ini_set() 函数允许你在脚本运行时动态地设置配置选项,但有些选项可能由于 安全或系统级别的限制 而不能通过 ini_set() 来修改。对此,请参考如下示例:

<?php# allow_url_include 配置项用于配置是否允许
# 通过 URL 包含并执行远程文件。
var_dump(ini_get('allow_url_include'));# 由于 allow_url_include 不允许通过 ini_set() 
# 的方式进行设置,故 ini_set() 将返回 false
var_dump(ini_set('allow_url_include', 'On'));

执行效果

string(0) ""
bool(false)

如果您需要查看某个配置项所 允许的配置方式,请访问由 PHP 官方提供的 ini.list.php 页面。

phpinfo()

phpinfo 页面

phpinfo() 是 PHP 提供的一个非常有用的 内置函数,该函数用于显示有关 PHP 的配置信息。当你调用这个函数时,它将产生一个 详尽的 HTML 页面,列出 所有与 PHP 的配置和环境相关的信息

Core

phpinfo() 是 PHP 提供的一个函数,用于输出关于 PHP 的配置信息。当你调用这个函数时,该函数将生成一个 详细的 HTML 页面,其中展示了诸如 PHP 版本编译参数、模块信息环境变量 等信息。phpinfo 页面中存在多个部分,其中 Core 部分是有关 PHP 核心设置的相关信息。具体请参考如下界面:

Core 部分,你会看到一系列的指令和它们的值。这些指令和值涉及到 PHP 的基本操作和行为。其中,Local ValueMaster Value 分别表示 运行时配置(当前 PHP 运行环境中实际生效的值) 与 PHP 配置文件 php.ini 中存储的 默认配置

这篇关于PHP 行事准则:PHP 配置文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/153377

相关文章

web群集--nginx配置文件location匹配符的优先级顺序详解及验证

文章目录 前言优先级顺序优先级顺序(详解)1. 精确匹配(Exact Match)2. 正则表达式匹配(Regex Match)3. 前缀匹配(Prefix Match) 匹配规则的综合应用验证优先级 前言 location的作用 在 NGINX 中,location 指令用于定义如何处理特定的请求 URI。由于网站往往需要不同的处理方式来适应各种请求,NGINX 提供了多种匹

PHP原理之内存管理中难懂的几个点

PHP的内存管理, 分为俩大部分, 第一部分是PHP自身的内存管理, 这部分主要的内容就是引用计数, 写时复制, 等等面向应用的层面的管理. 而第二部分就是今天我要介绍的, zend_alloc中描写的关于PHP自身的内存管理, 包括它是如何管理可用内存, 如何分配内存等. 另外, 为什么要写这个呢, 因为之前并没有任何资料来介绍PHP内存管理中使用的策略, 数据结构, 或者算法. 而在我们

php中json_decode()和json_encode()

1.json_decode() json_decode (PHP 5 >= 5.2.0, PECL json >= 1.2.0) json_decode — 对 JSON 格式的字符串进行编码 说明 mixed json_decode ( string $json [, bool $assoc ] ) 接受一个 JSON 格式的字符串并且把它转换为 PHP 变量 参数 json

如何将文件夹里的PHP代码放到一个文件里

find ./dir -name "*.php" -exec 'cat' {} \; > dir.out

PHP抓取网站图片脚本

方法一: <?phpheader("Content-type:image/jpeg"); class download_image{function read_url($str) { $file=fopen($str,"r");$result = ''; while(!feof($file)) { $result.=fgets($file,9999); } fclose($file); re

PHP防止SQL注入详解及防范

SQL 注入是PHP应用中最常见的漏洞之一。事实上令人惊奇的是,开发者要同时犯两个错误才会引发一个SQL注入漏洞。 一个是没有对输入的数据进行过滤(过滤输入),还有一个是没有对发送到数据库的数据进行转义(转义输出)。这两个重要的步骤缺一不可,需要同时加以特别关注以减少程序错误。 对于攻击者来说,进行SQL注入攻击需要思考和试验,对数据库方案进行有根有据的推理非常有必要(当然假设攻击者看不到你的

PHP防止SQL注入的方法(2)

如果用户输入的是直接插入到一个SQL语句中的查询,应用程序会很容易受到SQL注入,例如下面的例子: $unsafe_variable = $_POST['user_input'];mysql_query("INSERT INTO table (column) VALUES ('" . $unsafe_variable . "')"); 这是因为用户可以输入类似VALUE”); DROP TA

PHP防止SQL注入的方法(1)

(1)mysql_real_escape_string – 转义 SQL 语句中使用的字符串中的特殊字符,并考虑到连接的当前字符集 使用方法如下: $sql = "select count(*) as ctr from users where username ='".mysql_real_escape_string($username)."' and password='". mysql_r

Linux系统安装php开发环境

Linux系统centos6.5 PHP5.6 MySQL5.6 Nginx1.7 yum安装依赖库 yum install -y make cmake gcc gcc-c++ autoconf automake libpng-devel libjpeg-devel zlib libxml2-devel ncurses-devel bison \libtool-ltdl-devel li

PHP字符串全排列

方法一: $str = 'abc';$a =str_split($str);perm($a, 0, count($a)-1);function perm(&$ar, $k, $m) {if($k == $m){ echo join('',$ar), PHP_EOL;}else {for($i=$k; $i<=$m; $i++) {swap($ar[$k], $ar[$i]);perm($ar