Laravel 5 系列入门教程(二)【最适合中国人的 Laravel 教程】

2015-3-8   /   阅读数:159443   /   分类: Laravel

本教程示例代码见:https://github.com/johnlui/Learn-Laravel-5  

大家在任何地方卡住,最快捷的解决方式就是去看我的示例代码。

我们将改变学习路线,不再像 Laravel 4 教程那样先构建登录系统。在本篇教程中,我们将一起构建 Pages 的管理功能,尝试 Laravel 的路由和 PHP 的命名空间

1. 路由

Laravel 中的路由,跟其他 PHP 框架一样,作用是把各种请求分流到各个控制器。

在 `learnlaravel5/app/Http/routes.php` 的末尾添加以下代码:

Route::group(['prefix' => 'admin', 'namespace' => 'Admin'], function()
{
  Route::get('/', 'AdminHomeController@index');
});

这表示创建了一个路由组。

1. `'prefix' => 'admin'` 表示这个路由组的 url 前缀是 /admin,也就是说中间那一行代码 `Route::get('/'` 对应的链接不是 http://fuck.io:88/ 而是 http://fuck.io:88/admin ,如果这段代码是 `Route::get('fuck'` 的话,那么 URL 就应该是 http://fuck.io:88/admin/fuck

2. `'namespace' => 'Admin'` 表示下面的 `AdminHomeController@index` 不是在 `\App\Http\Controllers\AdminHomeController@index` 而是在 `\App\Http\Controllers\Admin\AdminHomeController@index`,加上了一个命名空间的前缀。

如果你用过 Laravel 4,会发现 Laravel 5 的命名空间规划比较怪异,这其实是一个非常大的进步。Laravel 4 其实已经全面引入了命名空间这个强大的特性,但是为了“降低学习成本”,把 路由、控制器、模型 的默认命名空间全部设置成了顶级命名空间,这个举动反而让很多人比较轻易地“上手”了 Laravel,但是在用了一段时间以后,还需要翻越一堵高墙,那就是命名空间,而且有了前面的“容易上手”的印象作为铺垫,后期的学习会更加困难。Laravel 5 把命名空间全部隔开,控制器在 `\App\Http\Controllers`,模型在 `\App`,让我们在刚上手的时候就体验命名空间分离的感觉,总体上其实是会降低学习成本的。

2. 控制器

我们可以使用 Artisan 非常方便地构建控制器:

php artisan make:controller Admin/AdminHomeController

得到 `learnlaravel5/app/Http/Controllers/Admin/AdminHomeController.php` 文件。

在 `class AdminHomeController extends Controller {` 上面增加一行:

use App\Page;

修改 index() 的代码如下:

public function index()
{
  return view('AdminHome')->withPages(Page::all());
}

控制器中文文档:http://laravel-china.org/docs/5.0/controllers

控制器中涉及到了许多的命名空间知识,可以参考 PHP 命名空间 解惑

3. 视图

新建 `learnlaravel5/resources/views/AdminHome.blade.php`:

@extends('app')

@section('content')
<div class="container">
  <div class="row">
    <div class="col-md-10 col-md-offset-1">
      <div class="panel panel-default">
        <div class="panel-heading">后台首页</div>

        <div class="panel-body">

        <a href="{{ URL('admin/pages/create') }}" class="btn btn-lg btn-primary">新增</a>

          @foreach ($pages as $page)
            <hr>
            <div class="page">
              <h4>{{ $page->title }}</h4>
              <div class="content">
                <p>
                  {{ $page->body }}
                </p>
              </div>
            </div>
            <a href="{{ URL('admin/pages/'.$page->id.'/edit') }}" class="btn btn-success">编辑</a>

            <form action="{{ URL('admin/pages/'.$page->id) }}" method="POST" style="display: inline;">
              <input name="_method" type="hidden" value="DELETE">
              <input type="hidden" name="_token" value="{{ csrf_token() }}">
              <button type="submit" class="btn btn-danger">删除</button>
            </form>
          @endforeach

        </div>
      </div>
    </div>
  </div>
</div>
@endsection

视图的基本用法在此不再赘述,请阅读中文文档:http://laravel-china.org/docs/5.0/views

访问 http://fuck.io:88/admin 得到如下页面:

Image

至此,包含 路由 》 控制器 》 模型 》 视图 的整个流程都已经完成。

4. 完成 Pages 管理功能

接下来,我将记录下我实现 Pages 管理功能的过程,不再做过多的阐述。大家有问题可以直接在本文下面留言,我会及时回复。

4.1 修改路由 learnlaravel5/app/Http/routes.php

Route::group(['prefix' => 'admin', 'namespace' => 'Admin'], function()
{
  Route::get('/', 'AdminHomeController@index');
  Route::resource('pages', 'PagesController');
});

此处增加了一条“资源控制器”,中文文档地址:http://laravel-china.org/docs/5.0/controllers#restful-resource-controllers

4.2 创建 learnlaravel5/app/Http/Controllers/Admin/PagesController.php

运行:

php artisan make:controller Admin/PagesController

4.3 修改 learnlaravel5/app/Http/Controllers/Admin/PagesController.php 为:

<?php namespace App\Http\Controllers\Admin;

use App\Http\Requests;
use App\Http\Controllers\Controller;

use Illuminate\Http\Request;

use App\Page;

use Redirect, Input, Auth;

class PagesController extends Controller {

	/**
	 * Show the form for creating a new resource.
	 *
	 * @return Response
	 */
	public function create()
	{
		return view('admin.pages.create');
	}

	/**
	 * Store a newly created resource in storage.
	 *
	 * @return Response
	 */
	public function store(Request $request)
	{
		$this->validate($request, [
			'title' => 'required|unique:pages|max:255',
			'body' => 'required',
		]);

		$page = new Page;
		$page->title = Input::get('title');
		$page->body = Input::get('body');
		$page->user_id = 1;//Auth::user()->id;

		if ($page->save()) {
			return Redirect::to('admin');
		} else {
			return Redirect::back()->withInput()->withErrors('保存失败!');
		}

	}

	/**
	 * Show the form for editing the specified resource.
	 *
	 * @param  int  $id
	 * @return Response
	 */
	public function edit($id)
	{
		return view('admin.pages.edit')->withPage(Page::find($id));
	}

	/**
	 * Update the specified resource in storage.
	 *
	 * @param  int  $id
	 * @return Response
	 */
	public function update(Request $request,$id)
	{
		$this->validate($request, [
			'title' => 'required|unique:pages,title,'.$id.'|max:255',
			'body' => 'required',
		]);

		$page = Page::find($id);
		$page->title = Input::get('title');
		$page->body = Input::get('body');
		$page->user_id = 1;//Auth::user()->id;

		if ($page->save()) {
			return Redirect::to('admin');
		} else {
			return Redirect::back()->withInput()->withErrors('保存失败!');
		}
	}

	/**
	 * Remove the specified resource from storage.
	 *
	 * @param  int  $id
	 * @return Response
	 */
	public function destroy($id)
	{
		$page = Page::find($id);
		$page->delete();

		return Redirect::to('admin');
	}

}

4.4 创建视图文件

首先在 learnlaravel5/resources/views 下创建 admin/pages 两级文件夹。

然后创建 learnlaravel5/resources/views/admin/pages/create.blade.php:

@extends('app')

@section('content')
<div class="container">
  <div class="row">
    <div class="col-md-10 col-md-offset-1">
      <div class="panel panel-default">
        <div class="panel-heading">新增 Page</div>

        <div class="panel-body">

          @if (count($errors) > 0)
            <div class="alert alert-danger">
              <strong>Whoops!</strong> There were some problems with your input.<br><br>
              <ul>
                @foreach ($errors->all() as $error)
                  <li>{{ $error }}</li>
                @endforeach
              </ul>
            </div>
          @endif

          <form action="{{ URL('admin/pages') }}" method="POST">
            <input type="hidden" name="_token" value="{{ csrf_token() }}">
            <input type="text" name="title" class="form-control" required="required">
            <br>
            <textarea name="body" rows="10" class="form-control" required="required"></textarea>
            <br>
            <button class="btn btn-lg btn-info">新增 Page</button>
          </form>

        </div>
      </div>
    </div>
  </div>
</div>
@endsection

之后创建 learnlaravel5/resources/views/admin/pages/edit.blade.php:

@extends('app')

@section('content')
<div class="container">
  <div class="row">
    <div class="col-md-10 col-md-offset-1">
      <div class="panel panel-default">
        <div class="panel-heading">编辑 Page</div>

        <div class="panel-body">

          @if (count($errors) > 0)
            <div class="alert alert-danger">
              <strong>Whoops!</strong> There were some problems with your input.<br><br>
              <ul>
                @foreach ($errors->all() as $error)
                  <li>{{ $error }}</li>
                @endforeach
              </ul>
            </div>
          @endif

          <form action="{{ URL('admin/pages/'.$page->id) }}" method="POST">
            <input name="_method" type="hidden" value="PUT">
            <input type="hidden" name="_token" value="{{ csrf_token() }}">
            <input type="text" name="title" class="form-control" required="required" value="{{ $page->title }}">
            <br>
            <textarea name="body" rows="10" class="form-control" required="required">{{ $page->body }}</textarea>
            <br>
            <button class="btn btn-lg btn-info">编辑 Page</button>
          </form>

        </div>
      </div>
    </div>
  </div>
</div>
@endsection

4.5 查看结果

后台首页 http://fuck.io:88/admin

Image

新增 Page http://fuck.io:88/admin/pages/create

Image

编辑 Page http://fuck.io:88/admin/pages/1/edit

Image

页面上的新增、编辑、删除的功能均已经完成,并且加入了表单验证,Pages 管理功能完成!



教程(二)代码快照:https://github.com/johnlui/Learn-Laravel-5/archive/tutorial_2.zip


下一步:Laravel 5 系列入门教程(三)【最适合中国人的 Laravel 教程】

WRITTEN BY

avatar

评论:

Yingdynasty
2015-11-03 11:32
博主 麻烦问您一下
view里面的这个完成修改:
  <form action="{{ URL('home/containers'.$container->id.)}}" method="POST">
            <input name="_method" type="hidden" value="PUT">
            <input type="hidden" name="_token" value="{{ csrf_token() }}">
   </form>

controller里面的
    public function update(Request $request,$id)
    {
        $this->validate($request, [
            'id' => 'required',
            'container_code' => 'required',
        ]);

        $Container = Container::find($id);
                    //还有其他代码
        if($Container->save()){
            return Redirect::to('home/container_info');//这个页面确实存在
            }
            else{
            return Redirect::back()->withInput()->withErrors('保存失败!');
            }

        }

但是完成修改时候他会报错
Sorry, the page you are looking for could not be found.
1/1
NotFoundHttpException in RouteCollection.php line 145:

万分感谢博主的时间~~
Ying
Jennifer
2015-11-02 10:52
刚才的问题,我已经知道了。不好意思,打扰了。
Jennifer
2015-11-02 10:49
Class 'App\Http\Controllers\Admin\Input' not found
报错没有引入Input和Redirect这两个文件,请问这两个文件在什么地方啊?
loveleo99
2016-03-22 17:00
@Jennifer:百度到的,测试可用
use Illuminate\Support\Facades\Input;
use Illuminate\Support\Facades\Redirect;
了不起的点赞
2016-06-14 16:35
@loveleo99:不错不错
JokerLinly
2015-10-28 14:34
你好,我想问一下,{{ $page->created_at }} 如果是要显示时间,而且是按照年月日的格式来显示的话,要怎么写?我尝试查过API,可是无从下手。求回复,谢谢!
JohnLui
2015-10-28 14:36
@JokerLinly:用 PHP 自带函数处理就可以。
hello
2015-10-23 14:59
执行php artisan make:controller Admin/AdminHomeController 显示 could not open input file:artisan
JohnLui
2015-10-23 15:04
@hello:artisan 是根目录下的一个文件,注意要 cd 到 learnlaravel5 目录下~
rain
2015-10-22 12:00
如何关闭指定路由的csrf, 比如说支付网关的,有其他途径来验证真实性,而用了csrf无法接收支付宝发来的post数据,

但是又不想全局禁用csrf。有什么办法没
JohnLui
2015-10-23 15:04
@rain:可以全局禁用,然后在某些路由组里打开。
Lisam
2015-10-20 10:21
请问下博主 laravel如何与App通信并返回json数据  听说可以用restful接口 但我也不清楚在哪里
JohnLui
2015-10-20 10:56
@Lisam:Laravel 有 return Response::json($data);
asc
2015-10-07 14:50
为何我的中文都是乱码?改哪里啊?
Apache
2015-10-13 11:46
@asc:把创建的view另存为utf-8格式的就ok了
nanf
2015-10-25 15:12
@Apache:请问这个具体怎么设置?
uping
2015-10-01 16:09
楼主我AdminHome出现这个错误,我和你的igt对比没差啊
Class App\Http\Controllers\Admin\adminHomeController does not exist
JohnLui
2015-10-01 17:21
@uping:adminHomeController A 要大写。。。
姚瑞
2015-10-03 22:48
@uping:哈哈,粗心
淹死的鱼
2015-09-29 15:34
感谢博主
TP9
2015-09-27 22:50
当点击新增时,页面会跳转到admin/pages/create,请问这个在路由里面没有设置,是在哪里设置的呢?
Apache
2015-10-13 11:52
@TP9:不用设置路由
点击新增按钮访问的是PagesController控制器的create方法,这个方法决定你要显示的内容:
public function create()
{
    //返回到create视图
    return view('admin.pages.create');
}
TP9
2015-09-27 22:18
博主你好,在admin下,也就是主页下,点击新增,这是会自动跳转到admin/pages/create,我想问一下,我在路由里面也没有看到你设置跳转啊,你是在哪里设置的?
jc
2015-09-22 13:31
博主,你好!
程序里面加了
@extends('app')

@section('content')
页面就显示空白也。去掉后就可以显示出来。这个是什么原因造成的?
Grace
2015-12-06 15:59
@jc:@section('example')
@show
这个要写完整吧
jc
2015-09-22 09:31
博主,你好!
routes代码如下:
Route::group(['prefix' => 'admin', 'namespace' => 'Admin'], function()
{
    Route::get('/', 'AdminHomeController@index');
    //Route::resource('pages', 'PagesController');
});
运行出现这个异常是什么原因导致的
at CompilerEngine->get('E:\www\learnlaravel5\resources\views/AdminHome.blade.php', array('__env' => object(Factory), 'app' => object(Application), 'errors' => object(ViewErrorBag), 'pages' => object(Collection))) in View.php line 138
随便我去
2015-09-19 10:04
删除不成功呀= =
wushd
2015-09-16 17:24
博主,请问一下,为什么我用http://地址/admin打开报错404,然后用http://地址/index.php/admin却可以打开页面呢
Qizi
2015-09-17 23:28
@wushd:伪静态问题,你要开启apache的rewrite模块
Eileen
2015-10-17 12:17
@Qizi:老师你好,我开启了那个功能还是不行啊,还是报错这个
阿莫
2015-09-14 19:20
博主您好!
test.com/laravel/  以及 test.com/laravel/1  这样的路由可以配置出来。

但 test.com/laravel/1.html   这样的地址, 路由怎么写,是和上面的两个地址访问的是一个地方呢?
why
2015-08-24 10:52
博主你好
我在显示模板的时候 出现
syntax error, unexpected end of file  

是因为@stop吗
Lisam
2015-08-22 23:06
博主
<form action="{{ URL('admin/pages') }}" method="POST">
            <input type="hidden" name="_token" value="{{ csrf_token() }}">
            <input type="text" name="title" class="form-control" required="required">
            <br>
            <textarea name="body" rows="10" class="form-control" required="required"></textarea>
            <br>
            <button class="btn btn-lg btn-info">新增 Page</button>
          </form>
这里面的{{ URL('admin/pages') }} 为什么能指向PagesController.php中的store方法
JohnLui
2015-08-22 23:54
@Lisam:因为 http://www.golaravel.com/laravel/docs/5.1/controllers/#restful-resource-controllers
Lisam
2015-08-23 11:32
@JohnLui:谢谢博主
bluebug
2015-08-19 14:58
根据你的教程 做出第一个laravel无限分类的查询资料系统,赞一个哦

发表评论:

© 2011-2019 岁寒  |  Powered by Emlog