說明
獲取請求物件
webman會自動將請求物件注入到action方法的第一個參數中,例如
範例
<?php
namespace app\controller;
use support\Request;
class UserController
{
public function hello(Request $request)
{
$default_name = 'webman';
// 從get請求中獲取name參數,如果沒有傳遞name參數則返回$default_name
$name = $request->get('name', $default_name);
// 向瀏覽器返回字串
return response('hello ' . $name);
}
}
透過$request
物件我們能獲取請求相關的任何資料。
有時候我們想在其他類別中獲取當前請求的$request
物件,這時候我們只要使用助手函數request()
即可;
獲取請求參數get
獲取整個get陣列
$request->get();
如果請求沒有get參數則返回一個空的陣列。
獲取get陣列的某一個值
$request->get('name');
如果get陣列中不包含這個值則返回null。
你也可以給get方法第二個參數傳遞一個預設值,如果get陣列中沒找到對應值則返回預設值。例如:
$request->get('name', 'tom');
獲取請求參數post
獲取整個post陣列
$request->post();
如果請求沒有post參數則返回一個空的陣列。
獲取post陣列的某一個值
$request->post('name');
如果post陣列中不包含這個值則返回null。
與get方法一樣,你也可以給post方法第二個參數傳遞一個預設值,如果post陣列中沒找到對應值則返回預設值。例如:
$request->post('name', 'tom');
獲取原始請求post包體
$post = $request->rawBody();
這個功能類似與 php-fpm
裡的 file_get_contents("php://input");
操作。用於獲得http原始請求包體。這在獲取非application/x-www-form-urlencoded
格式的post請求資料時很有用。
獲取header
獲取整個header陣列
$request->header();
如果請求沒有header參數則返回一個空的陣列。注意所有key均為小寫。
獲取header陣列的某一個值
$request->header('host');
如果header陣列中不包含這個值則返回null。注意所有key均為小寫。
與get方法一樣,你也可以給header方法第二個參數傳遞一個預設值,如果header陣列中沒找到對應值則返回預設值。例如:
$request->header('host', 'localhost');
獲取cookie
獲取整個cookie陣列
$request->cookie();
如果請求沒有cookie參數則返回一個空的陣列。
獲取cookie陣列的某一個值
$request->cookie('name');
如果cookie陣列中不包含這個值則返回null。
與get方法一樣,你也可以給cookie方法第二個參數傳遞一個預設值,如果cookie陣列中沒找到對應值則返回預設值。例如:
$request->cookie('name', 'tom');
獲取所有輸入
包含了post
get
的集合。
$request->all();
獲取指定輸入值
從post
get
的集合中獲取某個值。
$request->input('name', $default_value);
獲取部分輸入資料
從post
get
的集合中獲取部分資料。
// 獲取 username 和 password 組成的陣列,如果對應的key沒有則忽略
$only = $request->only(['username', 'password']);
// 獲得除了avatar 和 age 以外的所有輸入
$except = $request->except(['avatar', 'age']);
獲取上傳文件
獲取整個上傳文件陣列
$request->file();
類似的表單:
<form method="post" action="http://127.0.0.1:8787/upload/files" enctype="multipart/form-data" />
<input name="file1" multiple="multiple" type="file">
<input name="file2" multiple="multiple" type="file">
<input type="submit">
</form>
$request->file()
返回的格式類似:
array (
'file1' => object(webman\Http\UploadFile),
'file2' => object(webman\Http\UploadFile)
)
這是一個webman\Http\UploadFile
實例的陣列。webman\Http\UploadFile
類繼承了 PHP 內建的SplFileInfo
類,並且提供了一些實用的方法。
<?php
namespace app\controller;
use support\Request;
class UploadController
{
public function files(Request $request)
{
foreach ($request->file() as $key => $spl_file) {
var_export($spl_file->isValid()); // 文件是否有效,例如ture|false
var_export($spl_file->getUploadExtension()); // 上傳文件後綴名,例如'jpg'
var_export($spl_file->getUploadMimeType()); // 上傳文件mine類型,例如 'image/jpeg'
var_export($spl_file->getUploadErrorCode()); // 獲取上傳錯誤碼,例如 UPLOAD_ERR_NO_TMP_DIR UPLOAD_ERR_NO_FILE UPLOAD_ERR_CANT_WRITE
var_export($spl_file->getUploadName()); // 上傳文件名,例如 'my-test.jpg'
var_export($spl_file->getSize()); // 獲得文件大小,例如 13364,單位字節
var_export($spl_file->getPath()); // 獲得上傳的目錄,例如 '/tmp'
var_export($spl_file->getRealPath()); // 獲得臨時文件路徑,例如 `/tmp/workerman.upload.SRliMu`
}
return response('ok');
}
}
注意:
- 文件被上傳後會被命名為一個臨時文件,類似
/tmp/workerman.upload.SRliMu
- 上傳文件大小受到defaultMaxPackageSize 限制,默認10M,可在
config/server.php
文件中修改max_package_size
更改默認值。 - 請求結束後臨時文件將被自動清除
- 如果請求沒有上傳文件則
$request->file()
返回一個空的陣列 - 上傳的文件不支持
move_uploaded_file()
方法,請使用$file->move()
方法代替,參見下面的例子
獲取特定上傳文件
$request->file('avatar');
如果文件存在的話則返回對應文件的webman\Http\UploadFile
實例,否則返回null。
例子
<?php
namespace app\controller;
use support\Request;
class UploadController
{
public function file(Request $request)
{
$file = $request->file('avatar');
if ($file && $file->isValid()) {
$file->move(public_path().'/files/myfile.'.$file->getUploadExtension());
return json(['code' => 0, 'msg' => 'upload success']);
}
return json(['code' => 1, 'msg' => 'file not found']);
}
}
獲取host
獲取請求的host信息。
$request->host();
如果請求的地址是非標準的80或者443端口,host信息可能會攜帶端口,例如example.com:8080
。如果不需要端口第一個參數可以傳入true
。
$request->host(true);
獲取請求方法
$request->method();
返回值可能是GET
、POST
、PUT
、DELETE
、OPTIONS
、HEAD
中的一個。
獲取請求uri
$request->uri();
返回請求的uri,包括path和queryString部分。
獲取請求路徑
$request->path();
返回請求的path部分。
獲取請求queryString
$request->queryString();
返回請求的queryString部分。
獲取請求url
url()
方法返回不帶有Query
參數 的 URL。
$request->url();
返回類似//www.workerman.net/workerman-chat
fullUrl()
方法返回帶有Query
參數 的 URL。
$request->fullUrl();
返回類似//www.workerman.net/workerman-chat?type=download
注意
url()
和fullUrl()
沒有返回協議部分(沒有返回http或者https)。
因為瀏覽器裡使用//example.com
這樣以//
開頭的地址會自動識別當前站點的協議,自動以http或https發起請求。
如果你使用了nginx代理,請將 proxy_set_header X-Forwarded-Proto $scheme;
加入到nginx配置中,參考nginx代理,
這樣就可以用$request->header('x-forwarded-proto');
來判斷是http還是https,例如:
echo $request->header('x-forwarded-proto'); // 輸出 http 或 https
獲取請求HTTP版本
$request->protocolVersion();
返回字符串 1.1
或者1.0
。
獲取請求sessionId
$request->sessionId();
返回字符串,由字母和數字組成
獲取請求客戶端IP
$request->getRemoteIp();
獲取請求客戶端端口
$request->getRemotePort();
獲取請求客戶端真實IP
$request->getRealIp($safe_mode=true);
當項目使用代理(例如nginx)時,使用$request->getRemoteIp()
得到的往往是代理伺服器IP(類似127.0.0.1
192.168.x.x
)並非客戶端真實IP。這時候可以嘗試使用$request->getRealIp()
獲得客戶端真實IP。
$request->getRealIp()
會嘗試從HTTP頭的x-real-ip
、x-forwarded-for
、client-ip
、x-client-ip
、via
字段中獲取真實IP。
由於HTTP頭很容易伪造,所以此方法獲得的客戶端IP並非100%可信,尤其是
$safe_mode
為false時。透過代理獲得客戶端真實IP的比較可靠的方法是,已知安全的代理伺服器IP,並且明確知道攜帶真實IP是哪個HTTP頭,如果$request->getRemoteIp()
返回的IP確認為已知的安全的代理伺服器,然後通過$request->header('攜帶真實IP的HTTP頭')
獲取真實IP。
獲取服務器IP
$request->getLocalIp();
獲取服務器端口
$request->getLocalPort();
判斷是否是ajax請求
$request->isAjax();
判斷是否是pjax請求
$request->isPjax();
判斷是否是期待json返回
$request->expectsJson();
判斷客戶端是否接受json返回
$request->acceptJson();
獲得請求的插件名
非插件請求返回空字符串''
。
$request->plugin;
此特性需要webman>=1.4.0
獲得請求的應用名
單應用的時候始終返回空字符串''
,多應用的時候返回應用名
$request->app;
因為閉包函數不屬於任何應用,所以來自閉包路由的請求
$request->app
始終返回空字符串''
閉包路由參見 路由
獲得請求的控制器類名
獲得控制器對應的類名
$request->controller;
返回類似 app\controller\IndexController
因為閉包函數不屬於任何控制器,所以來自閉包路由的請求
$request->controller
始終返回空字符串''
閉包路由參見 路由
獲得請求的方法名
獲得請求對應的控制器方法名
$request->action;
返回類似 index
因為閉包函數不屬於任何控制器,所以來自閉包路由的請求
$request->action
始終返回空字符串''
閉包路由參見 路由