當前位置: 首頁>>代碼示例>>PHP>>正文


PHP MvcEvent::setError方法代碼示例

本文整理匯總了PHP中Zend\Mvc\MvcEvent::setError方法的典型用法代碼示例。如果您正苦於以下問題:PHP MvcEvent::setError方法的具體用法?PHP MvcEvent::setError怎麽用?PHP MvcEvent::setError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Zend\Mvc\MvcEvent的用法示例。


在下文中一共展示了MvcEvent::setError方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: testOnDispatchErrorStoreAndStreamImage

 /**
  * @covers ::onDispatchError
  */
 public function testOnDispatchErrorStoreAndStreamImage()
 {
     $id = 'someId';
     $resource = 'someResource';
     $this->event->setError(Application::ERROR_ROUTER_NO_MATCH);
     $image = $this->getMockBuilder(ImageEntity::class)->setMethods(['getLength', 'getResource'])->getMock();
     $image->setId($id);
     $image->setType('image/jpeg');
     $image->setName('image.jpg');
     $image->method('getLength')->willReturn(1024);
     $image->method('getResource')->willReturn($resource);
     $this->manager->expects($this->once())->method('matchUri')->willReturn($id);
     $this->repository->expects($this->once())->method('find')->with($this->equalTo($id))->willReturn($image);
     $this->manager->expects($this->once())->method('store')->with($this->identicalTo($image));
     $this->listener->onDispatchError($this->event);
     $response = $this->event->getResponse();
     $this->assertInstanceOf(Stream::class, $response);
     $this->assertEquals(Response::STATUS_CODE_200, $response->getStatusCode());
     $this->assertEquals($image->getName(), $response->getStreamName());
     $this->assertEquals($image->getResource(), $response->getStream());
     $headers = $response->getHeaders();
     $this->assertInstanceOf(Headers::class, $headers);
     $this->assertTrue($headers->has('Content-Type'));
     $this->assertEquals($image->getType(), $headers->get('Content-Type')->getFieldValue());
     $this->assertTrue($headers->has('Content-Length'));
     $this->assertEquals($image->getLength(), $headers->get('Content-Length')->getFieldValue());
 }
開發者ID:cross-solution,項目名稱:yawik,代碼行數:30,代碼來源:ApplicationListenerTest.php

示例2: testOnRenderErrorCreatesAnApiProblemResponse

 public function testOnRenderErrorCreatesAnApiProblemResponse()
 {
     $response = new Response();
     $request = new Request();
     $request->getHeaders()->addHeaderLine('Accept', 'application/json');
     $event = new MvcEvent();
     $event->setError(Application::ERROR_EXCEPTION);
     $event->setRequest($request);
     $event->setResponse($response);
     $this->listener->onRenderError($event);
     $this->assertTrue($event->propagationIsStopped());
     $this->assertSame($response, $event->getResponse());
     $this->assertEquals(406, $response->getStatusCode());
     $headers = $response->getHeaders();
     $this->assertTrue($headers->has('Content-Type'));
     $this->assertEquals('application/problem+json', $headers->get('content-type')->getFieldValue());
     $content = json_decode($response->getContent(), true);
     $this->assertArrayHasKey('status', $content);
     $this->assertArrayHasKey('title', $content);
     $this->assertArrayHasKey('describedBy', $content);
     $this->assertArrayHasKey('detail', $content);
     $this->assertEquals(406, $content['status']);
     $this->assertEquals('Not Acceptable', $content['title']);
     $this->assertContains('www.w3.org', $content['describedBy']);
     $this->assertContains('accept', $content['detail']);
 }
開發者ID:gstearmit,項目名稱:EshopVegeTable,代碼行數:26,代碼來源:RenderErrorListenerTest.php

示例3: onRoute

 /**
  * @param MvcEvent $e
  */
 public static function onRoute(MvcEvent $e)
 {
     if (!$e->getRequest() instanceof HttpRequest) {
         return;
     }
     $app = $e->getTarget();
     $rbacService = $app->getServiceManager()->get('ZfcRbac\\Service\\Rbac');
     $match = $app->getMvcEvent()->getRouteMatch();
     $controller = $match->getParam('controller');
     $action = $match->getParam('action');
     $resource = sprintf('%s:%s', $controller, $action);
     try {
         if ($rbacService->getFirewall('controller')->isGranted($resource)) {
             return;
         }
     } catch (InvalidArgumentException $ex) {
         //if Exception, default to unauthorized
     }
     try {
         $e->setError($rbacService::ERROR_CONTROLLER_UNAUTHORIZED)->setParam('identity', $rbacService->getIdentity())->setParam('controller', $controller)->setParam('action', $action);
         $app->getEventManager()->trigger('dispatch.error', $e);
     } catch (InvalidArgumentException $ex) {
         return;
     }
 }
開發者ID:Mystraht,項目名稱:builder,代碼行數:28,代碼來源:Controller.php

示例4: checkPermission

 public function checkPermission(MvcEvent $e)
 {
     $params = $e->getRouteMatch()->getParams();
     if (!isset($params['backend']) || !$params['backend']) {
         return;
     }
     $serviceLocator = $e->getApplication()->getServiceManager();
     $config = $serviceLocator->get('config');
     if (Authentication::getInstance()->hasIdentity()) {
         // Check if user has permission to access the current page
         $user = Authentication::getInstance()->getIdentity();
         /** @var \Acl\Service\Acl $acl */
         $acl = $serviceLocator->get('Acl\\Service\\Acl');
         if (!$acl->isAllowed($user->role, $params['controller'], $params['action'])) {
             $e->setError(self::ERROR_FORBIDDEN);
             $e->getApplication()->getEventManager()->trigger(MvcEvent::EVENT_DISPATCH_ERROR, $e);
         }
     } else {
         $request = $e->getRequest();
         /** @var \Zend\Http\Response $response */
         $response = $e->getResponse();
         $router = $e->getRouter();
         $url = $router->assemble([], ['name' => $config['acl']['signin_route']]) . '?continue=' . $request->getUri()->toString();
         $response->getHeaders()->addHeaderLine('Location', $url);
         $response->setStatusCode(302);
         return $response;
     }
 }
開發者ID:hoangpt,項目名稱:nextcms,代碼行數:28,代碼來源:AclListener.php

示例5: testOnBootstrapListenersWithHttpRequest

 public function testOnBootstrapListenersWithHttpRequest()
 {
     $module = new Module();
     $application = $this->createApplication();
     $sm = $application->getServiceManager();
     $sm->setService('FilterManager', new FilterPluginManager());
     foreach ($module->getServiceConfig()['invokables'] as $key => $value) {
         $sm->setInvokableClass($key, $value);
     }
     foreach ($module->getServiceConfig()['factories'] as $key => $value) {
         $sm->setFactory($key, $value);
     }
     $sm->get('ViewHelperManager')->setService('bodyClass', $this->getMock(BodyClass::class));
     $event = new MvcEvent();
     $event->setApplication($application);
     $em = $application->getEventManager();
     $em->getSharedManager()->clearListeners(LayoutUpdater::class);
     $module->onBootstrap($event);
     $layoutUpdater = $sm->get(LayoutUpdaterInterface::class);
     $this->assertEquals(['default'], $layoutUpdater->getHandles());
     $mvcEvent = new MvcEvent();
     $mvcEvent->setApplication($application);
     $mvcEvent->setName(MvcEvent::EVENT_DISPATCH_ERROR);
     $mvcEvent->setError('test-error');
     $em->triggerEvent($mvcEvent);
     $this->assertEquals(['default', 'test-error'], $layoutUpdater->getHandles());
 }
開發者ID:hummer2k,項目名稱:conlayout,代碼行數:27,代碼來源:ModuleTest.php

示例6: terminateEvent

 protected function terminateEvent(MvcEvent $event, $error, \Exception $exception)
 {
     $eventManager = $event->getApplication()->getEventManager();
     $event->setError($error);
     $event->setParam('exception', $exception);
     $event->stopPropagation(true);
     $eventManager->trigger(MvcEvent::EVENT_DISPATCH_ERROR, $event);
 }
開發者ID:aerisweather,項目名稱:ZfAuth,代碼行數:8,代碼來源:Module.php

示例7: testOnError_WithApiException

 public function testOnError_WithApiException()
 {
     $event = new MvcEvent();
     $event->setError("The resource doesn't support the specified HTTP verb.");
     $event->setParam('exception', new MethodNotAllowedException());
     $event->setResponse(new Response());
     $result = $this->testedObject->onError($event);
     $this->assertInstanceOf(JsonModel::class, $result);
 }
開發者ID:omusico,項目名稱:zf2-demo,代碼行數:9,代碼來源:ResolveExceptionToJsonModelListenerTest.php

示例8: onRoute

 public static function onRoute(MvcEvent $e)
 {
     $app = $e->getTarget();
     $route = $e->getRouteMatch()->getMatchedRouteName();
     $security = $app->getServiceManager()->get('SpiffySecurity\\Service\\Security');
     if (!$security->getFirewall('route')->isGranted($route)) {
         $e->setError($security::ERROR_ROUTE_UNAUTHORIZED)->setParam('identity', $security->getIdentity())->setParam('route', $route);
         $app->getEventManager()->trigger('dispatch.error', $e);
     }
 }
開發者ID:raykolbe,項目名稱:SpiffySecurity,代碼行數:10,代碼來源:Route.php

示例9: onDispatchError

 public function onDispatchError(MvcEvent $e)
 {
     if ($e->getError() !== Zf2Application::ERROR_ROUTER_NO_MATCH) {
         return;
     }
     $routeMatch = new RouteMatch(array());
     $routeMatch->setParam('controller', 'Zf1Module\\DispatchController');
     $e->setError(null);
     $e->setRouteMatch($routeMatch);
     return $routeMatch;
 }
開發者ID:xemlock,項目名稱:Zf1Module,代碼行數:11,代碼來源:DispatchListener.php

示例10: onEvent

 /**
  * Capture Error converted to exception, then trigger a dispatch error
  * @param MvcEvent $e
  */
 public function onEvent(MvcEvent $event)
 {
     $exception = ErrorHandler::stop();
     if ($exception instanceof \Exception) {
         $event->setError(Application::ERROR_EXCEPTION);
         $event->setParam('exception', $exception);
         $this->getEventManager()->trigger($event::EVENT_DISPATCH_ERROR, $event);
     } elseif (!$event->getError() && $event->getResponse()->getStatusCode() == 404) {
         $event->setError(Application::ERROR_CONTROLLER_CANNOT_DISPATCH);
         $this->getEventManager()->trigger($event::EVENT_DISPATCH_ERROR, $event);
     }
 }
開發者ID:ronan-gloo,項目名稱:zf2-error-manager,代碼行數:16,代碼來源:ErrorListener.php

示例11: onRoute

 public static function onRoute(MvcEvent $e)
 {
     $app = $e->getTarget();
     $service = $app->getServiceManager()->get('BjyAuthorize\\Service\\Authorize');
     $match = $app->getMvcEvent()->getRouteMatch();
     $routeName = $match->getMatchedRouteName();
     $allowed = $service->isAllowed('route/' . $routeName);
     if (!$allowed) {
         $e->setError('error-unauthorized-route')->setParam('route', $routeName)->setParam('identity', $service->getIdentity());
         $app->getEventManager()->trigger('dispatch.error', $e);
     }
 }
開發者ID:rrmodi88,項目名稱:BjyAuthorize,代碼行數:12,代碼來源:Route.php

示例12: onRoute

 /**
  * @param MvcEvent $e
  */
 public static function onRoute(MvcEvent $e)
 {
     if (!$e->getRequest() instanceof HttpRequest) {
         return;
     }
     $app = $e->getTarget();
     $route = $e->getRouteMatch()->getMatchedRouteName();
     $rbacService = $app->getServiceManager()->get('ZfcRbac\\Service\\Rbac');
     if (!$rbacService->getFirewall('route')->isGranted($route)) {
         $e->setError($rbacService::ERROR_ROUTE_UNAUTHORIZED)->setParam('identity', $rbacService->getIdentity())->setParam('route', $route);
         $app->getEventManager()->trigger('dispatch.error', $e);
     }
 }
開發者ID:Mystraht,項目名稱:builder,代碼行數:16,代碼來源:Route.php

示例13: onRoute

 public static function onRoute(MvcEvent $e)
 {
     $app = $e->getTarget();
     $service = $app->getServiceManager()->get('BjyAuthorize\\Service\\Authorize');
     $match = $app->getMvcEvent()->getRouteMatch();
     $controller = $match->getParam('controller');
     $action = $match->getParam('action');
     $controllerResource = sprintf('controller/%s', $controller);
     $actionResource = sprintf('controller/%s:%s', $controller, $action);
     $allowed = $service->isAllowed($controllerResource) || $service->isAllowed($actionResource);
     if (!$allowed) {
         $e->setError('error-unauthorized-controller')->setParam('identity', $service->getIdentity())->setParam('controller', $controller)->setParam('action', $action);
         $app->getEventManager()->trigger('dispatch.error', $e);
     }
 }
開發者ID:rafajaques,項目名稱:colloquium,代碼行數:15,代碼來源:Controller.php

示例14: triggerForbiddenEvent

 /**
  * 
  * @param MvcEvent $event
  */
 protected function triggerForbiddenEvent(MvcEvent $event)
 {
     $event->setError('route-forbidden');
     $event->setParam('exception', new UnauthorizedException('You are forbidden!', 403));
     $event->stopPropagation(true);
     if ($this->hasErrorViewModel()) {
         $event->setViewModel($this->errorView);
     }
     $response = $event->getResponse();
     $response->setStatusCode(403);
     $event->setResponse($response);
     $application = $event->getApplication();
     $eventManager = $application->getEventManager();
     $eventManager->trigger(MvcEvent::EVENT_DISPATCH_ERROR, $event);
 }
開發者ID:ughly,項目名稱:ugh-authorization,代碼行數:19,代碼來源:GuardListener.php

示例15: onRoute

 public function onRoute(MvcEvent $mvcEvent)
 {
     $request = $mvcEvent->getRequest();
     $response = $mvcEvent->getResponse();
     /**
      * If it's a CLI request - return.
      */
     if ($request instanceof \Zend\Console\Request) {
         return;
     }
     $app = $mvcEvent->getApplication();
     $match = $app->getMvcEvent()->getRouteMatch();
     $routeName = $match->getMatchedRouteName();
     $method = strtolower($request->getMethod());
     if (!$this->acl->hasResource($routeName)) {
         return;
     }
     $role = null;
     /**
      * Infer that if :
      * 1. the request is protected under 2 legged oauth,
      *    then it is a 2 legged oauth request
      * 2. the request is protected under 3 legged oauth,
      *    then it is a 3 legged oauth request
      * 3. otherwise it is not protected
      */
     if ($this->acl->isAllowed(BgOauthProviderAcl::TWO_LEGGED, $routeName, $method)) {
         $role = BgOauthProviderAcl::TWO_LEGGED;
         $this->oauthProvider->is2LeggedEndpoint();
     } elseif ($this->acl->isAllowed(BgOauthProviderAcl::THREE_LEGGED, $routeName, $method)) {
         $role = BgOauthProviderAcl::THREE_LEGGED;
     } else {
         return;
     }
     try {
         $this->oauthProvider->checkOAuthRequest();
     } catch (\OAuthException $e) {
         $error = \OAuthProvider::reportProblem($e, false);
         $response->setStatusCode(Response::STATUS_CODE_401);
         $response->setContent($error);
         $response->getHeaders()->addHeaders(array('WWW-Authenticate' => $error));
         $mvcEvent->setError(self::ERROR);
         $mvcEvent->getApplication()->getEventManager()->trigger(MvcEvent::EVENT_DISPATCH_ERROR, $mvcEvent);
         return $response;
     }
     //Success!
 }
開發者ID:jeremymills,項目名稱:BgOauthProvider,代碼行數:47,代碼來源:Route.php


注:本文中的Zend\Mvc\MvcEvent::setError方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。