php – 在Symfony 3 Controller中获取请求和会话
发布时间:2020-12-13 22:20:15 所属栏目:PHP教程 来源:网络整理
导读:我有一个大问题,请帮助我.所以我想创建一个只使用以下用户的登录系统: providers: in_memory: memory: users: 所以我的全局路由:/app/config/routing.yml: app_admin: resource: "@AppAdminBundle/Resources/config/routing.yml" prefix: /admin 我在Admi
我有一个大问题,请帮助我.所以我想创建一个只使用以下用户的登录系统:
providers: in_memory: memory: users: 所以我的全局路由:/app/config/routing.yml: app_admin: resource: "@AppAdminBundle/Resources/config/routing.yml" prefix: /admin 我在AdminBundle中的路由: app_admin_homepage: path: / defaults: { _controller: AppAdminBundle:Login:index } login: path: /login defaults: { _controller: AppAdminBundle:Login:login } login_check: path: /login_check 我的LoginController: <?php namespace AppAdminBundleController; use SymfonyBundleFrameworkBundleControllerController; use SymfonyComponentSecurityCoreSecurityContext; class LoginController extends Controller { public function indexAction() { return $this->render('AppAdminBundle:Member:login.html.twig'); } public function loginAction() { $request = $this->get('request'); $session = $this->get('session'); if ($request->attributes->has(SecurityContext::AUTHENTICATION_ERROR)) { $error = $request->attributes->get(SecurityContext::AUTHENTICATION_ERROR); } else { $error = $session->get(SecurityContext::AUTHENTICATION_ERROR); $session->remove(SecurityContext::AUTHENTICATION_ERROR); } return $this->render('AppAdminBundle:Member:login.html.twig',array( 'last_username' => $session->get(SecurityContext::LAST_USERNAME),'error' => $error,)); } } 我的login.html.twig: <form class="login-form" action="{{ path('login_check') }}"> <div class="login-wrap"> <p class="login-img"><i class="icon_lock_alt"></i></p> <div class="input-group"> <span class="input-group-addon"><i class="icon_profile"></i></span> <input type="text" id="username" name="_username" value="{{ last_username }}" class="form-control" placeholder="Username" autofocus> </div> <div class="input-group"> <span class="input-group-addon"><i class="icon_key_alt"></i></span> <input type="password" class="form-control" id="password" name="_password" placeholder="Password"> </div> <button class="btn btn-primary btn-lg btn-block" type="submit">Login</button> </div> </form> 而我的security.yml: security: role_hierarchy: ROLE_ADMIN: ROLE_USER ROLE_FMTI: ROLE_FMTI ROLE_SUPER_ADMIN: [ROLE_USER,ROLE_ADMIN,ROLE_ALLOWED_TO_SWITCH] access_control: - { path: ^/login,role: IS_AUTHENTICATED_ANONYMOUSLY } - { path: ^/admin,role: IS_AUTHENTICATED_ANONYMOUSLY } firewalls: dev: pattern: ^/(_(profiler|wdt)|css|images|js)/ security: false secured_area: pattern: ^/admin anonymous: ~ form_login: login_path: /admin/login check_path: /admin/login_check access_control: - { path: ^/admin,roles: ROLE_ADMIN } providers: in_memory: memory: users: admin: { password: 222221,roles: 'ROLE_FMTI' } encoders: SymfonyComponentSecurityCoreUserUser: plaintext 当我尝试访问:/ admin / login 我收到此错误:您已请求不存在的服务“请求”.你的意思是其中之一:“router.request_context”,“request_stack”,“monolog.logger.request”,“data_collector.request”? 请你帮助我好吗 ?提前致谢,对不起我的英语 解决方法
这是因为您试图在控制器中获得不存在的服务.在symfony控制器中,您可以在方法调用中获取请求:
在Logincontroller中,添加以下use语句: use SymfonyComponentHttpFoundationRequest; 并在您的函数声明中 public function loginAction(Request $request) { // you can directly use $request .... } 您现在可以删除尝试获取不存在服务的行: // remove this line $request = $this->get('request'); 此外,我不确定你会得到一个get(‘session’)会话.根据Symfony的文档,您应该执行以下操作: $session = $request->getSession(); 见http://symfony.com/doc/current/book/controller.html#managing-the-session (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |