本文主要给大家介绍了关于Laravel从入口到输出过程的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。
I. 预备知识
Laravel 目录
1
|
/path/to |
后面简称 Laravel
Web 目录
1
|
Laravel/public |
后面简称 Web
入口文件
1
|
Web/index.php |
II. 过程详解
范例: http://la.com/test/yueshu/female/20?name=chenxuelong
1. 定义 web 路由
文件路径:
1
|
Laravel/routes/web.php |
修改如下:
1
|
Route::get( '/test/{name}/{sex}/{age}' , 'TestController@test' ) |
2. 定义中间件
2.1 中间件路径:
1
|
Laravel/app/Http/Middleware |
2.2 新建中间件 Test.php:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
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 注册中间件
中间件配件文件路径:
1
|
Laravel/app/Http/Kernel.php |
在 routeMiddleware 键名下新增:
1
|
'Test' => \App\Http\Middleware\Test:: class |
4. 表单验证(请求)
文件存放目录:
1
|
Laravel/app/Http/Requests |
新建 FormValidate.php 验证类:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
/** * 验证不通过时,通过 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. 模型
文件路径:
1
|
Laravel/app |
新建模型 Test.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
|
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. 控制器
控制器路径:
1
|
Laravel/app/Http/Controllers |
新建控制器 TestController.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
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. 视图
视图路径:
1
|
Laravel/resource/views |
新建 test.blade.php 视图文件
1
|
< h1 >Laravel 从入口到输出解析完毕!</ h1 > |
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。
原文链接:https://segmentfault.com/a/1190000010862139