这篇文章主要介绍Laravel中之从入口到输出的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
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 视图文件
<h2>Laravel 从入口到输出解析完毕!</h2>
以上是“Laravel中之从入口到输出的示例分析”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。