摘要:路由定義文件定義下的所有的路由文件都是有效的定義路由必須使用控制器定義修改配置文件,強制路由訪問此時已經(jīng)開啟多應(yīng)用配置目錄文件如下修改配置文件,啟用路由
路由定義文件
route 定義下的所有的路由文件都是有效的
定義路由必須使用
use thinkfacadeRoute;
控制器定義
修改配置文件,強制路由訪問
此時已經(jīng)開啟多應(yīng)用配置
目錄文件如下
修改配置文件,啟用路由
// +---------------------------------------------------------------------- // +---------------------------------------------------------------------- // | 應(yīng)用設(shè)置 // +---------------------------------------------------------------------- use thinkfacadeEnv; return [ // 應(yīng)用地址 "app_host" => Env::get("app.host", ""), // 應(yīng)用Trace(環(huán)境變量優(yōu)先讀?。? "app_trace" => false, // 應(yīng)用的命名空間 "app_namespace" => "", // 是否啟用路由 "with_route" => true, // 是否啟用事件 "with_event" => true, // 自動多應(yīng)用模式 "auto_multi_app" => true, // 應(yīng)用映射(自動多應(yīng)用模式有效) "app_map" => [], // 域名綁定(自動多應(yīng)用模式有效) "domain_bind" => [], // 禁止URL訪問的應(yīng)用列表(自動多應(yīng)用模式有效) "deny_app_list" => [], // 默認應(yīng)用 "default_app" => "index", // 默認時區(qū) "default_timezone" => "Asia/Shanghai", // 默認驗證器 "default_validate" => "", // 異常頁面的模板文件 "exception_tmpl" => app()->getThinkPath() . "tpl/think_exception.tpl", // 錯誤顯示信息,非調(diào)試模式有效 "error_message" => "頁面錯誤!請稍后再試~", // 顯示錯誤信息 "show_error_msg" => true, ];再次修改配置文件,強制路由
// +---------------------------------------------------------------------- // +---------------------------------------------------------------------- // | 應(yīng)用設(shè)置 // +---------------------------------------------------------------------- return [ // PATHINFO變量名 用于兼容模式 "var_pathinfo" => "s", // 兼容PATH_INFO獲取 "pathinfo_fetch" => ["ORIG_PATH_INFO", "REDIRECT_PATH_INFO", "REDIRECT_URL"], // pathinfo分隔符 "pathinfo_depr" => "/", // HTTPS代理標識 "https_agent_name" => "", // URL偽靜態(tài)后綴 "url_html_suffix" => "html", // URL普通方式參數(shù) 用于自動生成 "url_common_param" => true, // 是否開啟路由延遲解析 "url_lazy_route" => false, // 是否強制使用路由 "url_route_must" => true, // 合并路由規(guī)則 "route_rule_merge" => false, // 路由是否完全匹配 "route_complete_match" => false, // 使用注解路由 "route_annotation" => false, // 是否開啟路由緩存 "route_check_cache" => false, // 路由緩存連接參數(shù) "route_cache_option" => [], // 路由緩存Key "route_check_cache_key" => "", // 訪問控制器層名稱 "controller_layer" => "controller", // 空控制器名 "empty_controller" => "Error", // 是否使用控制器后綴 "controller_suffix" => false, // 默認的路由變量規(guī)則 "default_route_pattern" => "[w.]+", // 域名根,如thinkphp.cn "url_domain_root" => "", // 是否自動轉(zhuǎn)換URL中的控制器和操作名 "url_convert" => true, // 表單請求類型偽裝變量 "var_method" => "_method", // 表單ajax偽裝變量 "var_ajax" => "_ajax", // 表單pjax偽裝變量 "var_pjax" => "_pjax", // 是否開啟請求緩存 true自動緩存 支持設(shè)置請求緩存規(guī)則 "request_cache" => false, // 請求緩存有效期 "request_cache_expire" => null, // 全局請求緩存排除規(guī)則 "request_cache_except" => [], // 默認控制器名 "default_controller" => "Index", // 默認操作名 "default_action" => "index", // 操作方法后綴 "action_suffix" => "", // 默認JSONP格式返回的處理方法 "default_jsonp_handler" => "jsonpReturn", // 默認JSONP處理方法 "var_jsonp_handler" => "callback", ];再次定義admin下的路由
此時訪問 http://localhost:8082/admin/ming/34
已經(jīng)開始路由
正常訪問
沒有路由
此時開啟強制路由以后,首頁需要開啟路由
由于默認的應(yīng)用為index 所以需要在route定義index
目錄如下
定義首頁目錄
此時訪問首頁
變量規(guī)則
http://localhost:8082/
會被重定向到 index控制器下的index方法變量規(guī)則,這里定義的是
Route::get("new/:name", "News/read") ->pattern(["name" => "[w|-]+"]);此時匹配的是name變量的匹配的規(guī)則,匹配的規(guī)則是雙斜杠
路由規(guī)則// 定義動態(tài)路由 Route::get("hello/:name", "index/:name/hello");可以做到把一個變量傳入另外一個路由中
路由地址路由到控制器的操作
添加一個控制器此控制器使用appadmincontroller 命名空間 其文件內(nèi)容如下
傳入$id作為參數(shù)
再次定義路由規(guī)則如下
Route::get("blog/:id", "Blog/read");此時訪問admin模塊下的blog內(nèi)容,會匹配:id的內(nèi)容,
http://localhost:8082/admin/blog/23/ 此時會匹配23內(nèi)容其結(jié)果如下
路由地址 路由到控制器操作路由到控制器和操作
上面的例子就是
路由到類的方法這種方式可以執(zhí)行任何方法
Route::get("blog/:id","appindexserviceBlog@read");Route::get("blog/:id","appindexserviceBlog::read");上方執(zhí)行的是Blog的read方法或者read的靜態(tài)方法
重定向路由Route::redirect("blog/:id", "http://blog.thinkphp.cn/read/:id", 302);使用302重定向一個新的地址
路由到模板使用路由到模板直接渲染
訪問 http://localhost:8082/admin/blog/ 此時會渲染出
閉包支持使用閉包可以使用一些特殊需求的路由,不需要再次執(zhí)行控制器的操作了
http://localhost:8082/admin/blog/34
閉包中可以實現(xiàn)依賴注入
method(); return $method . $name; });此時由于依賴request會自動注入request
路由參數(shù)對當前的路由進行匹配。。
ext("html") // url 后綴檢測 ->https(); // https 檢測只有全部符合要求才能匹配到
額外追加參數(shù)使用append額外追加參數(shù)
append( ["app_id" => 1, "status" => 1] );此時會傳入兩個參數(shù) app_id 和 status 兩個參數(shù)
綁定模型支持綁定模型
Route::get("hello/:id", "index/hello") ->model("appindexmodelUser");支持從模型層中直接獲取數(shù)據(jù)
同時可以使用閉包,獲取數(shù)據(jù)
Route::rule("hello/:id", "index/hello") ->model(function ($id) { $model = new appindexmodelUser; return $model->where("id", $id)->find(); });請求緩存Route::get("new/:name$", "News/read") ->cache(3600);表示直接請求3600秒
路由中間件可以在路由中,數(shù)據(jù)直接傳給中間件
路由分組可以對公有的路由進行分組操作
ext("html")->pattern([ "id" => "d+", "name" => "w+" ]);此時,可以根據(jù)正則匹配路由
資源路由此時訪問
資源嵌套
http://localhost:8082/admin/blog/34/edit 會調(diào)用edit方法
http://localhost:8082/admin/blog/34/read 會調(diào)用read方法路由支持資源嵌套
注解路由修改配置文件,實現(xiàn)注解路由
// +---------------------------------------------------------------------- // +---------------------------------------------------------------------- // | 應(yīng)用設(shè)置 // +---------------------------------------------------------------------- return [ // PATHINFO變量名 用于兼容模式 "var_pathinfo" => "s", // 兼容PATH_INFO獲取 "pathinfo_fetch" => ["ORIG_PATH_INFO", "REDIRECT_PATH_INFO", "REDIRECT_URL"], // pathinfo分隔符 "pathinfo_depr" => "/", // HTTPS代理標識 "https_agent_name" => "", // URL偽靜態(tài)后綴 "url_html_suffix" => "html", // URL普通方式參數(shù) 用于自動生成 "url_common_param" => true, // 是否開啟路由延遲解析 "url_lazy_route" => false, // 是否強制使用路由 "url_route_must" => true, // 合并路由規(guī)則 "route_rule_merge" => false, // 路由是否完全匹配 "route_complete_match" => false, // 使用注解路由 "route_annotation" => true, // 是否開啟路由緩存 "route_check_cache" => false, // 路由緩存連接參數(shù) "route_cache_option" => [], // 路由緩存Key "route_check_cache_key" => "", // 訪問控制器層名稱 "controller_layer" => "controller", // 空控制器名 "empty_controller" => "Error", // 是否使用控制器后綴 "controller_suffix" => false, // 默認的路由變量規(guī)則 "default_route_pattern" => "[w.]+", // 域名根,如thinkphp.cn "url_domain_root" => "", // 是否自動轉(zhuǎn)換URL中的控制器和操作名 "url_convert" => true, // 表單請求類型偽裝變量 "var_method" => "_method", // 表單ajax偽裝變量 "var_ajax" => "_ajax", // 表單pjax偽裝變量 "var_pjax" => "_pjax", // 是否開啟請求緩存 true自動緩存 支持設(shè)置請求緩存規(guī)則 "request_cache" => false, // 請求緩存有效期 "request_cache_expire" => null, // 全局請求緩存排除規(guī)則 "request_cache_except" => [], // 默認控制器名 "default_controller" => "Index", // 默認操作名 "default_action" => "index", // 操作方法后綴 "action_suffix" => "", // 默認JSONP格式返回的處理方法 "default_jsonp_handler" => "jsonpReturn", // 默認JSONP處理方法 "var_jsonp_handler" => "callback", ];添加注解,實現(xiàn)路由
路由綁定支持綁定到控制器操作,命名空間,和類
// 綁定當前的URL到 Blog控制器 Route::bind("blog"); // 綁定當前的URL到 Blog控制器的read操作 Route::bind("blog/read");原先訪問 http://serverName/blog/read/id/5
需要訪問 http://serverName/read/id/5 可以訪問到剩下的還可以綁定到命名空間 類
域名路由使用 Route::domain 綁定子域
路由緩存過
MISS 路由MISS路由為全局最后一條執(zhí)行的路由
跨域請求通過allowCrossDomain 進行跨域請求
URL請求用于生成url請求
路由規(guī)則5, "name" => "ming"])); return $id; } }
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/31606.html
摘要:杰出的數(shù)據(jù)庫遷移工具和緊密集成的單元測試支持,這些工具賦予你構(gòu)建任何應(yīng)用的能力。淺談應(yīng)公司要求,現(xiàn)在用重新搭一個框架,接觸了幾天對它也有了一定的了解。淺談支持,支持單元測試。更加嚴謹了,異常嚴謹?shù)腻e誤檢測和安全機制。 自從接觸php開始,用的就是thinkphp框架,它給我的感覺是輕量,且容易上手。后來進了一家外包公司又用了laravel框架,個人覺得laravel還是很高大上的,功能...
在ThinkPHP中我們使用偽靜態(tài)的時候會產(chǎn)生一些問題,從而不能夠很方便在用apache的rewrite規(guī)則來解決,不過官方因為這個問題給大家提供了一種高級解決方案就是route 我在使用ThinkPHP做項目的時候遇到這樣的事情 route的規(guī)則是要匹配一下控制器 這就是官方在路由的例子里面為什么不使用別的方式,我也納悶官方為什么沒有解決這個問題 看官方的例子,然后我在寫我的需求 ...
摘要:抽象數(shù)據(jù)庫訪問層作用對不同數(shù)據(jù)庫的操作進行封裝,最終達到用統(tǒng)一的操作方式操作不同數(shù)據(jù)庫連接器隱藏不同數(shù)據(jù)庫連接的差異,自動加載對應(yīng)的數(shù)據(jù)庫驅(qū)動查詢構(gòu)建起隱藏不同數(shù)據(jù)庫的差異,自動拼接路由層什么是路由每個框架都具有路由功能,所謂路由就是用戶請 抽象數(shù)據(jù)庫訪問層 作用:對不同數(shù)據(jù)庫的操作進行封裝,最終達到:用統(tǒng)一的操作方式操作不同數(shù)據(jù)庫 連接器:隱藏不同數(shù)據(jù)庫連接的差異,自動加載對應(yīng)的數(shù)...
摘要:源碼分析開門篇生命周期入口文件用戶發(fā)起的請求都會經(jīng)過應(yīng)用的入口文件,通常是文件。注冊錯誤和異常機制執(zhí)行注冊錯誤和異常處理機制。由三部分組成應(yīng)用關(guān)閉方法錯誤處理方法異常處理方法注冊應(yīng)用關(guān)閉方法是為了便于攔截一些系統(tǒng)錯誤。 源碼分析—開門篇 thinkphp生命周期 1、入口文件 用戶發(fā)起的請求都會經(jīng)過應(yīng)用的入口文件,通常是 ==public/index.php==文件。當然,你也可以更改...
摘要:如上為三個模塊行為行為是在預(yù)先定義好的一個應(yīng)用位置執(zhí)行的一些操作。發(fā)生作用的位置稱之為鉤子,當應(yīng)用程序運行到這個鉤子的時候,就會被攔截下來,統(tǒng)一執(zhí)行相關(guān)的行為。給某一個鉤子綁定相關(guān)行為就成了一種類編程的思想。 ThinkPhp5.0 Composer: php世界里的包管理器 目錄結(jié)構(gòu) project 應(yīng)用部署目錄 ├─application 應(yīng)用目錄(可設(shè)置) ...
摘要:異常處理上節(jié)解讀源碼一自動加載看完了自動加載部分,根據(jù)代碼執(zhí)行順序,的行注冊錯誤和異常處理機制加載慣例配置文件下面的加載配置文件不用說,現(xiàn)在重點看一下異常處理。博客鏈接解讀源碼二異常處理和請求生命周期 異常處理 上節(jié)解讀 thinkphp5 源碼(一):自動加載看完了自動加載部分,根據(jù)代碼執(zhí)行順序,base.php的59-64行 // 注冊錯誤和異常處理機制 hinkError::r...
閱讀 3500·2019-08-30 15:53
閱讀 3414·2019-08-29 16:54
閱讀 2202·2019-08-29 16:41
閱讀 2412·2019-08-23 16:10
閱讀 3384·2019-08-23 15:04
閱讀 1355·2019-08-23 13:58
閱讀 355·2019-08-23 11:40
閱讀 2459·2019-08-23 10:26