引言
PHP是一种流行的服务器脚本语言,用于创建动态和交互式web页面。开始使用你选择的语言是学习编程的第一步。
本教程将指导您在Ubuntu上安装PHP 7.4,并通过命令行设置本地编程环境。您还将安装依赖管理器Composer,并通过运行脚本来测试您的安装。
前期准备
要完成本教程,您需要安装Ubuntu 18.04的本地或虚拟机,并具有管理权限和到该机器的互联网连接。您可以通过Ubuntu发布页面下载此操作系统。
第1步 设置PHP 7.4
你将在命令行中完成安装和设置,这是一种与计算机交互的非图形化方式。也就是说,你不需要点击按钮,而是需要输入文本,并通过文本从计算机接收反馈。
命令行,也称为shell或终端,可以帮助您修改和自动化您每天在计算机上执行的许多任务,是软件开发人员的一个重要工具。要学习许多终端命令,它们可以让你做更强大的事情。这篇介绍Linux终端的文章可以让你更好地适应终端。
在Ubuntu上,你可以通过点击屏幕左上角的Ubuntu图标,在搜索栏中输入terminal
来找到Terminal应用程序。单击终端应用程序图标来打开它。或者,您可以同时按下键盘上的CTRL
、ALT
和T
键来自动打开终端应用程序。
您需要避免依赖PHP的默认版本,因为默认版本可能会根据您运行代码的位置更改。您可能还希望安装一个不同的版本以匹配您正在使用的应用程序,或者升级到较新的版本,如PHP 8。
运行以下命令来更新apt-get
本身,它确保你可以访问你想要安装的任何内容的最新版本:
shell
sudo apt-get update
接下来,安装software-properties-common
,它可以管理额外的软件资源:
shell
sudo apt -y install software-properties-common
-y
标志将自动同意安装。如果不这样做,每次安装都会在终端窗口中收到一个提示。
接下来,安装ppa:ondrej/php
仓库,它将提供所有版本的PHP:
shell
sudo add-apt-repository ppa:ondrej/php
最后,再次更新apt-get
,让你的包管理器可以看到新列出的包:
shell
sudo apt-get update
现在您可以使用以下命令安装PHP 7.4了:
shell
sudo apt -y install php7.4
检查安装的版本:
shell
php -v
你看到类似下面的内容:
shell
OutputPHP 7.4.0beta4 (cli) (built: Aug 28 2019 11:41:49) ( NTS )ight (c) The PHP Group
Zend Engine v3.4.0-dev, Copyright (c) Zend Technologies
with Zend OPcache v7.4.0beta4, Copyright (c), by Zend Technologies
除了PHP本身,您可能还需要安装一些额外的PHP模块。你可以使用这个命令来安装其他模块,用你想要安装的包替换==PACKAGE_NAME==
:
shell
sudo apt-get install php7.4-PACKAGE_NAME
你也可以一次安装多个包。以下是一些你最可能需要安装的常用模块:
shell
sudo apt-get install -y php7.4-cli php7.4-json php7.4-common php7.4-mysql php7.4-zip php7.4-gd php7.4-mbstring php7.4-curl php7.4-xml php7.4-bcmath
该命令将安装以下模块:
php7.4-cli
- 命令解释器,用于从shell中测试PHP脚本或执行一般的shell脚本任务php7.4-json
- 用于处理JSON数据php7.4-common
- PHP文档、示例和通用模块php7.4-mysql
- 用于使用MySQL数据库php7.4-zip
- 用于处理压缩文件php7.4-gd
- 用于处理图像php7.4-mbstring
- 用于管理非ascii字符串php7.4-curl
- 允许你用PHP发起HTTP请求php7.4-xml
- 用于处理XML数据php7.4-bcmath
- 在处理浮点精度时使用
与Apache相关的PHP配置存储在/etc/php/7.4/apache2/php.ini
中。你可以使用以下命令列出所有加载的PHP模块:
shell
php -m
您已经安装了PHP并验证了正在运行的版本。您还安装了所需的PHP模块,并能够列出已加载的模块。
您可以现在就开始使用PHP,但您可能希望使用各种库来快速构建PHP应用程序。在测试PHP环境之前,首先为项目设置一个依赖管理器。
第2步 设置Composer进行依赖管理(可选)
库是一组代码,可以帮助你解决常见问题,而不需要自己编写所有内容。由于有许多可用的库,使用依赖管理器将帮助您管理多个库,从而提高编写PHP的经验。
Composer是一个用于PHP依赖管理的工具。它允许你声明项目所依赖的库,并管理这些包的安装和更新。
尽管类似,但Composer不是与yum
或apt
相同意义上的包管理器。它处理包或库,但它以每个项目为基础管理它们,将它们安装在一个目录中(例如:vendor
)。默认情况下,它不会全局安装任何东西。因此,它是一个依赖管理器 。但是,为了方便,它通过global
命令支持全局项目。
这个想法并不新鲜,Composer深受Node的npm
和Ruby的bundler
的启发。
设想:
- 你有一个项目依赖于几个库。
- 其中一些库依赖于其他库。
Composer:
- 允许你声明所依赖的库。
- 找出哪些包的版本可以并且需要安装,并通过下载它们到你的项目中来安装它们。
- 使您能够在一个命令中更新所有依赖项。
- 允许您查看基本用法章节以了解更多关于声明依赖项的详细信息。
简而言之,有两种安装Composer的方法:作为项目的一部分在本地安装,或者作为系统范围内可执行的全局安装。无论哪种方式,都需要从本地安装开始。
本地安装
要在本地快速安装Composer,请在终端中运行此脚本:
shell
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
php -r "if (hash_file('sha384', 'composer-setup.php') === '756890a4488ce9024fc62c56153228907f1545c228516cbf63f885e036d37e9a59d27d63f46af1d4d07ee0f76181c7d3') { echo 'Installer verified'; } else { echo 'Installer corrupt'; unlink('composer-setup.php'); } echo PHP_EOL;"
php composer-setup.php
php -r "unlink('composer-setup.php');"
这个安装脚本会检查一些php.ini
的设置,如果设置不正确会发出警告,然后在当前目录下下载最新的composer.phar
。这四行代码按顺序如下:
- 将安装程序下载到当前目录
- 验证安装程序SHA-384,你也可以在这里交叉检查
- 运行安装程序
- 移除安装程序
安装程序将检查一些PHP设置,然后将composer.phar
下载到您的工作目录。这个文件是Composer二进制文件。它是一个PHAR (PHP归档),这是一种PHP的归档格式,可以在命令行上运行。
要运行Composer,需要使用php composer.phar
。例如,运行以下命令查看你安装的Composer版本:
shell
php composer.phar --version
要在本地使用Composer,你需要将composer.phar
文件放在项目的根目录下。你可以在安装Composer之前从你的项目目录开始。你也可以在安装后移动文件。你也可以使用--install-dir
选项将Composer安装到特定的目录中,并使用--filename
选项(重新)命名它。
由于Composer是跨项目使用的,因此建议您继续阅读下一部分,并将Composer设置为全局运行。
全局安装
您可以将Composer PHAR放置在您希望的任何位置。如果你把它放在$PATH
目录下,你可以全局访问它。您甚至可以使它在Ubuntu(和其他Unix系统)上可执行,并在不直接使用PHP解释器的情况下调用它。
本地安装完成后,运行以下命令将composer.phar
移动到当前路径下的目录:
shell
sudo mv composer.phar /usr/local/bin/composer
如果你只想为自己的用户安装它,并避免需要root权限,你可以使用~/.local/bin
,它在一些Linux发行版中默认可用:
shell
mv composer.phar ~/.local/bin/composer
现在要运行Composer,请使用composer
而不是php composer.phar
。要检查你的Composer版本,请运行:
shell
composer --version
作为最后一步,你可以选择使用composer init
初始化项目。这将创建一个composer.json
文件来管理项目依赖。初始化项目还将允许定义项目细节,如作者和许可证,并使用Composer的自动加载功能。您可以现在定义依赖项,也可以稍后添加它们。
运行这个命令来初始化一个项目:
shell
composer init
运行此命令将启动安装向导。您在向导中输入的详细信息稍后可以更新,因此可以保留默认值,只需按ENTER
。如果你不准备安装任何依赖项,你可以选择no
。在每个提示框中输入你的详细信息:
shell
OutputThis command will guide you through creating your composer.json config.
Package name (sammy/php_install): sammy/project1
Description []:
Author [Sammy <sammy@digitalocean.com>, n to skip]:
Minimum Stability []:
Package Type (e.g. library, project, metapackage, composer-plugin) []: project
License []:
Define your dependencies.
Would you like to define your dependencies (require) interactively [yes]? no
Would you like to define your dev dependencies (require-dev) interactively [yes]? no
{
"name": "sammy/project1",
"type": "project",
"authors": [
{
"name": "Sammy",
"email": "sammy@digitalocean.com"
}
],
"require": {}
}
Do you confirm generation [yes]? yes
在你确认生成之前,你将看到一个向导将要创建的composer.json
文件的示例。如果一切看起来都不错,你可以确认默认值为yes
。如果你需要重新开始,选择no
。
第一次定义依赖时,Composer会创建一个vendor
文件夹。所有依赖都安装到这个vendor
文件夹中。Composer还会创建一个composer.lock
文件。此文件指定了项目中使用的每个依赖项和子依赖项的确切版本。这可以确保运行程序的任何机器上的每个包都使用完全相同的版本。
注意: vendor
文件夹永远不应该提交到你的版本控制系统(VCS)。vendor
文件夹只包含您从其他供应商安装的软件包。这些供应商将在自己的版本控制系统中维护自己的代码。您应该只跟踪您编写的代码。你只需要提交你的composer.json
和composer.lock
文件,而不是提交vendor
文件夹。
现在你已经安装了PHP,并且可以使用Composer管理项目依赖项,现在可以测试你的环境了。
第3步 测试PHP环境
要测试您的系统是否正确配置了PHP,您可以创建并运行一个基本的PHP脚本。将这个脚本命名为hello.php
:
shell
sudo nano hello.php
这将打开一个空白文件。将以下文本(有效的PHP代码)放入文件中:
hello.php
php
<?php
echo 'Hello World!';
?>
一旦添加了文本,保存并关闭文件。你可以按住CTRL
键,按下x
键。然后选择y
和ENTER
。
现在您可以测试,以确保PHP正确地处理您的脚本。键入php
来告诉php处理文件,然后是文件的名称:
shell
php hello.php
如果PHP处理正确,您将只看到引号内的字符:
shell
OutputHello World!
PHP已经成功地处理了脚本,这意味着您的PHP环境已经成功安装,您已经准备好继续您的编程之旅。
总结
至此,您已经在本地Ubuntu机器上设置了PHP 7.4编程环境,可以开始编码项目了。
在开始编码之前,您可能需要设置一个集成开发环境(IDE)。虽然有许多IDE可供选择,但VS Code是一个流行的选择,因为它提供了许多强大的功能,如图形界面、语法高亮和调试。