本文整理匯總了PHP中Bluz\Proxy\Request::getAccept方法的典型用法代碼示例。如果您正苦於以下問題:PHP Request::getAccept方法的具體用法?PHP Request::getAccept怎麽用?PHP Request::getAccept使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Bluz\Proxy\Request
的用法示例。
在下文中一共展示了Request::getAccept方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1:
break;
case 501:
$title = __("Not Implemented");
$description = __("The server does not understand or does not support the HTTP method");
break;
case 503:
$title = __("Service Unavailable");
$description = __("The server is currently unable to handle the request due to a temporary overloading");
Response::setHeader('Retry-After', '600');
break;
default:
$title = __("Internal Server Error");
$description = __("An unexpected error occurred with your request. Please try again later");
break;
}
// check CLI or HTTP request
if (Request::isHttp()) {
// simple AJAX call, accept JSON
if (Request::getAccept(['application/json'])) {
$this->useJson();
Messages::addError($description);
return null;
}
// dialog AJAX call, accept HTML
if (!Request::isXmlHttpRequest()) {
$this->useLayout('small.phtml');
}
}
Layout::title($title);
return ['error' => $title, 'description' => $description];
};
示例2:
$description = __("The server does not understand or does not support the HTTP method");
break;
case 503:
$title = __("Service Unavailable");
$description = __("The server is currently unable to handle the request due to a temporary overloading");
Response::setHeader('Retry-After', '600');
break;
default:
$title = __("Internal Server Error");
$description = __("An unexpected error occurred with your request. Please try again later");
break;
}
// check CLI or HTTP request
if (Request::isHttp()) {
// simple AJAX call, accept JSON
if (Request::getAccept() == Request::ACCEPT_JSON) {
$this->useJson();
Messages::addError($message);
return $view;
}
// dialog AJAX call, accept HTML
if (!Request::isXmlHttpRequest()) {
$this->useLayout('small.phtml');
}
}
Layout::title($title);
$view->error = $title;
$view->description = $description;
if (getenv('BLUZ_DEBUG') && $message != '') {
$view->message = $message;
}
示例3: checkAccept
/**
* Check `Accept`
*
* @throws NotAcceptableException
*/
public function checkAccept()
{
// all ok for CLI
if (PHP_SAPI == 'cli') {
return;
}
$allowAccept = $this->getReflection()->getAccept();
// some controllers hasn't @accept tag
if (!$allowAccept) {
// but by default allow just HTML output
$allowAccept = [Request::TYPE_HTML, Request::TYPE_ANY];
}
// get Accept with high priority
$accept = Request::getAccept($allowAccept);
// some controllers allow any type (*/*)
// and client doesn't send Accept header
if (in_array(Request::TYPE_ANY, $allowAccept) && !$accept) {
// all OK, controller should realize logic for response
return;
}
// some controllers allow just selected types
// choose MIME type by browser accept header
// filtered by controller @accept
// switch statement for this logic
switch ($accept) {
case Request::TYPE_ANY:
case Request::TYPE_HTML:
// HTML response with layout
break;
case Request::TYPE_JSON:
// JSON response
$this->template = null;
break;
default:
throw new NotAcceptableException();
}
}
示例4: preProcess
/**
* Pre process
*
* @return void
* @throws ApplicationException
*/
protected function preProcess()
{
Router::process();
// disable Layout for XmlHttpRequests
if (Request::isXmlHttpRequest()) {
$this->layoutFlag = false;
}
// switch to JSON response based on Accept header
if (Request::getAccept([Request::TYPE_HTML, Request::TYPE_JSON]) == Request::TYPE_JSON) {
$this->layoutFlag = false;
Response::switchType('JSON');
}
}
示例5: forbidden
/**
* Denied access
* @param ForbiddenException $exception
* @return \Bluz\Controller\Controller|null
*/
public function forbidden(ForbiddenException $exception)
{
if (AuthProxy::getIdentity()) {
$message = Translator::translate("You don't have permissions to access this page");
} else {
$message = Translator::translate("You don't have permissions, please sign in");
}
// for AJAX and API calls (over JSON)
$jsonOrApi = Request::isXmlHttpRequest() || Request::getAccept([Request::TYPE_HTML, Request::TYPE_JSON]) == Request::TYPE_JSON;
// for guest, for requests
if (!AuthProxy::getIdentity() && !$jsonOrApi) {
// save URL to session and redirect make sense if presentation is null
Session::set('rollback', Request::getUri()->__toString());
// add error notice
Messages::addError($message);
// redirect to Sign In page
$url = Router::getUrl('users', 'signin');
return $this->redirect($url);
} else {
return $this->error(new ForbiddenException($message, 403, $exception));
}
}