解决nginx不支持thinkphp中pathinfo的问题
424
2023-12-08
本文主要给大家介绍了关于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 AppHttpMiddleware; 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' => AppHttpMiddlewareTest::class
4. 表单验证(请求)
文件存放目录:
Laravel/app/Http/Requests
新建 FormValidate.php 验证类:
/** * 验证不通过时,通过 header 中的 referer 重定向到 * 上一页 */ namespace AppHttpRequests; use IlluminateFoundationHttpFormRequest; 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 IlluminateDatabaseEloquentModel; 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 AppHttpControllers; use AppHttpControllersController; // 引入请求验证类 use AppHttpRequestsFormValidate; /* 可选注入模型类(分层) * 这边引入了一个 Test 模型类 */ use AppTest; 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>
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对绿夏网的支持。
#免责声明#
本站[绿夏技术导航]提供的一切软件、教程和内容信息仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络收集整理,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑或手机中彻底删除上述内容。如果您喜欢该程序或内容,请支持正版,购买注册,得到更好的正版服务。我们非常重视版权问题,如有侵权请邮件[admin@lxwl520.com]与我们联系进行删除处理。敬请谅解!