Laravel 5 系列入门教程(一)【最适合中国人的 Laravel 教程】
基于最新 Laravel 5.5 的 2017 版教程已经发布到 Github:https://github.com/johnlui/Learn-Laravel-5/issues
十分建议学习 5.5,跟 5.0 比变化非常大。
本教程示例代码见:https://github.com/johnlui/Learn-Laravel-5
大家在任何地方卡住,最快捷的解决方式就是去看我的示例代码。
Laravel 5 中文文档:
1. http://laravel-china.org/docs/5.0
2. http://www.golaravel.com/laravel/docs/5.0/
默认条件
本文默认你已经有配置完善的 PHP + MySQL 运行环境,懂得 PHP 网站运行的基础知识。跟随本教程走完一遍,你将会得到一个基础的包含登录的简单 blog 系统,并将学会如何使用一些强大的 Laravel 插件和 composer 包(Laravel 插件也是 composer 包)。
软件版本:PHP 5.4+,MySQL 5.1+
本文不推荐完全不懂 PHP 与 MVC 编程的人学习。本文不是 “一步一步跟我做” 教程。本文需要你付出一定的心智去解决一些或大或小的隐藏任务,以达到真正理解 Laravel 运行逻辑的目的。
1. 安装
许多人被拦在了学习Laravel的第一步,安装。并不是因为安装教程有多复杂,而是因为【众所周知的原因】。在此我推荐一个composer全量中国镜像:http://pkg.phpcomposer.com/ 。推荐以 “修改 composer 的配置文件” 方式配置。
镜像配置完成后,切换到你想要放置该网站的目录下(如 C:\wwwroot、/Library/WebServer/Documents/、/var/www/html、/etc/nginx/html 等),运行命令:
composer create-project laravel/laravel learnlaravel5 5.0.22
然后,稍等片刻,当前目录下就会出现一个叫 learnlaravel5 的文件夹。
本系列教程使用 Laravel 5.0 版本,5.1 版本去掉了本系列教程主要讲解的元素(Auth 系统),不建议使用 5.1 来学习。本系列教程为入门教程,目的是搞清楚 Laravel 的基本使用方法,切忌本末倒置。
如果你不会配置,建议去学会配置,网上资料很多。如果自暴自弃,可以把 的第 29 行 'url' => 'http://localhost', 配置成你的子目录地址,注意,要一直配置到 */learnlaravel5/public。然后将网站根目录配置为 learnlaravel5/public。
使用浏览器访问你配置的地址,将看到以下画面(我在本地配置的地址为 http://fuck.io:88 ):
2. 体验 Auth 系统并完成安装
—— 经过上面的过程,Laravel 5 的安装成功了?
—— 没有o(╯□╰)o
查看路由文件 learnlaravel5/app/Http/routes.php
的代码:
Route::get('/', 'WelcomeController@index'); Route::get('home', 'HomeController@index'); Route::controllers([ 'auth' => 'Auth\AuthController', 'password' => 'Auth\PasswordController', ]);
跟随代码里的蛛丝马迹,让我们访问 http://fuck.io:88/home (请自行替换域名),结果竟然跳转到了登陆页?
没错,Laravel 自带了开箱即用的 Auth 系统,连页面都已经写好了。
让我们随意输入邮箱和密码,点击登录,你很可能得到以下画面(Mac 或 Linux 下):
为什么空白?用开发者工具查看,这个请求的状态码是 500,为什么?
因为
learnlaravel5/storage
目录没有 777 权限。
执行 shell 命令:
cd learnlaravel5 sudo chmod -R 777 storage
重新访问 http://fuck.io:88/home ,随意输入邮箱和密码,如果你得到以下画面:
那么恭喜你~ Laravel 5 安装成功!
不想配置镜像的同学,可以使用 Laravel 界非常著名的 安正超 搞的安装神器:https://github.com/overtrue/latest-laravel
3. 数据库建立及迁移
Laravel 5 把数据库配置的地方改到了 learnlaravel5/.env
,打开这个文件,编辑下面四项,修改为正确的信息:
DB_HOST=localhost DB_DATABASE=laravel5 DB_USERNAME=root DB_PASSWORD=password
推荐新建一个名为 laravel5 的数据库,为了学习方便,推荐使用 root 账户直接操作。
Laravel 已经为我们准备好了 Auth 部分的 migration,运行以下命令执行数据库迁移操作:
php artisan migrate
得到的结果如下:
如果你运行命令报错,请检查数据库连接设置。
至此,数据库迁移已完成,你可以打开 http://fuck.io:88/home 欢快地尝试注册、登录啦。
4. 模型 Models
接下来我们将接触Laravel最为强大的部分,Eloquent ORM,真正提高生产力的地方,借用库克的一句话:鹅妹子英!
运行一下命令:
php artisan make:model Article php artisan make:model Page
Laravel 4 时代,我们使用 Generator 插件来新建 Model。现在,Laravel 5 已经把 Generator 集成进了 Artisan。
现在,Artisan 帮我们在 learnlaravel5/app/
下创建了两个文件 Article.php
和 Page.php
,这是两个 Model 类,他们都继承了 Laravel Eloquent 提供的 Model 类 Illuminate\Database\Eloquent\Model
,且都在 \App
命名空间下。这里需要强调一下,用命令行的方式创建文件,和自己手动创建文件没有任何区别,你也可以尝试自己创建这两个 Model 类。
Model 即为 MVC 中的 M,翻译为 模型,负责跟数据库交互。在 Eloquent 中,数据库中每一张表对应着一个 Model 类(当然也可以对应多个)。
如果你从其他框架转过来,可能对这里一笔带过的 Model 部分很不适应,没办法,是因为 Eloquent 实在太强大了啦,真的没什么好做的,继承一下 Eloquent 类就能实现很多很多功能了。
如果你想深入地了解 Eloquent,可以阅读系列文章:深入理解 Laravel Eloquent(一)——基本概念及用法
接下来进行 Article 和 Page 类对应的 articles 表和 pages表的数据库迁移,进入 learnlaravel5/database/migrations
文件夹。
在 *_create_articles_table.php 中修改:
Schema::create('articles', function(Blueprint $table) { $table->increments('id'); $table->string('title'); $table->string('slug')->nullable(); $table->text('body')->nullable(); $table->string('image')->nullable(); $table->integer('user_id'); $table->timestamps(); });
在 *_create_pages_table.php 中修改:
Schema::create('pages', function(Blueprint $table) { $table->increments('id'); $table->string('title'); $table->string('slug')->nullable(); $table->text('body')->nullable(); $table->integer('user_id'); $table->timestamps(); });
然后执行命令:
php artisan migrate
成功以后, articles 表和 pages 表已经出现在了数据库里,去看看吧~
5. 数据库填充 Seeder
在 learnlaravel5/database/seeds/
下新建 PageTableSeeder.php
文件,内容如下:
delete(); for ($i=0; $i < 10; $i++) { Page::create([ 'title' => 'Title '.$i, 'slug' => 'first-page', 'body' => 'Body '.$i, 'user_id' => 1, ]); } } }
然后修改同一级目录下的 DatabaseSeeder.php
中:
// $this->call('UserTableSeeder');
这一句为
$this->call('PageTableSeeder');
然后运行命令进行数据填充:
composer dump-autoload php artisan db:seed
去看看 pages 表,是不是多了十行数据?
教程(一)代码快照:https://github.com/johnlui/Learn-Laravel-5/archive/tutorial_1.zip
下一步:Laravel 5 系列入门教程(二)【最适合中国人的 Laravel 教程】
评论:
2015-12-08 11:05
D:\wamp\www\laravel>php artisan migrate
Fatal error: Call to undefined function Illuminate\Foundation\Bootstrap\mb_inter
nal_encoding() in D:\wamp\www\laravel\vendor\compiled.php on line 1809
报错,开启了mb_string扩展, 并且单独文件测试 mb_internal_ecoding函数没报错,一执行php artisan migrate 就报错,应该怎么解决呢
2015-12-03 09:51
为什么我在第三步最后,注册成功后,在数据库查看用户的密码是一堆类似乱码的杂乱符号呢? 而不是密码本身?
比如我注册一个用户,使用密码 123456 ,在数据库中查看就是一大长串字母加数字加符号,而我手动将数据库中的这个符号修改为 123456后
登录的时候会提示 Whoops! There were some problems with your input. These credentials do not match our records.
请问这可能是哪里出问题了呢?谢谢!
2015-11-22 13:20
input 文本之前的值没有 怎么回事
2015-11-15 11:37
2015-11-10 17:05
我按照步骤在执行php artisan migrate的时候出现了错误
[PDOException]
could not find driver
我的pdo_pgsql扩展是打开的
PDO
PDO support enabled
PDO drivers mysql, pgsql, sqlite
pdo_pgsql
PDO Driver for PostgreSQL enabled
PostgreSQL(libpq) Version 9.2.2
Module version 1.0.2
Revision $Id$
pgsql
PostgreSQL Support enabled
PostgreSQL(libpq) Version 9.2.2
PostgreSQL(libpq) Uninitialized version string (win32)
Multibyte character support enabled
SSL support disabled
Active Persistent Links 0
Active Links 0
Directive Local Value Master Value
pgsql.allow_persistent On On
pgsql.auto_reset_persistent Off Off
pgsql.ignore_notice Off Off
pgsql.log_notice Off Off
pgsql.max_links Unlimited Unlimited
pgsql.max_persistent Unlimited Unlimited
尝试了用PHP直接连postgresql正常,代码如下
<?php
$dsn = 'pgsql:dbname=kaigo;host=127.0.0.1;port=5432';
$user = 'kaigo';
$pass = 'kaigo';
try {
$dbh = new PDO($dsn, $user, $pass);
$sql = 'SELECT CURRENT_TIMESTAMP';
foreach ($dbh->query($sql) as $row) {
print $row[0] . "\n";
}
$dbh = null;
} catch (PDOException $e){
print('[ERROR] ' . $e->getMessage() . "\n");
die();
}
?>
.env文件数据库连接部分如下
DB_CONNECTION=pgsql
DB_HOST=127.0.0.1
DB_DATABASE=kaigo
DB_USERNAME=kaigo
DB_PASSWORD=kaigo
database.php文件部分如下
'default' => 'pgsql',
'connections' => [
'pgsql' => [
'driver' => 'pgsql',
'host' => env('DB_HOST', '127.0.0.1'),
'database' => env('DB_DATABASE', 'kaigo'),
'username' => env('DB_USERNAME', 'kaigo'),
'password' => env('DB_PASSWORD', 'kaigo'),
'charset' => 'utf8',
'prefix' => '',
'schema' => 'public',
],
环境是win7 64位,wampserver2.5(apache 2.4.9+php 5.5.12),postgresql 9.2
如果是连接mysql和sqlite能够正常通过,连postgresql就会出现上面说的错误
按照网上说的将libpq.dll文件拷到了apache目录下依然没有用
请问该如何解决?
2015-11-09 15:10
[ReflectionException]
Class PageTableSeeder does not exist
2015-11-04 16:12
请问如何能有效的去除掉laravel5中的public、index.php
我之前只是将网站root下的server.php改名为index.php
这个只解决了一部分,比如访问www.com/laravel不再是以前的ww.com/laravel/public/index.php
但是别的部分,比如有页面跳转的情况,比如ww.com/page/1是server not fund
然而ww.com/index.php/page/1是可以访问页面
我已经把。htaccess里面的参数也修改了,还是没有起效


2015-10-28 19:22


http://120.25.106.144:8888/auth/login
2015-10-19 11:11
|--------------------------------------------------------------------------
| Application URL
|--------------------------------------------------------------------------
|
| This URL is used by the console to properly generate URLs when using
| the Artisan command line tool. You should set this to the root of
| your application so that it is used when running Artisan tasks.
|
*/
这是我看到的配置网站根目录的介绍,说是要配置到应用的根目录,可是应用的根目录不应该配置到learnlaravel5吗,
您为啥要配置到public呢
2015-10-02 10:01
PHP Fatal error: Call to undefined method PageTableSeeder::setContainer() in /home/opt/demos/lv_demo/laraveldemo/vendor/laravel/framework/src/Illuminate/Database/Seeder.php on line 57
[Symfony\Component\Debug\Exception\FatalErrorException]
Call to undefined method PageTableSeeder::setContainer()
2015-12-09 14:24