今天小編就爲大家分享一篇基於laravel Request的所有方法詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
獲取請求的實例
通過 Facade
Request 這個 facade 可以讓我們得到綁定在容器裏的當前這個請求。比如:
$name = Request::input('name');
注意,如果你在一個命名空間裏,你需要在類文件的頂部使用 use Request; 這條聲明來導入 Request 這個 facade 。
通過依賴注入
要通過依賴注入得到當前 HTTP 請求的實例,需要在你的控制器構造函數或者方法裏 type-hint 類。當前請求的這個實例會被 Service Container 自動注入進來。
<?php namespace App\Http\Controllers; use Illuminate\Http\Request; use Illuminate\Routing\Controller; class UserController extends Controller { /** * 保存新的用戶 * * @param Request $request * @return Response */ public function store(Request $request) { $name = $request->input('name'); // } }
如果你的控制器方法期待來自路由參數上的 input(值),可以在其它的依賴的後面列出這些路由參數:
<?php namespace App\Http\Controllers; use Illuminate\Http\Request; use Illuminate\Routing\Controller; class UserController extends Controller { /** * Store a new user. * * @param Request $request * @param int $id * @return Response */ public function update(Request $request, $id) { // } }
檢索輸入
檢索輸入的值
使用幾個簡單的方法,你可以得到在 Illuminate\Http\Request 實例上的用戶的所有的輸入。你不用管請求使用的 HTTP 動作是什麼,可以使用同樣的方法來得到所有的輸入的值。
$name = Request::input('name');
在缺少輸入值的時候去獲取到默認值
$name = Request::input('name', 'Sally');
確定一個輸入值是否出現
if (Request::has('name')) { // }
得到請求裏的所有輸入的值
$input = Request::all();
得到請求裏的部分輸入值
$input = Request::only('username', 'password'); $input = Request::except('credit_card');
如果輸入裏面包含數組類型的值,可以使用點的形式訪問到這個數組裏的值:
$input = Request::input('products.0.name');
以前輸入的值
Laravel 會存儲在一次請求與下一次請求之間的輸入值。比如,你可能需要在驗證了輸入錯誤之後重新填寫表單。
把輸入值閃存到會話裏
flash 方法可以把當前的輸入的值閃存(flash)到會話( session) 裏。這樣,在用戶下一次對應用發出請求的時候可以用到這些輸入值:
Request::flash();
把一部分輸入值閃存到會話裏
Request::flashOnly('username', 'email'); Request::flashExcept('password');
閃存與重定向
你想閃存輸入值並且用一個重定向(redirect)到前一個頁面上,可以把輸入閃存鏈到一個重定向上。
return redirect('form')->withInput(); return redirect('form')->withInput(Request::except('password'));
得到以前的數據
得到前一個請求裏的閃存的輸入值,可以使用在 Request 實例上的 old 這個方法。
$username = Request::old('username');
如果你打算用 Blade 模板顯示以前的輸入值,可以使用 old 這個幫手:
{{ old('username') }}
Cookies
Laravel 框架創建的所有的 Cookies 都是加密的,並且會籤上一個認證的代碼,意思就是如果這些 Cookies 在客戶端那裏被修改過,就會被認爲是無效的 Cookies。
檢索 Cookie 值
$value = Request::cookie('name');
把一個新 Cookie 附加給一個響應
cookie 這個幫手的作用就是去生成新的 Symfony\Component\HttpFoundation\Cookie 實例。可以使用 withCookie 方法把Cookies 附加到 Response 實例上:
$response = new Illuminate\Http\Response('Hello World'); $response->withCookie(cookie('name', 'value', $minutes));
創建永恆的 Cookie
永恆,我們的意思其實就是 5 年。
$response->withCookie(cookie()->forever('name', 'value'));
文件
檢索一個上傳了的文件
$file = Request::file('photo');
確定一個文件是不是被上傳了
if (Request::hasFile('photo')) { // }
file 方法返回來的對象是 Symfony\Component\HttpFoundation\File\UploadedFile 類的一個實例,這個類繼承了 PHP 的 SplFileInfo 類,提供了很多方法可以跟文件交互。
確定上傳的文件是否有效
if (Request::file('photo')->isValid()) { // }
移動一個上傳的文件
Request::file('photo')->move($destinationPath); Request::file('photo')->move($destinationPath, $fileName);
其它文件方法
在 UploadedFile 實例上還有一些其它的方法。具體可以看一下 Class API 的文檔 。
其它的請求信息
Request 類爲你的應用提供了很多方法可以檢查 HTTP 請求,它繼承了 Symfony\Component\HttpFoundation\Request 類。下面是幾個亮點。
檢索請求 URI
$uri = Request::path();
檢索請求方法
$method = Request::method(); if (Request::isMethod('post')) { // }
確定請求路徑是否匹配一個模式
if (Request::is('admin/*')) { // }
得到當前請求的地址
$url = Request::url();
以上這篇基於laravel Request的所有方法詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持神馬文庫。