gpt4 book ai didi

spring-security - 打开和关闭 spring security SAML 的方法

转载 作者:行者123 更新时间:2023-12-04 07:00:11 25 4
gpt4 key购买 nike

除了其他身份验证机制外,我在我的应用程序中还有一个相当标准的 spring security saml 实现。开箱即用的 SAML 不会被配置,但可以通过表单进行配置,因此默认情况下 SAML 应该被禁用。我希望能够轻松地打开/关闭 SAML,但不确定最好的方法是什么。

似乎一种方法是执行自定义 FilterChainProxy,如果我检查是否启用了 saml,如果启用则忽略 samlFilter 链(How to delete one filter from default filter stack in Spring Security?),并对元数据生成器过滤器执行类似的实现。

任何建议都会很棒。

这是我的配置:

<http auto-config="false" use-expressions="true"
access-decision-manager-ref="webAccessDecisionManager"
disable-url-rewriting="false"
create-session="never"
authentication-manager-ref="authenticationManager">

<custom-filter before="FIRST" ref="metadataGeneratorFilter"/>
<custom-filter after="BASIC_AUTH_FILTER" ref="samlFilter"/>
</http>

元数据生成器过滤器:

<beans:bean id="metadataGeneratorFilter" class="org.springframework.security.saml.metadata.MetadataGeneratorFilter">
<beans:constructor-arg>
<beans:bean class="org.springframework.security.saml.metadata.MetadataGenerator">
<beans:property name="entityId" value="${saml.entityId}"/>
<beans:property name="signMetadata" value="${saml.signMetadata}"/>
</beans:bean>
</beans:constructor-arg>
</beans:bean>

样本过滤器:

<beans:bean id="samlFilter" class="org.springframework.security.web.FilterChainProxy">
<filter-chain-map request-matcher="ant">
<filter-chain pattern="/saml/login/**" filters="samlEntryPoint"/>
<filter-chain pattern="/saml/logout/**" filters="samlLogoutFilter"/>
<filter-chain pattern="/saml/metadata/**" filters="metadataDisplayFilter"/>
<filter-chain pattern="/saml/SSO/**" filters="samlWebSSOProcessingFilter"/>
<filter-chain pattern="/saml/SSOHoK/**" filters="samlWebSSOHoKProcessingFilter"/>
<filter-chain pattern="/saml/SingleLogout/**" filters="samlLogoutProcessingFilter"/>
<filter-chain pattern="/saml/discovery/**" filters="samlIDPDiscovery"/>
</filter-chain-map>
</beans:bean>

编辑:这是我的实现,它有点 hackish 并且依赖于已弃用的方法但它有效

下面的代码片段禁用了 MetadataGeneratorFilter:

public class MyMetadataGeneratorFilter extends MetadataGeneratorFilter {

private boolean isActive = false;

public MyMetadataGeneratorFilter(MetadataGenerator generator) {
super(generator);
}

@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
if (isActive) {
processMetadataInitialization((HttpServletRequest) request);
}
chain.doFilter(request, response);
}

public void setActive(boolean active) {
isActive = active;
}
}

还有 Autowiring 的 samlFilter/FilterChainMap。如果启用了 saml,我会保持此链不变,如果它被禁用,我会将链设置为我的服务中的一个空映射,以启用/禁用 saml。

初始化后,我得到 filterchainmap 值:

private Map<RequestMatcher, List<Filter>> map;

@Override
public void init() throws ServiceException, MetadataProviderException {

SamlConfig samlConfig = getConfig();
map = samlFilter.getFilterChainMap();

applySamlConfig(samlConfig);

}

在下面的方法中,我将过滤器链映射设置为 spring xml 中提供的原始映射(如果启用)或空映射(如果禁用)。

public void applySamlConfig(SamlConfig samlConfig) throws ServiceException, MetadataProviderException {


if (!samlConfig.isEnabled()) {
Map<RequestMatcher, List<Filter>> emptyMap = samlFilter.getFilterChainMap();
emptyMap.clear();
samlFilter.setFilterChainMap(emptyMap);
return;
}

samlFilter.setFilterChainMap(map);

最佳答案

我在entry-point-ref 定义 中添加了自定义过滤器。如果未启用该功能,此过滤器将跳过所有后续过滤器。

<security:http entry-point-ref="samlEntryPoint">
<security:intercept-url pattern="/**" access="IS_AUTHENTICATED_FULLY" />
<!-- This filter checks if the SSO-Feature is enabled - otherwise all following security filters will be skipped -->
<security:custom-filter before="BASIC_AUTH_FILTER" ref="ssoEnabledFilter"/>
<security:custom-filter before="FIRST" ref="metadataGeneratorFilter" />
<security:custom-filter after="BASIC_AUTH_FILTER" ref="samlFilter" />

ssoEnabledFilter:

    public class SsoEnabledFilter extends GenericFilterBean {

@Override
public void doFilter(final ServletRequest request, final ServletResponse response, final FilterChain filterChain) throws IOException, ServletException {
boolean ssoEnabled = isSsoEnabled();

if (ssoEnabled) {
filterChain.doFilter(request, response);
} else {
request.getRequestDispatcher(((HttpServletRequest) request).getServletPath()).forward(request, response);
}
}
}

关于spring-security - 打开和关闭 spring security SAML 的方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25171556/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com