介绍
Laravel是一个开源的PHP框架,提供了一套工具和资源来构建现代PHP应用程序. 随着完整的生态系统利用其内置的功能,Laravel的普及在过去几年中迅速增长,许多开发者采用它作为他们选择的框架,以简化开发过程。
在本指南中,您将在 Ubuntu 20.04 服务器上安装和配置一个新的 Laravel 应用程序,使用 Composer来下载和管理框架依赖和 Nginx 来服务应用程序。
前提条件
要完成本指南,您首先需要在 Ubuntu 20.04 服务器上执行以下任务:
- ** 创建一个
sudo
用户并启用ufw
** . 要设置此设置,您可以遵循我们的 初始服务器设置与Ubuntu 20.04指南。 - 安装LEMP堆栈与MySQL 8 . 如果您尚未设置此设置,您可以按照我们指南的步骤1到3在
如何在Ubuntu 20.04上安装Nginx,MySQL和PHP
(https://andsky.com/tech/tutorials/how-to-install-linux-nginx-mysql-php-lemp-stack-on-ubuntu-20-04)。 - Install Composer . 我们将使用(https://getcomposer.org/)来安装Laravel及其依赖。
第1步:安装必要的PHP模块
在您可以安装Laravel之前,您需要安装一些PHP模块,这些模块是框架所要求的。我们将使用apt
来安装php-mbstring
,php-xml
和php-bcmath
PHP模块。这些PHP扩展为处理字符编码、XML和精确数学提供了额外的支持。
如果这是第一次在本会话中使用apt
,您应该先运行更新
命令来更新包管理器缓存:
1sudo apt update
现在您可以安装所需的软件包:
1sudo apt install php-mbstring php-xml php-bcmath
您的系统现在已经准备好通过 Composer 执行 Laravel 的安装,但在此之前,您需要为您的应用程序建立一个数据库。
步骤 2 – 创建应用程序的数据库
为了展示 Laravel 的基本安装和使用,我们将创建一个 travel list 应用程序,以显示用户想要旅行的地点列表,以及他们已经访问的地点列表。
要从 Laravel 应用程序连接到数据库,我们将创建一个专用 MySQL 用户,并授予该用户对旅行者
数据库的全部权限。
在本文写作时,原生MySQL PHP库mysqlnd
不支持(https://www.php.net/manual/en/ref.pdo-mysql.php)`caching_sha2_authentication`,这是MySQL 8的默认身份验证方法。
要开始,请登录 MySQL 控制台作为 root 数据库用户:
1sudo mysql
若要创建新的数据库,请从您的 MySQL 控制台执行以下命令:
1CREATE DATABASE travellist;
现在您可以创建一个新用户,并在您刚刚创建的自定义数据库中授予他们完整的权限. 在本示例中,我们正在创建一个名为 travellist_user 的用户,其密码为密码
,但您应该将其更改为您选择的安全密码:
1CREATE USER 'travellist_user'@'%' IDENTIFIED WITH mysql_native_password BY 'password';
现在我们需要在旅行者
数据库上授予此用户权限:
1GRANT ALL ON travellist.* TO 'travellist_user'@'%';
这将为travellist_user
用户提供对travellist
数据库的完整权限,同时阻止该用户在您的服务器上创建或修改其他数据库。
接下来,输出 MySQL 壳:
1exit
现在,您可以通过再次登录到MySQL控制台来测试新用户是否有正确的权限,这一次使用自定义用户凭证:
1mysql -u travellist_user -p
请注意这个命令中的p
标志,它会提示您在创建 travellist_user 用户时使用的密码。
1SHOW DATABASES;
这将为您带来以下结果:
1[secondary_label Output]
2+--------------------+
3| Database |
4+--------------------+
5| information_schema |
6| travellist |
7+--------------------+
82 rows in set (0.01 sec)
接下来,在旅行者
数据库中创建一个名为地点
的表,从MySQL控制台运行以下陈述:
1CREATE TABLE travellist.places (
2 id INT AUTO_INCREMENT,
3 name VARCHAR(255),
4 visited BOOLEAN,
5 PRIMARY KEY(id)
6);
现在,用一些样本数据填充位置
表:
1INSERT INTO travellist.places (name, visited)
2VALUES ("Tokyo", false),
3("Budapest", true),
4("Nairobi", false),
5("Berlin", true),
6("Lisbon", true),
7("Denver", false),
8("Moscow", false),
9("Olso", false),
10("Rio", true),
11("Cincinnati", false),
12("Helsinki", false);
若要确认数据已成功保存到表中,请运行:
1SELECT * FROM travellist.places;
您将看到类似于此的输出:
1[secondary_label Output]
2+----+-----------+---------+
3| id | name | visited |
4+----+-----------+---------+
5| 1 | Tokyo | 0 |
6| 2 | Budapest | 1 |
7| 3 | Nairobi | 0 |
8| 4 | Berlin | 1 |
9| 5 | Lisbon | 1 |
10| 6 | Denver | 0 |
11| 7 | Moscow | 0 |
12| 8 | Oslo | 0 |
13| 9 | Rio | 1 |
14| 10 | Cincinnati| 0 |
15| 11 | Helsinki | 0 |
16+----+-----------+---------+
1711 rows in set (0.00 sec)
在确认您在测试表中有有效数据后,您可以退出MySQL控制台:
1exit
您现在已经准备好创建应用程序并将其配置为连接到新数据库。
步骤 3 – 创建一个新的Laravel应用程序
您现在将使用composer create-project
命令创建一个新的 Laravel 应用程序. 此 Composer 命令通常用于基于现有框架和内容管理系统启动新应用程序。
在本指南中,我们将使用travellist
作为示例应用程序,但您可以自由地将其更改为其他东西。travellist
应用程序将显示来自本地MySQL服务器的位置列表,旨在展示Laravel的基本配置并确认您可以连接到数据库。
首先,进入用户的家庭目录:
1cd ~
以下命令将创建一个新的旅行者
目录,该目录包含基于默认设置的Laravel应用程序:
1composer create-project --prefer-dist laravel/laravel travellist
您将看到类似于此的输出:
1[secondary_label Output]
2Installing laravel/laravel (v5.8.17)
3 - Installing laravel/laravel (v5.8.17): Downloading (100%)
4Created project in travellist
5> @php -r "file_exists('.env') || copy('.env.example', '.env');"
6Loading composer repositories with package information
7Updating dependencies (including require-dev)
8Package operations: 80 installs, 0 updates, 0 removals
9 - Installing symfony/polyfill-ctype (v1.11.0): Downloading (100%)
10 - Installing phpoption/phpoption (1.5.0): Downloading (100%)
11 - Installing vlucas/phpdotenv (v3.4.0): Downloading (100%)
12 - Installing symfony/css-selector (v4.3.2): Downloading (100%)
13...
安装完成后,访问应用程序目录并运行Laravel的手工
命令,以验证所有组件是否成功安装:
1cd travellist
2php artisan
你会看到类似于此的输出:
1[secondary_label Output]
2Laravel Framework 7.11.0
3
4Usage:
5 command [options] [arguments]
6
7Options:
8 -h, --help Display this help message
9 -q, --quiet Do not output any message
10 -V, --version Display this application version
11 --ansi Force ANSI output
12 --no-ansi Disable ANSI output
13 -n, --no-interaction Do not ask any interactive question
14 --env[=ENV] The environment the command should run under
15 -v|vv|vvv, --verbose Increase the verbosity of messages: 1 for normal output, 2 for more verbose output and 3 for debug
16...
此输出确认应用程序文件已在位置,Laravel命令行工具正在按预期工作,但我们仍然需要配置应用程序来设置数据库和其他一些细节。
步骤 4 – 配置 Laravel
Laravel 配置文件位于应用程序的 root 目录中的一个名为config
的目录中。 此外,当您与 Composer 一起安装 Laravel 时,它会创建一个 environment file。 此文件包含对应用程序正在运行的当前环境特定的设置,并将优先于位于 config
目录中的常规配置文件中设置的值。 在新的环境中,每个安装都需要一个定制的环境文件来定义数据库连接设置、调试选项、应用程序 URL 等内容,这些内容可能因应用程序正在运行的环境而有所不同。
<$>[警告] 警告 :环境配置文件包含有关您的服务器的敏感信息,包括数据库凭证和安全密钥。
我们现在将编辑.env 文件,以定制当前应用环境的配置选项。
使用您所选择的命令行编辑器打开 .env
文件. 在这里,我们将使用 nano
:
1nano .env
虽然这个文件中有许多配置变量,但您不需要现在设置所有这些变量,以下列表包含需要立即关注的变量概述:
APP_NAME
:应用名称,用于通知和消息。APP_ENV
:当前应用环境.APP_KEY
:用于生成盐和哈希,此独特的密钥在安装Laravel时自动创建,所以您不需要更改它。APP_DEBUG
:是否在客户端显示调试信息。APP_URL
:应用程序的基本URL,用于生成应用链接。
默认情况下,这些值是为使用 Homestead的本地开发环境配置的,这是由 Laravel 提供的预先包装的 Vagrant 框。
如果您在 development 或 ** testing** 环境中安装 Laravel,您可以将APP_DEBUG
选项关闭,因为在从浏览器中测试应用程序时,这将为您提供重要的调试信息。
如果您在生产环境中安装 Laravel,您应该禁用APP_DEBUG
选项,因为它会向最终用户显示有关您的应用程序的敏感信息。
下面的 .env
文件为 development 设置了我们的示例应用程序:
<$>[注] 注 :「APP_KEY」变量包含一个独特的密钥,在您通过 Composer 安装 Laravel 时自动生成,您不需要更改此值。
1[label /var/www/travellist/.env]
2APP_NAME=TravelList
3APP_ENV=development
4APP_KEY=APPLICATION_UNIQUE_KEY_DONT_COPY
5APP_DEBUG=true
6APP_URL=http://domain_or_IP
7
8LOG_CHANNEL=stack
9
10DB_CONNECTION=mysql
11DB_HOST=127.0.0.1
12DB_PORT=3306
13DB_DATABASE=travellist
14DB_USERNAME=travellist_user
15DB_PASSWORD=password
16
17...
当你完成编辑时,保存并关闭文件以保留你的更改. 如果你使用nano
,你可以用CTRL+X
,然后Y
和Enter
来确认。
您的 Laravel 应用程序现在已设置,但我们仍然需要配置 Web 服务器,以便能够从浏览器中访问它。
步骤五:设置 Nginx
我们已经在您的远程用户主目录的本地文件夹上安装了Laravel,虽然这对本地开发环境非常有效,但对于向公共互联网开放的Web服务器来说,这不是一个建议的做法。
首先,使用mv
命令将应用程序文件夹及其所有内容移动到/var/www/travellist
:
1sudo mv ~/travellist /var/www/travellist
现在我们需要给网页服务器用户写入存储
和缓存
文件夹,在那里Laravel存储应用程序生成的文件:
1sudo chown -R www-data.www-data /var/www/travellist/storage
2sudo chown -R www-data.www-data /var/www/travellist/bootstrap/cache
应用程序文件现在有序,但我们仍然需要配置 Nginx 来服务内容. 为此,我们将创建一个新的虚拟主机配置文件在 /etc/nginx/sites-available
:
1sudo nano /etc/nginx/sites-available/travellist
以下配置文件包含 Nginx 上 Laravel 应用程序的 推荐设置:
1[label /etc/nginx/sites-available/travellist]
2server {
3 listen 80;
4 server_name server_domain_or_IP;
5 root /var/www/travellist/public;
6
7 add_header X-Frame-Options "SAMEORIGIN";
8 add_header X-XSS-Protection "1; mode=block";
9 add_header X-Content-Type-Options "nosniff";
10
11 index index.html index.htm index.php;
12
13 charset utf-8;
14
15 location / {
16 try_files $uri $uri/ /index.php?$query_string;
17 }
18
19 location = /favicon.ico { access_log off; log_not_found off; }
20 location = /robots.txt { access_log off; log_not_found off; }
21
22 error_page 404 /index.php;
23
24 location ~ \.php$ {
25 fastcgi_pass unix:/var/run/php/php7.4-fpm.sock;
26 fastcgi_index index.php;
27 fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
28 include fastcgi_params;
29 }
30
31 location ~ /\.(?!well-known).* {
32 deny all;
33 }
34}
将此内容复制到您的 /etc/nginx/sites-available/travellist
文件,并在需要时调整突出值以匹配您的配置。
要激活新的虚拟主机配置文件,在网站启用
中创建一个符号链接到旅行者
:
1sudo ln -s /etc/nginx/sites-available/travellist /etc/nginx/sites-enabled/
<$>[注意]
注意 :如果您有另一个虚拟主机文件,此前已配置为同一服务器_名称
用于旅行者
虚拟主机,您可能需要通过在/etc/nginx/sites-enabled/
中删除相应的符号链接来禁用旧配置。
要确认配置不包含任何语法错误,您可以使用:
1sudo nginx -t
你应该看到这样的输出:
1[secondary_label Output]
2nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
3nginx: configuration file /etc/nginx/nginx.conf test is successful
若要应用这些更改,请重新加载 Nginx:
1sudo systemctl reload nginx
现在,进入您的浏览器并使用服务器的域名或IP地址访问应用程序,如您的配置文件中的server_name
指令所定义:
1http://server_domain_or_IP
你会看到这样的页面:
这确认您的 Nginx 服务器已正确配置以服务 Laravel. 从此,您可以开始在默认安装提供的骨骼上构建您的应用程序。
在下一步中,我们将修改应用程序的主要路径以使用Laravel的DB
面貌查询数据库中的数据。
步骤 6 – 定制主页
假设您已经遵循本指南的所有步骤,您应该有一个工作Laravel应用程序和一个名为位置
的数据库表,其中包含一些样本数据。
现在我们将编辑应用程序的主要路径来查询数据库,并将内容返回应用程序的 view。
打开主路线文件,‘routes/web.php’:
1nano routes/web.php
此文件默认情况下提供以下内容:
1[label routes/web.php]
2<?php
3
4/*
5|--------------------------------------------------------------------------
6| Web Routes
7|--------------------------------------------------------------------------
8|
9| Here is where you can register web routes for your application. These
10| routes are loaded by the RouteServiceProvider within a group which
11| contains the "web" middleware group. Now create something great!
12|
13*/
14
15Route::get('/', function () {
16 return view('welcome');
17});
在此文件中,路线是使用静态方法Route::get
定义的,该路径将收到一个 path 和一个 ** callback** 函数作为参数。
以下代码取代了主要路线回调函数. 它使用访问
旗帜对数据库进行 2 个查询,以过滤结果. 它将结果返回到名为travellist
的视图中,我们将下次创建。
1[label routes/web.php]
2<?php
3
4use Illuminate\Support\Facades\DB;
5
6Route::get('/', function () {
7 $visited = DB::select('select * from places where visited = ?', [1]);
8 $togo = DB::select('select * from places where visited = ?', [0]);
9
10 return view('travellist', ['visited' => $visited, 'togo' => $togo ] );
11});
当您完成编辑时,将保存并关闭文件. 我们现在将创建将数据库结果呈现给用户的视图. 在资源/视图
中创建一个新的视图文件:
1nano resources/views/travellist.blade.php
下面的模板会根据访问
和togo
变量创建两个位置列表,将此内容复制到新视图文件中:
1[label resources/views/travellist/blade.php]
2<html>
3<head>
4 <title>Travel List</title>
5</head>
6
7<body>
8 <h1>My Travel Bucket List</h1>
9 <h2>Places I'd Like to Visit</h2>
10 <ul>
11 @foreach ($togo as $newplace)
12 <li>{{ $newplace->name }}</li>
13 @endforeach
14 </ul>
15
16 <h2>Places I've Already Been To</h2>
17 <ul>
18 @foreach ($visited as $place)
19 <li>{{ $place->name }}</li>
20 @endforeach
21 </ul>
22</body>
23</html>
完成后保存并关闭文件. 现在进入您的浏览器并重新加载应用程序. 您将看到这样的页面:
你现在有一个功能性的Laravel应用程序从MySQL数据库中提取内容。
结论
在本教程中,您已经在LEMP堆栈(Linux, Nginx,MySQL和PHP)上设置了一个新的Laravel应用程序,在Ubuntu 20.04服务器上运行。
从这里,您可以为您的应用程序需要的任何额外页面创建新的路径和视图。 查看官方的 Laravel 文档,以获取有关 路径, 视图和 数据库支持的更多信息。