Php 找不到Lexik JWT令牌
我看到过类似的问题,但仍然无法实现 我是Symfony的新手,我使用Lexik JWT捆绑包和symfony3进行API身份验证,并使用登录表单进行web身份验证 我得到了令牌,但当我尝试使用它时,我得到了401-错误的身份验证。 我知道这可能是apache的问题,所以我尝试使用PHP的内置web服务器,但仍然没有成功 这是我的security.yml文件:Php 找不到Lexik JWT令牌,php,jwt,symfony,lexikjwtauthbundle,Php,Jwt,Symfony,Lexikjwtauthbundle,我看到过类似的问题,但仍然无法实现 我是Symfony的新手,我使用Lexik JWT捆绑包和symfony3进行API身份验证,并使用登录表单进行web身份验证 我得到了令牌,但当我尝试使用它时,我得到了401-错误的身份验证。 我知道这可能是apache的问题,所以我尝试使用PHP的内置web服务器,但仍然没有成功 这是我的security.yml文件: security: encoders: AppBundle\Entity\User: algorithm: bc
security:
encoders:
AppBundle\Entity\User:
algorithm: bcrypt
# http://symfony.com/doc/current/book/security.html#where-do-users-come-from-user-providers
providers:
in_memory:
memory: ~
our_db_provider:
entity:
class: AppBundle:User
property: username
firewalls:
# disables authentication for assets and the profiler, adapt it according to your needs
dev:
pattern: ^/(_(profiler|wdt)|css|images|js)/
security: false
login:
pattern: ^/api/login
stateless: true
anonymous: true
form_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
provider: our_db_provider
api:
pattern: ^/api
stateless: true
provider: our_db_provider
lexik_jwt:
authorization_header: # check token in Authorization Header
enabled: true
prefix: Bearer
throw_exceptions: true # When an authentication failure occurs, return a 401 response immediately
create_entry_point: true # When no authentication details are provided, create a default entry point that returns a 401 response
main:
anonymous: ~
form_login:
login_path: /login
check_path: /login_check
provider: our_db_provider
access_control:
- { path: ^/api/login, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/api, roles: IS_AUTHENTICATED_FULLY }
- { path: ^/login, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/register, roles: IS_AUTHENTICATED_ANONYMOUSLY }
- { path: ^/, roles: [ROLE_ADMIN, ROLE_USER] }
如果我在api防火墙中将create_entry_point设置为false,我会得到一个500错误:在令牌存储中找不到令牌
也许我把代币传错了方向?我试过几种方法,因为我不确定哪一种是正确的。以下是我的标题:
POST /api/notifications HTTP/1.1
Host: localhost:8000
Authorization: bearer {"token":"eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXUyJ9.eyJleHAiOjE0NTUwMDk1ODAsInVzZXJuYW1lIjoiYXNvcmlhIiwiaWF0IjoiMTQ1NDkyMzE4MCJ9.rwgAkLBesTYOZn3B96Jlsf9_3Qy-rjrRt2l5UxdXD8ZadJ2YbK-9m7qNqUd9-bhaA_MFL1lssPZ-0AzmQCZx8bL8XD_l2_df0wfVm6Le6pEJEJk0arbyxlEOZ-9LrRdOa6EjnzDcZT6Wn76QNOsCSjME7rjk0w0lLs4eXAaXGAYL6lqU4YoiM1xnifzHgGtJKc7RBBivY8yHjfs51S6GwEKzPGrYMUTZWmjhxFPlKZCqEJlaJ6NT82A3PuoISCMUvt7AuxhHdgeuS-TMjdTY-WhqaL7f7Z2FP0_FstKVORHDzC1vf7VlylF76SnF0Sh2tMTuvf70zYnD_gF0k7b9zoOp54e0mJt0XaLTyCtomPSeDhfJV1wJY6EZsrvdUrrHXXtXhA6K70FIM_nQJPVo4Raht-hQWmOnWb3Ib0SvvytQHP96klXVgKHyIaicEjvWhmonzgSRndme4HGXlPWmbKH6tVJpvWatOeaWD4jjS-ZLD_5oBr_o3vNPw81oZj0huI6OgzYvXDpLPw3P7Ma4LmBdQOLwpUEPG3LnuKIdU27umFTrN3T-Cfrb6kITU1BTaTL-AIOM-F6FDlcgJfYxOs6GEFOlFtjJ5KSAEiY8DWiubbrS-VH9uaMlc9YapTlNVsUI7whzO7QmXzC-V8idrNoWBWVftyMDlA9YR_D7N9E"}
Cache-Control: no-cache
Content-Type: application/x-www-form-urlencoded
或
有什么想法吗
提前谢谢 授权标头应为
授权:持票人EYJHBGCIOIJZI1NIISINR5CCI6IKPXUYJ9…9年
第一个解决方案用于解决“401-错误身份验证”错误
但是对于出现错误“401-JWT令牌未找到”的Apache用户,解决方案是通过在virtualhost上放置以下说明来重写请求的HTTP授权头:
RewriteEngine On
RewriteCond %{HTTP:Authorization} ^(.*)
RewriteRule .* - [e=HTTP_AUTHORIZATION:%1]
您可以在、上和上找到有关此问题的更多阅读资料。如果有人仍然存在此问题,尤其是在完成上述所有操作后,您可以尝试类似的方法。您可以使用自定义HTTP头,例如
Php Auth Digest
,而不是使用HTTP\u授权。使用HTTP\u授权
可能很棘手,并且由于各种不同的服务器设置(特别是使用共享服务器环境、cPanel等),可能会从请求中删除
在LexikJWT包中接受自定义http头的配置如下:
lexik_jwt_authentication:
# token extraction settings
token_extractors:
# look for a token as Authorization Header
authorization_header:
enabled: true
prefix: Bearer
name: Php-Auth-Digest
要了解有关此链接的更多信息,请访问此链接-
从api应用程序发送标题的方式如下(这是Angular 6中的一个示例)
我希望这对某人有帮助。干杯。是的,就是这样!问题似乎出在小写的“bearer”中,因为现在它可以使用大括号,也可以不使用大括号。我发誓一开始我试过使用大写字母B,但我想当时我的配置出了问题。非常感谢你^^是的,如果您仔细阅读防火墙的配置,您会发现您可以将其更改为:将前缀:Bearer
更改为前缀:Foo
,您可以使用授权:Foo eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXUyJ9…9YR_D7N9E
传递您的令牌。在我的情况下,/web目录中缺少.htaccess。此外,还可以将重写条件添加到。htaccessI可以确认这些apache设置。我的错误与此相似。引发了一个不充分的AuthenticationException。我们的配置是一个在nginx负载平衡器、反向代理和ssl终止VM后面带有apache的VM。我很确定,如果没有nginx网关,这些线路不会出现在我们的旧服务器上。
lexik_jwt_authentication:
# token extraction settings
token_extractors:
# look for a token as Authorization Header
authorization_header:
enabled: true
prefix: Bearer
name: Php-Auth-Digest
request = request.clone({
setHeaders: {
"Php-Auth-Digest": `Bearer ${currentUser.token}`,
}
});