利用Laravel 5 框架构建 Pages 的管理功能

1. 路由

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

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

Route::group([‘prefix‘ => ‘admin‘, ‘namespace‘ => ‘Admin‘], function()

{

Route::get(‘/‘, ‘[email protected]‘);

});

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

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‘` 表示下面的 `[email protected]` 不是在 `\App\Http\Controllers\[email protected]` 而是在 `\App\Http\Controllers\Admin\[email protected]`,加上了一个命名空间的前缀。

如果你用过 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`:

?1234567891011121314151617181920212223242526272829303132333435363738 @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 得到如下页面:

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

4. 完成 Pages 管理功能

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

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

Route::group([‘prefix‘ => ‘admin‘, ‘namespace‘ => ‘Admin‘], function()

{

Route::get(‘/‘, ‘[email protected]‘);

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 :

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

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

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

文章参考CODEGO.NET和CSDN.NET

时间: 2024-11-06 09:57:08

利用Laravel 5 框架构建 Pages 的管理功能的相关文章

如何利用Truffle React框架构建完整的智能合约

如何利用Truffle React框架构建完整的智能合约 使用solidity的truffle框架开发智能合约,前端使用react框架,最终完成智能合约从前端到后端,从开发到部署的完整流程. 1. 版本需求 Truffle v5.0.28 (core: 5.0.28) Solidity v0.5.0 (solc-js) Node v8.11.2 Web3.js v1.0.0-beta.37 2. 项目初始化 mkdir -p truffle cd truffle truffle unbox re

使用 SailingEase WinForm 框架构建复合式应用程序(插件式应用程序)

对于一些较小的项目,具备一定经验的开发人员应该能够设计和构建出便于进行维护和扩展的应用程序.但是,随着功能模块数量(以及开发维护这些部件的人员)的不断增加,对项目实施控制的难度开始呈指数级增长. SailingEase WinForm 框架为您提供了针对此问题提出的解决方案.在本文中,将对基于SailingEase WinForm 框架的复合应用程序的定义进行解释,并简要说明如何才能构建一个基于 SailingEase WinForm 框架功能的复合应用程序. 传统的单一应用程序 传统的单一应用

ASP.NET Core 入门教程 2、使用ASP.NET Core MVC框架构建Web应用

原文:ASP.NET Core 入门教程 2.使用ASP.NET Core MVC框架构建Web应用 一.前言 1.本文主要内容 使用dotnet cli创建基于解决方案(sln+csproj)的项目 使用Visual Studio Code开发基于解决方案(sln+csproj)的项目 Visual Studio Code Solution插件( vscode-solution-explorer)基础使用介绍 基于 .NET Core web项目模板构建 ASP.NET Core MVC We

有Ceph、GlusterFS等分布式存储的实际开发和应用经验,Openstack Cinder框架、容器卷管理方案如Flocker

岗位职责:参与构建云存储服务,包括开发.设计和运维工作?. 任职要求:1.本科及以上,3年以上存储系开发.设计或运维工作经验:2.熟练操作Linux系统并对内核比较了解:对云计算.虚拟化有所了解:3.有Ceph.GlusterFS等分布式存储的实际开发和应用经验:4.至少精通JAVA.Python.Ruby.C/C++.Go等语言之一,具备较强的开发能力和技巧:5.有参与过云平台或大型互联网系统底层平台开发设计者优先:参与过开源代码项目贡献的优先:6.喜欢钻研技术,想从事云计算的开发设计和运维工

利用Laravel自带的Mail类发邮件

由于项目在运行过程中经常用到邮件检测报警的功能,而在之前我都是用shell脚本发送邮件.shell脚本的优点是可以直接处理服务器指令,但是其缺点就是处理数据的能力效率太低,取数据库的许多数据要先把数据写入文件里,然后每行读文件并且分割来取出你想要的数据,相对来说麻烦太多.所以本人就准备直接利用Laravel框架封装好的Mail类直接发邮件,而且php语言相对shell来说数据处理能力简直强太多,所以果断弃坑了. 首先新建一个Laravel项目,在其.env文件里找到MAIL相关值,配好邮件发送账

ASP.NET MVC+EF框架+EasyUI实现权限管理系列

http://www.cnblogs.com/hanyinglong/archive/2013/03/22/2976478.html ASP.NET MVC+EF框架+EasyUI实现权限管理系列之开篇 前言:博客又有一段时间没有更新了,心里感觉这段时间空空的,好像什么都没有学下,所以就想写博客,所以就有了这个系列,这里当然也要感谢大家了,因这个 项目我已经上传了,得到了很多网友的评价,也有好多人发邮件给我说这个框架容易出现问题,不能访问,这也是支持我写这个系列的动力,我将这个项目写成一个 系列

基于Spring4+SpringMVC4+Mybatis3+Hibernate4+Junit4框架构建高性能企业级的部标GPS监控平台

开发企业级的部标GPS监控平台,投入的开发力量很大,开发周期也很长,选择主流的开发语言以及成熟的开源技术框架来构建基础平台,是最恰当不过的事情,在设计之初就避免掉了技术选型的风险,避免以后在开发过程中,不断的填坑走弯路,以至于整个团队被坑埋掉.做GPS平台这么多年,以前就了解到一些开发团队过于关注某一种语言的优势,比如过于选用GO,Erlang,python,php等技术,最后团队熟悉这些技术的关键人员离职了,都没人接手,不能不说是个悲剧.所以说平台的技术架构选型要注重的是稳健,均衡而不是偏激,

利用Multipeer Connectivity框架进行WiFi传输-b

什么是Multipeer Connectivity? 在iOS7中,引入了一个全新的框架——Multipeer Connectivity(多点连接).利用Multipeer Connectivity框架,即使在没有连接到WiFi(WLAN)或移动网络(xG)的情况下,距离较近的Apple设备(iMac/iPad/iPhone)之间可基于蓝牙和WiFi(P2P WiFi)技术进行发现和连接实现近场通信. Multipeer Connectivity扩充的功能与利用AirDrop传输文件非常类似,可

ASP.NET MVC+EF框架+EasyUI实现权限管理

4.为什么使用MVC而不是用WebForm呢? (1)为什么使用MVC而不是用WebForm呢?这个是我临时想的,因为我就是想说明一下WebForm和MVC的优缺点,来可以使大家能够更好地理解 MVC和WebForm,而不像某些人说MVC会替代WebForm,我个人认为这个可能性很小,因为各有各的好处,看在哪里使用吧,下面我就简单介绍下 WebForm和MVC的优缺点. (2)WebForm介绍 1)优点 1):支持事件模型,取决于微软提供了丰富的服务器端组建,WebForm可以快速的搭建Web