前言
本文主要給大家介紹了修改Laravel中url()函數(shù)生成URL的根地址的相關(guān)內(nèi)容,相信大家都曉得 Larevel 的一票幫助函數(shù)中有個(gè) url(),可以通過(guò)給予的目錄生成完整的 URL,是非常方便的一個(gè)函數(shù):
// return: https://skin.dev/user/profile url('user/profile')
但是這玩意生成的 URL 中要補(bǔ)完的部分是框架內(nèi)部根據(jù) Request 自動(dòng)判斷的,而自動(dòng)判斷出的東西有時(shí)候會(huì)出錯(cuò)(譬如在套了一層反向代理之類(lèi)的情況下)。
文檔上并沒(méi)有提到我們要如何才能自定義它生成的 URL 中的根地址和協(xié)議頭部分(http(s)),這就非常吃癟了。那我們要咋辦呢?
首先我們來(lái)看看 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è)對(duì)象的 to 方法。
而這個(gè) UrlGenerator 類(lèi)是在 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í)通過(guò) url 這個(gè) abstract 來(lái)訪(fǎng)問(wèn)服務(wù)容器中的這個(gè) UrlGenerator,并且修改它。
而且它也確實(shí)暴露了我們需要的方法:forceSchema 和 forceRootUrl。
修改 url() 函數(shù)生成的 URL 中的根地址的代碼如下:
// 用它提供的方法檢測(cè) URL 是否有效 if (app('url')->isValidUrl($rootUrl)) { app('url')->forceRootUrl($rootUrl); } // 強(qiáng)制生成使用 HTTPS 協(xié)議的 URL app('url')->forceSchema('https');
上面那些代碼推薦放在自定義的 ServiceProvider,這樣之后所有的 url() 函數(shù)生成的鏈接都會(huì)使用上面定義的根地址和協(xié)議了。
所以說(shuō)啊,要真正掌握 Laravel 的那些東西,光看文檔還是不夠的。而且 Laravel 的源碼文檔做的很不錯(cuò),讀起來(lái)很清晰,能學(xué)到不少東西。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)的支持。