本文主要给大家介绍了关于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