前言
本文主要給大家介紹了修改Laravel中url()函數(shù)生成URL的根地址的相關(guān)內(nèi)容,相信大家都曉得 Larevel 的一票幫助函數(shù)中有個(gè) url(),可以通過給予的目錄生成完整的 URL,是非常方便的一個(gè)函數(shù):
// return: https://skin.dev/user/profileurl('user/profile')但是這玩意生成的 URL 中要補(bǔ)完的部分是框架內(nèi)部根據(jù) Request 自動判斷的,而自動判斷出的東西有時(shí)候會出錯(cuò)(譬如在套了一層反向代理之類的情況下)。
文檔上并沒有提到我們要如何才能自定義它生成的 URL 中的根地址和協(xié)議頭部分(http(s)),這就非常吃癟了。那我們要咋辦呢?
首先我們來看看 url() 被定義的位置:
# File: src/Illuminate/Foundation/helpers.php/** * Generate a url for the application. * * @param string $path * @param mixed $parameters * @param bool $secure * @return Illuminate/Contracts/Routing/UrlGenerator|string */function url($path = null, $parameters = [], $secure = null){ if (is_null($path)) { return app(UrlGenerator::class); } return app(UrlGenerator::class)->to($path, $parameters, $secure);}可以看到,它從 Laravel 的服務(wù)容器中解析出了一個(gè) Illuminate/Contracts/Routing/UrlGenerator,并且把參數(shù)轉(zhuǎn)交給了這個(gè)對象的 to 方法。
而這個(gè) UrlGenerator 類是在 src/Illuminate/Routing/RoutingServiceProvider.php 這個(gè)服務(wù)提供者中被綁定到服務(wù)容器上去的:
/** * Register the URL generator service. * * @return void */protected function registerUrlGenerator(){ $this->app['url'] = $this->app->share(function ($app) { // 略 $url = new UrlGenerator( $routes, $app->rebinding( 'request', $this->requestRebinder() ) ); return $url; });}這也就意味著我們可以隨時(shí)通過 url 這個(gè) abstract 來訪問服務(wù)容器中的這個(gè) UrlGenerator,并且修改它。
而且它也確實(shí)暴露了我們需要的方法:forceSchema 和 forceRootUrl。
修改 url() 函數(shù)生成的 URL 中的根地址的代碼如下:
// 用它提供的方法檢測 URL 是否有效if (app('url')->isValidUrl($rootUrl)) { app('url')->forceRootUrl($rootUrl);}// 強(qiáng)制生成使用 HTTPS 協(xié)議的 URLapp('url')->forceSchema('https');上面那些代碼推薦放在自定義的 ServiceProvider,這樣之后所有的 url() 函數(shù)生成的鏈接都會使用上面定義的根地址和協(xié)議了。
所以說啊,要真正掌握 Laravel 的那些東西,光看文檔還是不夠的。而且 Laravel 的源碼文檔做的很不錯(cuò),讀起來很清晰,能學(xué)到不少東西。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網(wǎng)的支持。
新聞熱點(diǎn)
疑難解答
圖片精選