Laravel 从入口到输出过程详解

代码逐梦号说
• 阅读 4155

I. 预备知识

Laravel 目录

/path/to

后面简称 Laravel

Web 目录

Laravel/public

后面简称 Web

入口文件

Web/index.php

II. 过程详解

范例: http://la.com/test/yueshu/female/20?name=chenxuelong

1. 定义 web 路由

文件路径:

Laravel/routes/web.php

修改如下:

Route::get('/test/{name}/{sex}/{age}' , 'TestController@test')

2. 定义中间件

2.1 中间件路径:

Laravel/app/Http/Middleware

2.2 新建中间件 Test.php

namespace App\Http\Middleware;

use Closure;

class Test {
    /**
     * 必须返回响应(response)
     */
    public function handle($request , Closure $next){
        // 在处理请求之前做些什么...
        
        $response = $next($request);
        
        // 在处理请求之后做些什么
        
        return $response;
    }
    
    /**
     * 中间件处理完毕后,做些什么
     */
    public function terminate($request , $response){
        // 中间件处理完毕后,做些什么....
    }
}

2.3 注册中间件

中间件配件文件路径:

Laravel/app/Http/Kernel.php

routeMiddleware 键名下新增:

'Test' => \App\Http\Middleware\Test::class

4. 表单验证(请求)

文件存放目录:

Laravel/app/Http/Requests

新建 FormValidate.php 验证类:

/**
 * 验证不通过时,通过 header 中的 referer 重定向到
 * 上一页
 */
namespace App\Http\Requests;

use Illuminate\Foundation\Http\FormRequest;

class FormValidate extends FormRequest {
    // 是否经过授权的访问
    public function authorize(){
        return true;
    }  
    
    // 验证规则
    public function rules(){
        /**
         * required 表示必须
         * max:255  最大长度 255
         */
        return [
            'name' => 'required|max:255'
        ];
    }
}

5. 模型

文件路径:

Laravel/app

新建模型 Test.php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Test extends Model {

    // 获取某张表的所有数据(查询构造器)
    public function get($table){
        \DB::table($table)->get();
    }
    
    // 获取(原生 sql)
    public function select($sql , $params){
        \DB::select($sql , $params);
    }
    
    // 插入(原生 sql)
    public functioin insert($sql , $params){
        \DB::insert($sql , $params);
    }
    
    // 更新(原生 sql)
    public function update($sql , $params){
        \DB::update($sql , $params);
    }
    
    // 删除(原生 sql)
    public function delete($sql , $params){
        \DB::delete($sql , $params);
    }
    
    // 执行通用 sql(原生 sql)
    public function statement($sql , $params){
        \DB::statement($sql , $params);
    }
    
    // 事务
    public function transaction($sql , callable $callback){
        \DB::transaction($sql , $callback):
    }
    
    // 手动开启事务
    public function beginTransaction(){
        \DB::beginTransaction();
    }
    
    // 手动回滚
    public function rollBack(){
        \DB::rollBack();
    }
    
    // 提交
    public function commit(){
        \DB::commit();
    }
    
    
}

6. 控制器

控制器路径:

Laravel/app/Http/Controllers

新建控制器 TestController.php

namespace App\Http\Controllers;

use App\Http\Controllers\Controller;

// 引入请求验证类
use App\Http\Requests\FormValidate;

/* 可选注入模型类(分层)
 * 这边引入了一个 Test 模型类
 */
use App\Test;

class TestController extends Controller {

    // 构造器(可以添加中间件 或 注入)
    function __construct(Test $test){
        // 添加先前注册的中间件
        $this->middleware('Test');
        
        // 注入模型类
        $this->test = $test;
    }
    
    /**
     * 路由中设置的动作名称
     * 通过类型提示,引入请求验证
     */
    public function test(FormValidate $request , $name , $sex , $age){
        // 通过验证的请求.....
        $data = [];
        
        if (view()->exists('test')) {
            view('test' , $data);
        } else {
            exit('模板文件不存在....');
        }
    }
}

7. 视图

视图路径:

Laravel/resource/views

新建 test.blade.php 视图文件

<h1>Laravel 从入口到输出解析完毕!</h1>
点赞
收藏
评论区
推荐文章
blmius blmius
4年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
美凌格栋栋酱 美凌格栋栋酱
7个月前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
Stella981 Stella981
3年前
InsightFace源码以及pre
一下摘自:https://blog.csdn.net/Fire\_Light\_/article/details/79602705(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fblog.csdn.net%2FFire_Light_%2Farticle%2Fdetails%2F7960
Stella981 Stella981
3年前
KaliTools说明书+BurpSuit实战指南+SQL注入知识库+国外渗透报告
!(https://oscimg.oschina.net/oscnet/d1c876a571bb41a7942dd9752f68632e.gif"15254461546.gif")0X00KaliLinux Tools中文说明书!(https://oscimg.oschina.net/oscnet/
Easter79 Easter79
3年前
TiDB Pre
8月30日,TiDB发布PreGA版。该版本对MySQL兼容性、SQL优化器、系统稳定性、性能做了大量的工作。TiDB:SQL查询优化器调整代价模型优化索引选择,支持不同类型字段比较的索引选择支持基于贪心算法的JoinReorder
Stella981 Stella981
3年前
Jenkins配置下拉菜单联动效果
  在使用Jenkins集成时,经常需要配置一些环境信息,由于测试、线上、预发布需要切换环境和域名,需要在Jenkins中配置下拉菜单联动效果。  首先选择参数化构建过程,然后首先配置环境,环境分为:测试环境、预发布环境、正式环境,选择的组件为ChoiceParameter,Name定义为environment,选项为test、pre、onli
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
PHP创建多级树型结构
<!lang:php<?php$areaarray(array('id'1,'pid'0,'name''中国'),array('id'5,'pid'0,'name''美国'),array('id'2,'pid'1,'name''吉林'),array('id'4,'pid'2,'n
Stella981 Stella981
3年前
Pre
PAT甲级1119,我先在CSDN上面发布的这篇文章:https://blog.csdn.net/weixin\_44385565/article/details/89737224(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fblog.csdn.net%2Fweixin_443855
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这
代码逐梦号说
代码逐梦号说
Lv1
近乡情更怯,不敢问来人。
文章
4
粉丝
0
获赞
0