विवरण
अनुरोध ऑब्जेक्ट प्राप्त करें
webman स्वत: ही कार्रवाई विधि के पहले पैरामीटर में अनुरोध ऑब्जेक्ट को स्वचालित रूप से इंजेक्ट करेगा, जैसे
उदाहरण
<?php
namespace app\controller;
use support\Request;
class UserController
{
public function hello(Request $request)
{
$default_name = 'webman';
// get अनुरोध से नाम पैरामीटर प्राप्त करें, अगर नाम पैरामीटर पास नहीं किया गया है तो $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 पैरामीटर नहीं है तो एक खाली एरे देगा।
पोस्ट एरे का कोई विशेष मान प्राप्त करें
$request->post('name');
अगर जो पोस्ट एरे में यह मान शामिल नहीं है तो null लौटाएगा।
get विधि की तरह, आप चाहें तो पोस्ट विधि को दूसरी पैरामीटर के रूप में एक डिफ़ॉल्ट मान भी पास कर सकते हैं, अगर पोस्ट एरे में विशेष मान नहीं मिला तो वह डिफ़ॉल्ट मान देगा। उदाहरण:
$request->post('name', 'tom');
मौलिक अनुरोध पोस्ट बॉडी प्राप्त करें
$post = $request->rawBody();
इस कार्य का php-fpm में file_get_contents("php://input");
के ऑपरेशन के समान है। यह अनुरोध के मौलिक पोस्ट बॉडी को प्राप्त करने के लिए उपयोगी है। यह उपयोगी होता है गैर application/x-www-form-urlencoded
प्रारूप के पोस्ट अनुरोध डेटा को प्राप्त करने में।
हेडर प्राप्त करें
संपूर्ण हेडर एरे प्राप्त करें
$request->header();
अगर अनुरोध में हेडर पैरामीटर नहीं है तो एक खाली एरे देगा। सभी कुंजी छोटे लिखे गए होंगे।
हेडर एरे का कोई विशेष मान प्राप्त करें
$request->header('host');
अगर हेडर एरे में इस मान को नहीं मिला तो null देगा। सभी कुंजी छोटे लिखे गए होंगे।
get विधि की तरह, आप चाहें तो हेडर विधि को दूसरी पैरामीटर के रूप में एक डिफ़ॉल्ट मान भी पास कर सकते हैं, अगर हेडर एरे में विशेष मान नहीं मिला तो वह डिफ़ॉल्ट मान देगा। उदाहरण:
$request->header('host', 'localhost');
कुकी प्राप्त करें
संपूर्ण कुकी एरे प्राप्त करें
$request->cookie();
यदि अनुरोध में कुकी पैरामीटर नहीं है तो एक खाली एरे देगा।
कुकी एरे का कोई विशेष मान प्राप्त करें
$request->cookie('name');
अगर कुकी एरे में इस मान को नहीं मिला तो null देगा।
get विधि की तरह, आप चाहें तो कुकी विधि को दूसरी पैरामीटर के रूप में एक डिफ़ॉल्ट मान भी पास कर सकते हैं, अगर कुकी एरे में विशेष मान नहीं मिला तो वह डिफ़ॉल्ट मान देगा। उदाहरण:
$request->cookie('name', 'tom');
सभी इनपुट प्राप्त करें
post
get
को शामिल करता है।
$request->all();
निर्दिष्ट इनपुट मान प्राप्त करें
post
get
संग्रह से कोई मान प्राप्त करें।
$request->input('name', $default_value);
कुछ इनपुट डेटा प्राप्त करें
post
get
संग्रह से कुछ डेटा प्राप्त करें।
// उपयोगकर्ता नाम और पासवर्ड से बना संग्रह प्राप्त करें, यदि संबंधित कुंजी नहीं मिली है तो उपेक्षा करें
$only = $request->only(['username', 'password']);
// अवतार और उम्र को छोड़कर सभी इनपुट प्राप्त करें
$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
वर्करमैन का एक्सटेंशन 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()); // फ़ाइल क्या वैध है, जैसे true|false
var_export($spl_file->getUploadExtension()); // अपलोड फ़ाइल एक्सटेंशन, जैसे 'jpg'
var_export($spl_file->getUploadMimeType()); // अपलोड फ़ाइल MIME प्रकार, जैसे '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']);
}
}
होस्ट प्राप्त करें
अनुरोध के होस्ट जानकारी प्राप्त करें।
$request->host();
यदि अनुरोध का पता मानक 80 या 443 पोर्ट नहीं है, तो होस्ट जानकारी में पोर्ट शामिल हो सकता है, जैसे example.com:8080
। पोर्ट की आवश्यकता न हो तो पहले पैरामीटर true
को पास किया जा सकता है।
$request->host(true);
अनुरोध पद्धति प्राप्त करें
$request->method();
GET
、POST
।PUT
।DELETE
, OPTIONS
, HEAD
में से एक लौटाता है।
अनुरोध यूआरआई प्राप्त करें
$request->uri();
पथ और क्वेरी स्ट्रिंग सहित अनुरोध का URI लौटाता है।
अनुरोध पथ प्राप्त करें
$request->path();
अनुरोध का पथ भाग लौटाता है।
अनुरोध क्वेरी स्ट्रिंग प्राप्त करें
$request->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 से नियुक्त होकर अनुरोध भेजता है।
यदि आप एनजिंक्स प्रॉक्सी का उपयोग कर रहे हैं, तो कृपया एनजिंक्स कॉन्फ़िगरेशन में proxy_set_header X-Forwarded-Proto $scheme;
जोड़ें, एनजिंक्स प्रॉक्सी से संबंधित।
ऐसा करने से आप $request->header('x-forwarded-proto');
का उपयोग करके http या https को पहचान सकते हैं, जैसे:
echo $request->header('x-forwarded-proto'); // प्रिंट करें http या https
अनुरोध HTTP संस्करण प्राप्त करें
$request->protocolVersion();
स्ट्रिंग 1.1
या 1.0
को लौटाता है।
अनुरोध सत्राधीश प्राप्त करें
$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()
वास्तविक IP प्राप्त करने के लिए x-real-ip
, x-forwarded-for
, client-ip
, x-client-ip
, via
फ़ील्ड से प्रयास करेगा।
HTTP हेडर आसानी से जाली बनाया जा सकता है, इसलिए इस विधि से प्राप्त किए गए ग्राहक IP निश्चित रूप से 100% विश्वसनीय नहीं है, विशेष रूप से जब $safe_mode फॉल्स होता है। प्रॉक्सी के माध्यम से ग्राहक का वास्तविक IP प्राप्त करने का तुलनात्मक विश्वसनीय उपाय है, यहां तक कि यदि कोई जानकार तानिक प्रॉक्सी सर्वरों के IP के बारे में है और स्पष्ट रूप से पता है कि वास्तविक IP कोनसा HTTP हेडर ले जाता है। यदि $request->getRemoteIp() द्वारा वापस लौटाया गया IP निश्चित रूप से जानी पहचानी सुरक्षित प्रॉक्सी सर्वर की पुष्टि होती है, और फिर $request->header('वास्तविक IP लेने वाला HTTP हेडर') के माध्यम से वास्तविक IP प्राप्त कर सकते हैं।
सर्वर IP प्राप्त करें
$request->getLocalIp();
सर्वर पोर्ट प्राप्त करें
$request->getLocalPort();
क्या यह एजेक्स अनुरोध है, इसे निर्धारित करें
$request->isAjax();
क्या यह पीजैक्स अनुरोध है, इसे निर्धारित करें
$request->isPjax();
क्या यह जेसन को वापस देना चाहता है, इसे निर्धारित करें
$request->expectsJson();
क्या ग्राहक जेसन को स्वीकार करता है, इसे निर्धारित करें
$request->acceptJson();
अनुरोध का प्लगइन नाम प्राप्त करें
प्लगइन के अनुरोध पर खाली स्ट्रिंग ''
वापस लौटाएगा।
$request->plugin;
यह विशेषता webman>=1.4.0 की आवश्यकता होती है
अनुरोध का ऐप का नाम प्राप्त करें
एकल ऐप के समय हमेशा खाली स्ट्रिंग ''
लौटाएगा, बहु-ऐप्लिकेशन के समय एप्लिकेशन का नाम लौटाएगा
$request->app;
क्योंकि बंद फ़ंक्शन किसी भी एप्लिकेशन का हिस्सा नहीं है, इसलिए बंद फ़ंक्शन से आने वाले अनुरोध $request->app हमेशा खाली स्ट्रिंग
''
लौटाता है
बंद फ़ंक्शन देखें रूट
अनुरोध का नियंत्रक का नाम प्राप्त करें
नियंत्रक के लिए संबंधित क्लास का नाम प्राप्त करें
$request->controller;
वापस ब्लॉक की तरह app\controller\IndexController
लौटेगा
क्योंकि बंद फ़ंक्शन किसी भी नियंत्रक का हिस्सा नहीं है, इसलिए बंद फ़ंक्शन से आने वाले अनुरोध $request->controller हमेशा खाली स्ट्रिंग
''
लौटाता है
बंद फ़ंक्शन देखें रूट
अनुरोध का विधि का नाम प्राप्त करें
नियंत्रक की विधि का नाम प्राप्त करें
$request->action;
वापस index
जैसा लौटेगा
क्योंकि बंद फ़ंक्शन किसी भी नियंत्रक का हिस्सा नहीं है, इसलिए बंद फ़ंक्शन से आने वाले अनुरोध $request->action हमेशा खाली स्ट्रिंग
''
लौटाता है
बंद फ़ंक्शन देखें रूट