美文网首页
9月17日知识点记录

9月17日知识点记录

作者: 默言1024 | 来源:发表于2017-09-17 17:26 被阅读0次

    一.Laravel控制器

    基础控制器(组织请求处理逻辑)

    通过路由来指定控制器行为:
    Route::get('user/{id}','UserController@showProfile');//路由所带参数也会被传递到showProfile方法
    命名控制器路由:
    Route::get('foo', ['uses' => 'FooController@method', 'as' => 'name']);
    $url = route('name')//生成命名控制器路由的 URL
    $url = action('FooController@method');//生成指向控制器行为的 URL
    $action = Route::currentRouteAction();//取到正在运行的控制器行为名称

    中间件和控制器:

    Route::get('profile', [
        'middleware' => 'auth',
        'uses' => 'UserController@showProfile'
    ]);//将 中间件 指定给控制器路由
    

    在控制器构造器中使用 middleware 方法,你可以很容易地将中间件指定给控制器。你甚至可以对中间件作出限制,仅将它提供给控制器类中的某些方法。

     public function __construct()
        {
            $this->middleware('auth');
    
            $this->middleware('log', ['only' => ['fooAction', 'barAction']]);
    
            $this->middleware('subscribed', ['except' => ['fooAction', 'barAction']]);
    }
    

    RESTful 资源控制器资源

    控制器让你可以轻松地创建与资源相关的 RESTful 控制器,
    使用 make:controller Artisan 命令,我们可以快速地创建一个像这样的控制器
    php artisan make:controller 控制器名称
    Route::resource('photos', 'PhotosController');//在控制器中注册资源化路由
    这一条路由声明会创建多个路由,用来处理各式各样和相片资源相关的的 RESTful 行为。同样地,生成的控制器有着各种和这些行为绑定的方法,包含要处理的 URI 及方法对应的注释。
    由资源控制器处理的行为:

    动词 路径 行为(方法) 路由名称
    GET /photos index photo.index
    GET /photos/create create photos.create
    POST /photos store photos.store
    GET /photos/{photo} show photos.show
    GET /photos/{photo}/edit edit photos.edit
    PUT/PATCH /photos/{photo} update photos.update
    DELETE /photos/{photo} destroy photos.destroy

    部分资源路由:(声明资源路由时,你可以指定让此路由仅处理一部分的行为)

    Route::resource('photos', 'PhotosController',
                    ['only' => ['index', 'show']]);
    Route::resource('photos', 'PhotosController',
                    ['except' => ['create', 'store', 'update', 'destroy']]);
    

    命名资源路由(所有的资源控制器行为默认都有路由名称;不过你可以在选项中传递一个 names 数组来重写这些名称)
    Route::resource('photos', 'PhotosController', ['names' => ['create' => 'photo.build']]);
    嵌套资源(有时你可能会需要定义「嵌套」资源路由。例如,相片资源可能会附带多个「评论」。要「嵌套」此资源控制器,可在路由声明中使用「点」记号)
    Route::resource('photos.comments', 'PhotoCommentController');//photos/{photos}/comments/{comments}通过类示URL访问
    附加资源控制器(如果想在资源控制器中默认的资源路由之外加入其它额外路由,则应该在调用 Route::resource 之前 定义这些路由。否则,由 resource 方法定义的路由可能会不小心覆盖你附加的路由)

    隐式控制器

    通过定义单个路由来处理控制器类中的各种行为,
    使用 Route::controller 方法来定义路由
    Route::controller('users', 'UserController');//controller 方法接受两个参数。第一个参数是控制器所处理的基本 URI,第二个是控制器的类名称
    只要在控制器中加入方法。方法的名称应由它们所响应的 HTTP 动词作为开头,紧跟着首字母大写的 URI 所组成

    <?php
    namespace App\Http\Controllers;
    
    class UserController extends Controller
    {
        /**
        * 响应对 GET /users 的请求
         */
        public function getIndex()
       {
            //
        }
    
        /**
         * 响应对 GET /users/show/1 的请求
         */
        public function getShow($id)
        {
            //
        }
    
        /**
         * 响应对 GET /users/admin-profile 的请求
         */
        public function getAdminProfile()
        {
            //
        }
    
        /**
         * 响应对 POST /users/profile 的请求
         */
        public function postProfile()
        {
            //
        }
    }
    

    分派路由名称
    命名控制器中的某些路由,可以在 controller 方法中传入一个名称数组作为第三个参数
    Route::controller('users', 'UserController', [ 'getShow' => 'user.show', ]);

    依赖注入与控制器

    构造器注入
    方法注入...都不太懂

    路由缓存

    若你的应用程序完全通过控制器使用路由,你可以利用 Laravel 的路由缓存。使用路由缓存可以大幅降低注册全部路由所需的时间。
    要生成路由缓存,只要运行 route:cache 此 Artisan 命令
    php artisan route:cache
    这就可以了!现在你的缓存路由文件将被用来代替 app/Http/routes.php 这一文件。请记得,若你添加了任何新的路由,就必须生成新的路由缓存。因此你可能希望只在你的项目部署时才运行 route:cache 这一命令。
    要移除缓存路由文件而不生成新的缓存,请使用 route:clear 命令
    php artisan route:clear

    二.Laravel请求

    获取请求:要通过依赖注入的方式获取 HTTP 请求的实例,就必须在控制器的构造器或方法中,使用 Illuminate\Http\Request 类型提示

    public function store(Request $request)
    {
        $name = $request->input('name');
    
        //
    }
    

    如果控制器方法也有输入数据是从路由参数传入的,只需将路由参数置于其它依赖之后
    EP:Route::put('user/{id}', 'UserController@update');

    public function update(Request $request, $id)
    {
        //
    }
    

    基本请求信息:Illuminate\Http\Request 的实例提供了多种方法来用于检查应用程序的 HTTP 请求。Larevel 的 Illuminate\Http\Request 继承了 Symfony\Component\HttpFoundation\Request 类
    获取请求的 URI

    $uri = $request->path();//path 方法会返回请求的 URI;
    if ($request->is('admin/*')) {
         //is 方法可以验证接收到的请求 URI 与指定的规则是否相匹配,*号为通配符
    }
    $url = $request->url();//使用 url 方法,可以获取完整的网址
    

    获取请求的方法

    $method = $request->method();//method方法会返回此次请求的http动作
    if ($request->isMethod('post')) {
        //isMethod方法来验证http动作是否和指定的字符串是否相匹配
    }
    

    获取输入数据

    特定值:$request->input('name');``$request->字段名;
    $request->input('name', 'Sally');//第二个参数中传入一个默认值。当请求的输入数据不存在于此次请求时,就会返回默认值
    $request->input('products.0.name');//如果是「数组」形式的输入数据,则可以使用「点」语法来获取数组
    $request->has('name')//确认是否有值
    $input = $request->all();//获取所有输入数据
    如果想获取输入数据的子集,则可以使用 only 及 except 方法。这两个方法都接受单个数组或是动态列表作为参数
    $input = $request->only(['username', 'password']); $input = $request->only('username', 'password'); $input = $request->except(['credit_card']); $input = $request->except('credit_card');
    旧输入数据:Laravel 可以让你将本次的输入数据保留到下一次请求发送前。对于在表单验证失败后重新填入表单值相当有用
    将输入数据闪存至 Session$request->flash();
    $request->flashOnly('username', 'email'); $request->flashExcept('password');//数据的子集保存至 Session
    闪存输入数据至 Session 后重定向return redirect('form')->withInput(); return redirect('form')->withInput($request->except('password'));
    获取旧输入数据->若要获取上一次请求后所闪存的输入数据,则可以使用Request
    实例中的old方法。old方法提供一个简便的方式从 Session 取出被闪存的输入数据
    $username = $request->old('username');
    Laravel 也提供了全局辅助函数old。如果你要在 Blade 模板 中显示旧输入数据,可以使用更加方便的old辅助函数{{ old('username') }}
    从请求中取出Cookie值$value = $request->cookie('name');

    上传文件

    获取上传文件,可以使用 Illuminate\Http\Request 实例中的 file 方法获取上传的文件。file 方法返回的对象是 Symfony\Component\HttpFoundation\File\UploadedFile 类的实例,该类继承了 PHP 的 SplFileInfo 类,并提供了许多和文件交互的方法
    $file = $request->file('photo');
    $request->hasFile('photo')//确认上传的文件是否存在
    $request->file('photo')->isValid()//验证上传的文件是否有效
    $request->file('photo')->move($destinationPath); $request->file('photo')->move($destinationPath, $fileName);//将文件从缓存位置(由你的 PHP 配置决定)移动至你指定的永久保存位置

    三.视图

    视图包含你应用程序所用到的 HTML,它能够将控制器和应用程序逻辑在呈现逻辑中进行分离。视图被存在 resources/views 目录下
    因为这个视图被保存在 resources/views/greeting.php,所以我们可以像这样使用全局的辅助函数 view 来返回
    Route::get('/', function () { return view('greeting', ['键' => '值']); });//view 辅助函数的第一个参数会对应到 resources/views 目录内视图文件的名称;传递到 view 辅助函数的第二个参数是一个能够在视图内取用的数据数组
    视图文件也可以被存放在 resources/views 的子目录内。. (小数点)的表示法可以被用来表示在子目录内的视图文件
    return view('home.user.index', $data);
    判断视图文件是否存在
    view()->exists('emails.customer')//在视图文件存在时返回 true
    return view('greetings', ['name' => 'Victoria']);//传递一个数组的数据给视图
    $view = view('greeting')->with('name', 'Victoria');//使用 with 来传递额外数据给视图

    相关文章

      网友评论

          本文标题:9月17日知识点记录

          本文链接:https://www.haomeiwen.com/subject/kdppsxtx.html