如何使用 API PLATFORM (symfony 4) 添加登录到 swagger UI?
How to add Login to swagger UI with API PLATFORM (symfony 4)?
我安装并配置了 LexikJWTAuthenticationBundle,它工作正常,但我遇到了一个小问题。
我已经包含了用于放置 JWT 令牌的授权按钮,问题是我可以获得令牌的唯一方法是使用此命令:
curl -X POST -H "Content-Type: application/json" http://localhost:8000/api/login_check -d '{"username":"johndoe","password":"test"}'
它发送给我的令牌,我把它放在 API 中,好的。
第一个问题:
当我用 POSTMAN 尝试这个请求时,我得到一个错误:
Unable to find the controller for path "/api/login_check".
The route is wrongly configured. (404 Not Found)
请求:localhost:8000/api/login_check?username=johndoe&password=test with POST method
所以使用 curl 它可以工作,但不能使用 POSTMAN,为什么?这是我的 security.yaml:
security:
encoders:
App\Entity\User:
algorithm: argon2i
providers:
app_user_provider:
entity:
class: App\Entity\User
property: email
firewalls:
dev:
pattern: ^/(_(profiler|wdt)|css|images|js)/
security: false
login:
pattern: ^/api/login
stateless: true
anonymous: true
json_login:
check_path: /api/login_check
success_handler: lexik_jwt_authentication.handler.authentication_success
failure_handler: lexik_jwt_authentication.handler.authentication_failure
require_previous_session: false
register:
pattern: ^/api/register
stateless: true
anonymous: true
api:
pattern: ^/api
stateless: true
anonymous: true
provider: app_user_provider
main:
anonymous: true
access_control:
- { path: ^/api/login, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/api/register, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/api, roles: IS_AUTHENTICATED_ANONYMOUSLY }
role_hierarchy:
ROLE_DELEGATION: [ROLE_USER]
ROLE_EXPORT: [ROLE_USER]
ROLE_USER_ADMIN: [ROLE_USER]
ROLE_LIST_ADMIN: [ROLE_USER]
ROLE_IMPORT: [ROLE_USER]
ROLE_MOBILE: [ROLE_USER]
ROLE_ADMIN: [ROLE_USER, ROLE_ALLOWED_TO_SWITCH]
ROLE_SUPER_ADMIN: [ROLE_USER, ROLE_ALLOWED_TO_SWITCH]
第二个问题,我想在Swagger中添加登录。
像这样:
我不知道该怎么做,尝试在 LoginCheckController 中添加 @ApiRessource() 但它什么也没做。
需要一些帮助/提示,提前致谢
只需将您的防火墙登录名放在首位,在您的示例中,dev 上方。
404 消息告诉您没有路由定义 /api/login_check
或者它存在配置问题并且找不到路由
你应该先 check and debug your routes 看看是否已经定义了
login_check:
path: /login_check
您可能还想查看此 GitHub Issue
稍后编辑:
经过更多研究后,我找到了解决您问题的可能方法
我安装并配置了 LexikJWTAuthenticationBundle,它工作正常,但我遇到了一个小问题。
我已经包含了用于放置 JWT 令牌的授权按钮,问题是我可以获得令牌的唯一方法是使用此命令:
curl -X POST -H "Content-Type: application/json" http://localhost:8000/api/login_check -d '{"username":"johndoe","password":"test"}'
它发送给我的令牌,我把它放在 API 中,好的。
第一个问题: 当我用 POSTMAN 尝试这个请求时,我得到一个错误:
Unable to find the controller for path "/api/login_check". The route is wrongly configured. (404 Not Found)
请求:localhost:8000/api/login_check?username=johndoe&password=test with POST method
所以使用 curl 它可以工作,但不能使用 POSTMAN,为什么?这是我的 security.yaml:
security:
encoders:
App\Entity\User:
algorithm: argon2i
providers:
app_user_provider:
entity:
class: App\Entity\User
property: email
firewalls:
dev:
pattern: ^/(_(profiler|wdt)|css|images|js)/
security: false
login:
pattern: ^/api/login
stateless: true
anonymous: true
json_login:
check_path: /api/login_check
success_handler: lexik_jwt_authentication.handler.authentication_success
failure_handler: lexik_jwt_authentication.handler.authentication_failure
require_previous_session: false
register:
pattern: ^/api/register
stateless: true
anonymous: true
api:
pattern: ^/api
stateless: true
anonymous: true
provider: app_user_provider
main:
anonymous: true
access_control:
- { path: ^/api/login, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/api/register, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/api, roles: IS_AUTHENTICATED_ANONYMOUSLY }
role_hierarchy:
ROLE_DELEGATION: [ROLE_USER]
ROLE_EXPORT: [ROLE_USER]
ROLE_USER_ADMIN: [ROLE_USER]
ROLE_LIST_ADMIN: [ROLE_USER]
ROLE_IMPORT: [ROLE_USER]
ROLE_MOBILE: [ROLE_USER]
ROLE_ADMIN: [ROLE_USER, ROLE_ALLOWED_TO_SWITCH]
ROLE_SUPER_ADMIN: [ROLE_USER, ROLE_ALLOWED_TO_SWITCH]
第二个问题,我想在Swagger中添加登录。
像这样:
我不知道该怎么做,尝试在 LoginCheckController 中添加 @ApiRessource() 但它什么也没做。
需要一些帮助/提示,提前致谢
只需将您的防火墙登录名放在首位,在您的示例中,dev 上方。
404 消息告诉您没有路由定义 /api/login_check
或者它存在配置问题并且找不到路由
你应该先 check and debug your routes 看看是否已经定义了
login_check:
path: /login_check
您可能还想查看此 GitHub Issue
稍后编辑:
经过更多研究后,我找到了解决您问题的可能方法