Laravel框架目前已经发展到5.6版本了,但是目前官方的入门教程还是基于5.1的博客教程。为了更多的人能快速上手新版本,本教程使用Laravel5.6
一部一部跟大家分享如何搭建一个博客系统。下面来看一下如何用十分钟使用Laravel5.6搭建简单博客
Laravel 框架对PHP版本和扩展有一定要求
下载安装PHP7,composer,mysql
执行 composer global require "laravel/installer"
, 安装laravel之后配置环境变量,执行laravel new blog
执行php artisan make:model --migration Post
,会在database/migrations目录下建立"日期create_posts_table.php"文件,编辑该文件
Schema::create('posts', function (Blueprint $table) {
$table->increments('id');
$table->string('slug')->unique();
$table->string('title');
$table->text('content');
$table->timestamps();
$table->timestamp('published_at')->nullable()->index();
});
这其实是在设置文字内容表的数据字段
命令同时会在app目录下建立一个Post.php文件,编辑文件
protected $dates = ['published_at'];
public function setTitleAttribute($value)
{
$this->attributes['title'] = $value;
if (! $this->exists) {
$this->attributes['slug'] = str_slug($value);
}
}
执行php artisan migrate
,该命令会在数据库中根据配置创建数据表
Laravel提供数据填充,添加factory 文件 database/factories/PostFactory.php,内容如下:
define(App\Post::class, function (Faker $faker) {
return [
'title' => $faker->sentence(mt_rand(3, 10)),
'content' => join("\n\n", $faker->paragraphs(mt_rand(3, 6))),
'published_at' => $faker->dateTimeBetween('-1 month', '+3 days'),
];
});
执行php artisan make:seed PostsTableSeeder
创建生博客文章数据成器,命令会在database/seeds下建立PostsTableSeeder.php文件。然后执行***composer dump-autoload 导入(否则class not found)***
function run(){
factory(App\Post::class, 50)->create();
}
编辑database/seeds/DatabaseSeeder.php中编辑
public function run()
{
$this->call(PostsTableSeeder::class);
}
执行 php artisan db:seed ,命令会根据数据生成器生成50条post数据
在config目录添加blog.php文件,文件内容如下:
'My Blog',
'posts_per_page' => 5
];
修改routes/web.php文件
Route::get('/', function () {
return redirect('/blog');
});
Route::get('blog', 'BlogController@index');
Route::get('blog/{slug}', 'BlogController@showPost');
执行php artisan make:controller BlogController
,在app/Http/Controllers下建立BlogController.php,修改内容如下
orderBy('published_at', 'desc')
->paginate(config('blog.posts_per_page'));
return view('blog.index', compact('posts'));
}
public function showPost($slug)
{
$post = Post::whereSlug($slug)->firstOrFail();
return view('blog.post')->withPost($post);
}
}
在resources/view下建立***blog文件夹***,分别添加index.blade.php,post.blade.php文件分别用户博客列表和详情的展示
index.blade.php
{% raw %}
<html>
<head>
<title>{{ config('blog.title') }}title>
<link href="https://cdn.bootcss.com/bootstrap/4.1.0/css/bootstrap.css" rel="stylesheet">
head>
<body>
<div class="container">
<h1>{{ config('blog.title') }}h1>
<h5>Page {{ $posts->currentPage() }} of {{ $posts->lastPage() }}h5>
<hr>
<ul>
@foreach ($posts as $post)
<li>
<a href="/blog/{{ $post->slug }}">{{ $post->title }}a>
<em>({{ $post->published_at }})em>
<p>
{{ str_limit($post->content) }}
p>
li>
@endforeach
ul>
<hr>
{!! $posts->render() !!}
div>
body>
html>
{% endraw %}
post.blade.php
{% raw %}
<html>
<head>
<title>{{ $post->title }}title>
<link href="https://cdn.bootcss.com/bootstrap/4.1.0/css/bootstrap.css" rel="stylesheet">
head>
<body>
<div class="container">
<h1>{{ $post->title }}h1>
<h5>{{ $post->published_at }}h5>
<hr>
{!! nl2br(e($post->content)) !!}
<hr>
<button class="btn btn-primary" onclick="history.go(-1)">
« Back
button>
div>
body>
html>
{% endraw %}
执行php artisan serve
启动服务,在浏览器中输入http://127.0.0.1:8080 浏览器会跳转到http://127.0.0.1:8080/blog 并展示下面内容
use Illuminate\Support\Facades\Schema;
,在boot中添加:Schema::defaultStringLength(191);本教程代码 下载
更多内容关注公众号 “写PHP的老王”