问题描述
我正在关注 此 auth0 的教程 以确保我的应用程序使用 JWT.
I'm following this auth0's tutorial to secure my application using JWT.
我最终得到了以下 WebSecurity 配置:
I've ended up with the following WebSecurity configuration:
以及以下 JWTAuthenticationFilter:
and the following JWTAuthenticationFilter:
目前,该应用接受 /login
URL 上的 POST 请求.我想知道如何将 URL 更改为,比如说,/api/auth/login
.有没有办法将 URL 字符串注入身份验证过滤器或以某种方式在安全配置中进行设置?
At the moment, the app accepts POST requests on the /login
URL. I wonder how to change the URL to, let's say, /api/auth/login
. Is there any way to inject the URL string into the authentication filter or to set it somehow in the security config?
推荐答案
你正在扩展 org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter 本身扩展org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter.在这最后一个类中,有一个名为 setFilterProcessesUrl
的设置器,它的目的就是这样做:
You are extending org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter which itself extends
org.springframework.security.web.authentication.AbstractAuthenticationProcessingFilter. In this last class, there is a setter called setFilterProcessesUrl
which is intended to do just this:
setFilterProcessesUrl
public void setFilterProcessesUrl(String filterProcessesUrl)
public void setFilterProcessesUrl(String filterProcessesUrl)
设置确定是否需要身份验证的 URL
Sets the URL that determines if authentication is required
参数:filterProcessesUrl
Parameters: filterProcessesUrl
This 是指向该 javadoc 部分的链接
This is the link to that javadoc section
所以在你的 WebSecurityConfigurerAdapter
你可以这样做:
So in your WebSecurityConfigurerAdapter
you could do just like this:
然后在同一个类的 configure
方法中只引用它而不是创建新实例:
And then in your configure
method in the same class just reference it instead of creating new instance:
这篇关于在 Spring Security UsernamePasswordAuthenticationFilter JWT 身份验证中设置自定义登录 url的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!