欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Laravel5.1 框架控制器基础用法实例分析

程序员文章站 2022-10-15 09:58:28
本文实例讲述了laravel5.1 框架控制器基础用法。分享给大家供大家参考,具体如下: 为什么要使用控制器 像我们之前写一些逻辑呢都是在route(路由)中,搞得route文件特...

本文实例讲述了laravel5.1 框架控制器基础用法。分享给大家供大家参考,具体如下:

为什么要使用控制器

像我们之前写一些逻辑呢都是在route(路由)中,搞得route文件特别庞大,其实我们应该把这些逻辑都抽到一个控制器里,路由分发后到控制器,控制器做相应的操作,比如关于后台的逻辑应该抽到admincontroller中,route文件只管分发。

1 如何创建一个控制器

1.1.1 创建restful控制器

至于什么是restful?自行百度- -,我先简单说下,它里面自动填充了一些增删改查的方法。ok 我们在artisan控制台创建:

php artisan make:controller admin\\homecontroller

然后 我们在 app/http/controller/admin/ 下找到它:

class homecontroller extends controller
{
  /**
   * display a listing of the resource.
   *
   * @return \illuminate\http\response
   */
  public function index()
  {
  }
  /**
   * show the form for creating a new resource.
   *
   * @return \illuminate\http\response
   */
  public function create()
  {
    //
  }
  /**
   * store a newly created resource in storage.
   *
   * @param \illuminate\http\request $request
   * @return \illuminate\http\response
   */
  public function store(request $request)
  {
    //
  }
  /**
   * display the specified resource.
   *
   * @param int $id
   * @return \illuminate\http\response
   */
  public function show($id)
  {
    //
  }
  /**
   * show the form for editing the specified resource.
   *
   * @param int $id
   * @return \illuminate\http\response
   */
  public function edit($id)
  {
    //
  }
  /**
   * update the specified resource in storage.
   *
   * @param \illuminate\http\request $request
   * @param int $id
   * @return \illuminate\http\response
   */
  public function update(request $request, $id)
  {
    //
  }
  /**
   * remove the specified resource from storage.
   *
   * @param int $id
   * @return \illuminate\http\response
   */
  public function destroy($id)
  {
    //
  }
}

每个方法就是它的字面意思,至于怎么使用,我们来注册一条路由就清楚了。

1.1.2 实现restful路由

route::group(['prefix' => 'admin', 'namespace' => 'admin'], function (){
  route::resource('/', 'homecontroller');
});

resource是为restful风格的控制器注册多条路由的 我们可以在artisan控制台看看:

php artisan route:list

如果没有什么错误的话,咱肯定会看见打印出来的表,表里面标明了每条路由的属性,如果你还是不太明白,那无所谓~咱以后的文章会频繁使用到这些内容哦。

1.2.1 普通控制器

在实际开发中啊 有时候咱不一定需要restful风格的服务器,我们只想要一个空的控制器来自己实现一些方法,可以这么生成:

php artisan make:controller usercontroller --plain

只要后面跟个plain标识符 就可以生成空的控制器啦。

1.2.2 单条路由使用控制器

上面是使用resource方法来对应控制器的动作了,像这种空的控制器咱怎么在路由中使用呢?

/**
 * 控制器名@方法名 就可以了
 */
route::get('/user', 'usercontroller@index');
/**
 * 这是在配置一些其他东西时的写法,因为要在数组中嘛,它对应的key是uses。
 */
route::get('/user', ['as' => 'showuser', 'uses' => 'usercontroller@index']);

然后自行实现usercontroller的index方法就可以咯:

class usercontroller extends controller
{
  public function index()
  {
    return '展示一些东西';
  }
}

1.3.1 其实还有另一种写法 隐式控制器

这种路由我不太常用 先来看看语法吧:

route::controller('/user', 'usercontroller');

首先 使用了controller来注册路由,第一个参数是路径没新鲜的,第二个参数是控制器 但是它没有跟着方法。因为它能自动根据路径相应到方法 看看下面控制器方法的实现。

class usercontroller extends controller
{
  /**
   * 对应着 /user/ 路由 get方式
   */
  public function getindex()
  {
    return '展示一些东西~';
  }
  /**
   * 对应着 /user/show/{id} 路由 get方式
   */
  public function getshow($id)
  {
    return '此用户id为: '.$id;
  }
  /**
   * 对应着 /user/update/{id} 路由 post方式
   */
  public function postupdate($id, requests\request $request){
  }
}

这个控制器的方法开头都是http请求的方式 最常用的就是get 和 post 后面跟的是方法名字,具体对应的路径在注释中写清楚了。

如果你想给这些路由命名的话,后面可以跟一个数组来命名:

route::controller('/user', 'usercontroller',['getshow' => 'user.show']);

这样就可以给对应的方法命名了,oh funk 大k真的不喜欢这种方式,也许是没明白这样写的真谛把。

--今天关于控制器就先写这么多吧,具体逻辑实现咱还得学一些新的知识来结合使用,比如middleware啊和request还有blade模板引擎,但都不是很难~