parent
428b0e45aa
commit
658acf0332
|
@ -1,156 +0,0 @@
|
||||||
package org.springframework.security.config.http
|
|
||||||
|
|
||||||
import java.text.MessageFormat
|
|
||||||
|
|
||||||
import org.springframework.beans.factory.config.PropertyPlaceholderConfigurer
|
|
||||||
import org.springframework.mock.web.MockFilterChain
|
|
||||||
import org.springframework.mock.web.MockHttpServletRequest
|
|
||||||
import org.springframework.mock.web.MockHttpServletResponse
|
|
||||||
import org.springframework.security.access.SecurityConfig
|
|
||||||
import org.springframework.security.config.BeanIds
|
|
||||||
import org.springframework.security.util.FieldUtils
|
|
||||||
import org.springframework.security.web.PortMapperImpl
|
|
||||||
import org.springframework.security.web.access.ExceptionTranslationFilter
|
|
||||||
import org.springframework.security.web.access.channel.ChannelProcessingFilter
|
|
||||||
import org.springframework.security.web.access.intercept.FilterSecurityInterceptor
|
|
||||||
import org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter
|
|
||||||
|
|
||||||
class PlaceHolderAndELConfigTests extends AbstractHttpConfigTests {
|
|
||||||
|
|
||||||
def setup() {
|
|
||||||
// Add a PropertyPlaceholderConfigurer to the context for all the tests
|
|
||||||
bean(PropertyPlaceholderConfigurer.class.name, PropertyPlaceholderConfigurer.class)
|
|
||||||
}
|
|
||||||
|
|
||||||
def unsecuredPatternSupportsPlaceholderForPattern() {
|
|
||||||
System.setProperty("pattern.nofilters", "/unprotected");
|
|
||||||
|
|
||||||
xml.http(pattern: '${pattern.nofilters}', security: 'none')
|
|
||||||
httpAutoConfig() {
|
|
||||||
interceptUrl('/**', 'ROLE_A')
|
|
||||||
}
|
|
||||||
createAppContext()
|
|
||||||
|
|
||||||
List filters = getFilters("/unprotected");
|
|
||||||
|
|
||||||
expect:
|
|
||||||
filters.size() == 0
|
|
||||||
}
|
|
||||||
|
|
||||||
// SEC-1201
|
|
||||||
def interceptUrlsAndFormLoginSupportPropertyPlaceholders() {
|
|
||||||
System.setProperty("secure.Url", "/secure");
|
|
||||||
System.setProperty("secure.role", "ROLE_A");
|
|
||||||
System.setProperty("login.page", "/loginPage");
|
|
||||||
System.setProperty("default.target", "/defaultTarget");
|
|
||||||
System.setProperty("auth.failure", "/authFailure");
|
|
||||||
|
|
||||||
xml.http(pattern: '${login.page}', security: 'none')
|
|
||||||
xml.http('use-expressions':false) {
|
|
||||||
interceptUrl('${secure.Url}', '${secure.role}')
|
|
||||||
'form-login'('login-page':'${login.page}', 'default-target-url': '${default.target}',
|
|
||||||
'authentication-failure-url':'${auth.failure}');
|
|
||||||
}
|
|
||||||
createAppContext();
|
|
||||||
|
|
||||||
expect:
|
|
||||||
propertyValuesMatchPlaceholders()
|
|
||||||
getFilters("/loginPage").size() == 0
|
|
||||||
}
|
|
||||||
|
|
||||||
// SEC-1309
|
|
||||||
def interceptUrlsAndFormLoginSupportEL() {
|
|
||||||
System.setProperty("secure.url", "/secure");
|
|
||||||
System.setProperty("secure.role", "ROLE_A");
|
|
||||||
System.setProperty("login.page", "/loginPage");
|
|
||||||
System.setProperty("default.target", "/defaultTarget");
|
|
||||||
System.setProperty("auth.failure", "/authFailure");
|
|
||||||
|
|
||||||
xml.http('use-expressions':false) {
|
|
||||||
interceptUrl("#{systemProperties['secure.url']}", "#{systemProperties['secure.role']}")
|
|
||||||
'form-login'('login-page':"#{systemProperties['login.page']}", 'default-target-url': "#{systemProperties['default.target']}",
|
|
||||||
'authentication-failure-url':"#{systemProperties['auth.failure']}");
|
|
||||||
}
|
|
||||||
createAppContext()
|
|
||||||
|
|
||||||
expect:
|
|
||||||
propertyValuesMatchPlaceholders()
|
|
||||||
}
|
|
||||||
|
|
||||||
private void propertyValuesMatchPlaceholders() {
|
|
||||||
// Check the security attribute
|
|
||||||
def fis = getFilter(FilterSecurityInterceptor);
|
|
||||||
def fids = fis.getSecurityMetadataSource();
|
|
||||||
Collection attrs = fids.getAttributes(createFilterinvocation("/secure", null));
|
|
||||||
assert attrs.size() == 1
|
|
||||||
assert attrs.contains(new SecurityConfig("ROLE_A"))
|
|
||||||
|
|
||||||
// Check the form login properties are set
|
|
||||||
def apf = getFilter(UsernamePasswordAuthenticationFilter)
|
|
||||||
assert FieldUtils.getFieldValue(apf, "successHandler.defaultTargetUrl") == '/defaultTarget'
|
|
||||||
assert "/authFailure" == FieldUtils.getFieldValue(apf, "failureHandler.defaultFailureUrl")
|
|
||||||
|
|
||||||
def etf = getFilter(ExceptionTranslationFilter)
|
|
||||||
assert "/loginPage"== etf.authenticationEntryPoint.loginFormUrl
|
|
||||||
}
|
|
||||||
|
|
||||||
def portMappingsWorkWithPlaceholdersAndEL() {
|
|
||||||
System.setProperty("http", "9080");
|
|
||||||
System.setProperty("https", "9443");
|
|
||||||
|
|
||||||
httpAutoConfig {
|
|
||||||
'port-mappings'() {
|
|
||||||
'port-mapping'(http: '#{systemProperties.http}', https: '${https}')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
createAppContext();
|
|
||||||
|
|
||||||
def pm = (appContext.getBeansOfType(PortMapperImpl).values() as List)[0];
|
|
||||||
|
|
||||||
expect:
|
|
||||||
pm.getTranslatedPortMappings().size() == 1
|
|
||||||
pm.lookupHttpPort(9443) == 9080
|
|
||||||
pm.lookupHttpsPort(9080) == 9443
|
|
||||||
}
|
|
||||||
|
|
||||||
def requiresChannelSupportsPlaceholder() {
|
|
||||||
System.setProperty("secure.url", "/secure");
|
|
||||||
System.setProperty("required.channel", "https");
|
|
||||||
|
|
||||||
httpAutoConfig {
|
|
||||||
'intercept-url'(pattern: '${secure.url}', 'requires-channel': '${required.channel}')
|
|
||||||
}
|
|
||||||
createAppContext();
|
|
||||||
List filters = getFilters("/secure");
|
|
||||||
|
|
||||||
expect:
|
|
||||||
filters.size() == AUTO_CONFIG_FILTERS + 1
|
|
||||||
filters[0] instanceof ChannelProcessingFilter
|
|
||||||
MockHttpServletRequest request = new MockHttpServletRequest();
|
|
||||||
request.setServletPath("/secure");
|
|
||||||
MockHttpServletResponse response = new MockHttpServletResponse();
|
|
||||||
filters[0].doFilter(request, response, new MockFilterChain());
|
|
||||||
response.getRedirectedUrl().startsWith("https")
|
|
||||||
}
|
|
||||||
|
|
||||||
def accessDeniedPageWorksWithPlaceholders() {
|
|
||||||
System.setProperty("accessDenied", "/go-away");
|
|
||||||
xml.http('auto-config': 'true') {
|
|
||||||
'access-denied-handler'('error-page' : '${accessDenied}') {}
|
|
||||||
}
|
|
||||||
createAppContext();
|
|
||||||
|
|
||||||
expect:
|
|
||||||
FieldUtils.getFieldValue(getFilter(ExceptionTranslationFilter.class), "accessDeniedHandler.errorPage") == '/go-away'
|
|
||||||
}
|
|
||||||
|
|
||||||
def accessDeniedHandlerPageWorksWithEL() {
|
|
||||||
httpAutoConfig {
|
|
||||||
'access-denied-handler'('error-page': "#{'/go' + '-away'}")
|
|
||||||
}
|
|
||||||
createAppContext()
|
|
||||||
|
|
||||||
expect:
|
|
||||||
getFilter(ExceptionTranslationFilter).accessDeniedHandler.errorPage == '/go-away'
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,212 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2002-2018 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.springframework.security.config.http;
|
||||||
|
|
||||||
|
import org.junit.Rule;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.config.test.SpringTestRule;
|
||||||
|
import org.springframework.security.test.context.annotation.SecurityTestExecutionListeners;
|
||||||
|
import org.springframework.security.test.context.support.WithMockUser;
|
||||||
|
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
||||||
|
import org.springframework.test.web.servlet.MockMvc;
|
||||||
|
import org.springframework.web.bind.annotation.GetMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RestController;
|
||||||
|
|
||||||
|
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
|
||||||
|
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.post;
|
||||||
|
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.forwardedUrl;
|
||||||
|
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.redirectedUrl;
|
||||||
|
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Josh Cummings
|
||||||
|
*/
|
||||||
|
@RunWith(SpringJUnit4ClassRunner.class)
|
||||||
|
@SecurityTestExecutionListeners
|
||||||
|
public class PlaceHolderAndELConfigTests {
|
||||||
|
|
||||||
|
private static final String CONFIG_LOCATION_PREFIX =
|
||||||
|
"classpath:org/springframework/security/config/http/PlaceHolderAndELConfigTests";
|
||||||
|
|
||||||
|
@Rule
|
||||||
|
public final SpringTestRule spring = new SpringTestRule();
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
MockMvc mvc;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getWhenUsingPlaceholderThenUnsecuredPatternCorrectlyConfigured()
|
||||||
|
throws Exception {
|
||||||
|
|
||||||
|
System.setProperty("pattern.nofilters", "/unsecured");
|
||||||
|
|
||||||
|
this.spring.configLocations(this.xml("UnsecuredPattern")).autowire();
|
||||||
|
|
||||||
|
this.mvc.perform(get("/unsecured"))
|
||||||
|
.andExpect(status().isOk());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SEC-1201
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void loginWhenUsingPlaceholderThenInterceptUrlsAndFormLoginWorks()
|
||||||
|
throws Exception {
|
||||||
|
|
||||||
|
System.setProperty("secure.Url", "/secured");
|
||||||
|
System.setProperty("secure.role", "ROLE_NUNYA");
|
||||||
|
System.setProperty("login.page", "/loginPage");
|
||||||
|
System.setProperty("default.target", "/defaultTarget");
|
||||||
|
System.setProperty("auth.failure", "/authFailure");
|
||||||
|
|
||||||
|
this.spring.configLocations(this.xml("InterceptUrlAndFormLogin")).autowire();
|
||||||
|
|
||||||
|
// login-page setting
|
||||||
|
|
||||||
|
this.mvc.perform(get("/secured"))
|
||||||
|
.andExpect(redirectedUrl("http://localhost/loginPage"));
|
||||||
|
|
||||||
|
// login-processing-url setting
|
||||||
|
// default-target-url setting
|
||||||
|
|
||||||
|
this.mvc.perform(post("/loginPage")
|
||||||
|
.param("username", "user")
|
||||||
|
.param("password", "password"))
|
||||||
|
.andExpect(redirectedUrl("/defaultTarget"));
|
||||||
|
|
||||||
|
// authentication-failure-url setting
|
||||||
|
|
||||||
|
this.mvc.perform(post("/loginPage")
|
||||||
|
.param("username", "user")
|
||||||
|
.param("password", "wrong"))
|
||||||
|
.andExpect(redirectedUrl("/authFailure"));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SEC-1309
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void loginWhenUsingSpELThenInterceptUrlsAndFormLoginWorks()
|
||||||
|
throws Exception {
|
||||||
|
|
||||||
|
System.setProperty("secure.url", "/secured");
|
||||||
|
System.setProperty("secure.role", "ROLE_NUNYA");
|
||||||
|
System.setProperty("login.page", "/loginPage");
|
||||||
|
System.setProperty("default.target", "/defaultTarget");
|
||||||
|
System.setProperty("auth.failure", "/authFailure");
|
||||||
|
|
||||||
|
this.spring.configLocations(
|
||||||
|
this.xml("InterceptUrlAndFormLoginWithSpEL")).autowire();
|
||||||
|
|
||||||
|
// login-page setting
|
||||||
|
|
||||||
|
this.mvc.perform(get("/secured"))
|
||||||
|
.andExpect(redirectedUrl("http://localhost/loginPage"));
|
||||||
|
|
||||||
|
// login-processing-url setting
|
||||||
|
// default-target-url setting
|
||||||
|
|
||||||
|
this.mvc.perform(post("/loginPage")
|
||||||
|
.param("username", "user")
|
||||||
|
.param("password", "password"))
|
||||||
|
.andExpect(redirectedUrl("/defaultTarget"));
|
||||||
|
|
||||||
|
// authentication-failure-url setting
|
||||||
|
|
||||||
|
this.mvc.perform(post("/loginPage")
|
||||||
|
.param("username", "user")
|
||||||
|
.param("password", "wrong"))
|
||||||
|
.andExpect(redirectedUrl("/authFailure"));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@WithMockUser
|
||||||
|
public void requestWhenUsingPlaceholderOrSpELThenPortMapperWorks()
|
||||||
|
throws Exception {
|
||||||
|
|
||||||
|
System.setProperty("http", "9080");
|
||||||
|
System.setProperty("https", "9443");
|
||||||
|
|
||||||
|
this.spring.configLocations(this.xml("PortMapping")).autowire();
|
||||||
|
|
||||||
|
this.mvc.perform(get("http://localhost:9080/secured"))
|
||||||
|
.andExpect(status().isFound())
|
||||||
|
.andExpect(redirectedUrl("https://localhost:9443/secured"));
|
||||||
|
|
||||||
|
this.mvc.perform(get("https://localhost:9443/unsecured"))
|
||||||
|
.andExpect(status().isFound())
|
||||||
|
.andExpect(redirectedUrl("http://localhost:9080/unsecured"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@WithMockUser
|
||||||
|
public void requestWhenUsingPlaceholderThenRequiresChannelWorks()
|
||||||
|
throws Exception {
|
||||||
|
|
||||||
|
System.setProperty("secure.url", "/secured");
|
||||||
|
System.setProperty("required.channel", "https");
|
||||||
|
|
||||||
|
this.spring.configLocations(this.xml("RequiresChannel")).autowire();
|
||||||
|
|
||||||
|
this.mvc.perform(get("http://localhost/secured"))
|
||||||
|
.andExpect(status().isFound())
|
||||||
|
.andExpect(redirectedUrl("https://localhost/secured"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@WithMockUser
|
||||||
|
public void requestWhenUsingPlaceholderThenAccessDeniedPageWorks()
|
||||||
|
throws Exception {
|
||||||
|
|
||||||
|
System.setProperty("accessDenied", "/go-away");
|
||||||
|
|
||||||
|
this.spring.configLocations(this.xml("AccessDeniedPage")).autowire();
|
||||||
|
|
||||||
|
this.mvc.perform(get("/secured"))
|
||||||
|
.andExpect(forwardedUrl("/go-away"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@WithMockUser
|
||||||
|
public void requestWhenUsingSpELThenAccessDeniedPageWorks()
|
||||||
|
throws Exception {
|
||||||
|
|
||||||
|
this.spring.configLocations(this.xml("AccessDeniedPageWithSpEL")).autowire();
|
||||||
|
|
||||||
|
this.mvc.perform(get("/secured"))
|
||||||
|
.andExpect(forwardedUrl("/go-away"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@RestController
|
||||||
|
static class SimpleController {
|
||||||
|
@GetMapping("/unsecured")
|
||||||
|
String unsecured() {
|
||||||
|
return "unsecured";
|
||||||
|
}
|
||||||
|
|
||||||
|
@GetMapping("/secured")
|
||||||
|
String secured() {
|
||||||
|
return "secured";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private String xml(String configName) {
|
||||||
|
return CONFIG_LOCATION_PREFIX + "-" + configName + ".xml";
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,37 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!--
|
||||||
|
~ Copyright 2002-2018 the original author or authors.
|
||||||
|
~
|
||||||
|
~ Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
~ you may not use this file except in compliance with the License.
|
||||||
|
~ You may obtain a copy of the License at
|
||||||
|
~
|
||||||
|
~ http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
~
|
||||||
|
~ Unless required by applicable law or agreed to in writing, software
|
||||||
|
~ distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
~ See the License for the specific language governing permissions and
|
||||||
|
~ limitations under the License.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<b:beans xmlns:b="http://www.springframework.org/schema/beans"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xmlns="http://www.springframework.org/schema/security"
|
||||||
|
xsi:schemaLocation="
|
||||||
|
http://www.springframework.org/schema/security
|
||||||
|
http://www.springframework.org/schema/security/spring-security.xsd
|
||||||
|
http://www.springframework.org/schema/beans
|
||||||
|
http://www.springframework.org/schema/beans/spring-beans.xsd">
|
||||||
|
|
||||||
|
<http auto-config="true" use-expressions="false">
|
||||||
|
<intercept-url pattern="/secured" access="ROLE_NUNYA"/>
|
||||||
|
<access-denied-handler error-page="${accessDenied}"/>
|
||||||
|
</http>
|
||||||
|
|
||||||
|
<b:bean name="propertyPlaceholderConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"/>
|
||||||
|
|
||||||
|
<b:bean name="sc" class="org.springframework.security.config.http.PlaceHolderAndELConfigTests.SimpleController"/>
|
||||||
|
|
||||||
|
<b:import resource="userservice.xml"/>
|
||||||
|
</b:beans>
|
|
@ -0,0 +1,37 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!--
|
||||||
|
~ Copyright 2002-2018 the original author or authors.
|
||||||
|
~
|
||||||
|
~ Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
~ you may not use this file except in compliance with the License.
|
||||||
|
~ You may obtain a copy of the License at
|
||||||
|
~
|
||||||
|
~ http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
~
|
||||||
|
~ Unless required by applicable law or agreed to in writing, software
|
||||||
|
~ distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
~ See the License for the specific language governing permissions and
|
||||||
|
~ limitations under the License.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<b:beans xmlns:b="http://www.springframework.org/schema/beans"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xmlns="http://www.springframework.org/schema/security"
|
||||||
|
xsi:schemaLocation="
|
||||||
|
http://www.springframework.org/schema/security
|
||||||
|
http://www.springframework.org/schema/security/spring-security.xsd
|
||||||
|
http://www.springframework.org/schema/beans
|
||||||
|
http://www.springframework.org/schema/beans/spring-beans.xsd">
|
||||||
|
|
||||||
|
<http auto-config="true" use-expressions="false">
|
||||||
|
<intercept-url pattern="/secured" access="ROLE_NUNYA"/>
|
||||||
|
<access-denied-handler error-page="#{'/go' + '-away'}"/>
|
||||||
|
</http>
|
||||||
|
|
||||||
|
<b:bean name="propertyPlaceholderConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"/>
|
||||||
|
|
||||||
|
<b:bean name="sc" class="org.springframework.security.config.http.PlaceHolderAndELConfigTests.SimpleController"/>
|
||||||
|
|
||||||
|
<b:import resource="userservice.xml"/>
|
||||||
|
</b:beans>
|
|
@ -0,0 +1,42 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!--
|
||||||
|
~ Copyright 2002-2018 the original author or authors.
|
||||||
|
~
|
||||||
|
~ Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
~ you may not use this file except in compliance with the License.
|
||||||
|
~ You may obtain a copy of the License at
|
||||||
|
~
|
||||||
|
~ http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
~
|
||||||
|
~ Unless required by applicable law or agreed to in writing, software
|
||||||
|
~ distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
~ See the License for the specific language governing permissions and
|
||||||
|
~ limitations under the License.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<b:beans xmlns:b="http://www.springframework.org/schema/beans"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xmlns="http://www.springframework.org/schema/security"
|
||||||
|
xsi:schemaLocation="
|
||||||
|
http://www.springframework.org/schema/security
|
||||||
|
http://www.springframework.org/schema/security/spring-security.xsd
|
||||||
|
http://www.springframework.org/schema/beans
|
||||||
|
http://www.springframework.org/schema/beans/spring-beans.xsd">
|
||||||
|
|
||||||
|
<http use-expressions="false">
|
||||||
|
<intercept-url pattern="${secure.Url}" access="${secure.role}"/>
|
||||||
|
<form-login
|
||||||
|
login-page="${login.page}"
|
||||||
|
login-processing-url="${login.page}"
|
||||||
|
default-target-url="${default.target}"
|
||||||
|
authentication-failure-url="${auth.failure}"/>
|
||||||
|
<csrf disabled="true"/>
|
||||||
|
</http>
|
||||||
|
|
||||||
|
<b:bean name="propertyPlaceholderConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"/>
|
||||||
|
|
||||||
|
<b:bean name="unsecured" class="org.springframework.security.config.http.PlaceHolderAndELConfigTests.SimpleController"/>
|
||||||
|
|
||||||
|
<b:import resource="userservice.xml"/>
|
||||||
|
</b:beans>
|
|
@ -0,0 +1,45 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!--
|
||||||
|
~ Copyright 2002-2018 the original author or authors.
|
||||||
|
~
|
||||||
|
~ Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
~ you may not use this file except in compliance with the License.
|
||||||
|
~ You may obtain a copy of the License at
|
||||||
|
~
|
||||||
|
~ http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
~
|
||||||
|
~ Unless required by applicable law or agreed to in writing, software
|
||||||
|
~ distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
~ See the License for the specific language governing permissions and
|
||||||
|
~ limitations under the License.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<b:beans xmlns:b="http://www.springframework.org/schema/beans"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xmlns="http://www.springframework.org/schema/security"
|
||||||
|
xsi:schemaLocation="
|
||||||
|
http://www.springframework.org/schema/security
|
||||||
|
http://www.springframework.org/schema/security/spring-security.xsd
|
||||||
|
http://www.springframework.org/schema/beans
|
||||||
|
http://www.springframework.org/schema/beans/spring-beans.xsd">
|
||||||
|
|
||||||
|
<http use-expressions="false">
|
||||||
|
<intercept-url
|
||||||
|
pattern="#{systemProperties['secure.url']}"
|
||||||
|
access="#{systemProperties['secure.role']}"/>
|
||||||
|
|
||||||
|
<form-login
|
||||||
|
login-page="#{systemProperties['login.page']}"
|
||||||
|
login-processing-url="#{systemProperties['login.page']}"
|
||||||
|
default-target-url="#{systemProperties['default.target']}"
|
||||||
|
authentication-failure-url="#{systemProperties['auth.failure']}"/>
|
||||||
|
<csrf disabled="true"/>
|
||||||
|
</http>
|
||||||
|
|
||||||
|
<b:bean name="propertyPlaceholderConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"/>
|
||||||
|
|
||||||
|
<b:bean name="sc" class="org.springframework.security.config.http.PlaceHolderAndELConfigTests.SimpleController"/>
|
||||||
|
|
||||||
|
<b:import resource="userservice.xml"/>
|
||||||
|
</b:beans>
|
|
@ -0,0 +1,41 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!--
|
||||||
|
~ Copyright 2002-2018 the original author or authors.
|
||||||
|
~
|
||||||
|
~ Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
~ you may not use this file except in compliance with the License.
|
||||||
|
~ You may obtain a copy of the License at
|
||||||
|
~
|
||||||
|
~ http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
~
|
||||||
|
~ Unless required by applicable law or agreed to in writing, software
|
||||||
|
~ distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
~ See the License for the specific language governing permissions and
|
||||||
|
~ limitations under the License.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<b:beans xmlns:b="http://www.springframework.org/schema/beans"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xmlns="http://www.springframework.org/schema/security"
|
||||||
|
xsi:schemaLocation="
|
||||||
|
http://www.springframework.org/schema/security
|
||||||
|
http://www.springframework.org/schema/security/spring-security.xsd
|
||||||
|
http://www.springframework.org/schema/beans
|
||||||
|
http://www.springframework.org/schema/beans/spring-beans.xsd">
|
||||||
|
|
||||||
|
<http auto-config="true" use-expressions="false">
|
||||||
|
<intercept-url pattern="/secured" access="ROLE_USER" requires-channel="https"/>
|
||||||
|
<intercept-url pattern="/unsecured" access="ROLE_USER" requires-channel="http"/>
|
||||||
|
|
||||||
|
<port-mappings>
|
||||||
|
<port-mapping http="#{systemProperties.http}" https="${https}"/>
|
||||||
|
</port-mappings>
|
||||||
|
</http>
|
||||||
|
|
||||||
|
<b:bean name="propertyPlaceholderConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"/>
|
||||||
|
|
||||||
|
<b:bean name="sc" class="org.springframework.security.config.http.PlaceHolderAndELConfigTests.SimpleController"/>
|
||||||
|
|
||||||
|
<b:import resource="userservice.xml"/>
|
||||||
|
</b:beans>
|
|
@ -0,0 +1,36 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!--
|
||||||
|
~ Copyright 2002-2018 the original author or authors.
|
||||||
|
~
|
||||||
|
~ Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
~ you may not use this file except in compliance with the License.
|
||||||
|
~ You may obtain a copy of the License at
|
||||||
|
~
|
||||||
|
~ http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
~
|
||||||
|
~ Unless required by applicable law or agreed to in writing, software
|
||||||
|
~ distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
~ See the License for the specific language governing permissions and
|
||||||
|
~ limitations under the License.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<b:beans xmlns:b="http://www.springframework.org/schema/beans"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xmlns="http://www.springframework.org/schema/security"
|
||||||
|
xsi:schemaLocation="
|
||||||
|
http://www.springframework.org/schema/security
|
||||||
|
http://www.springframework.org/schema/security/spring-security.xsd
|
||||||
|
http://www.springframework.org/schema/beans
|
||||||
|
http://www.springframework.org/schema/beans/spring-beans.xsd">
|
||||||
|
|
||||||
|
<http auto-config="true" use-expressions="false">
|
||||||
|
<intercept-url pattern="${secure.url}" access="ROLE_USER" requires-channel="${required.channel}"/>
|
||||||
|
</http>
|
||||||
|
|
||||||
|
<b:bean name="propertyPlaceholderConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"/>
|
||||||
|
|
||||||
|
<b:bean name="sc" class="org.springframework.security.config.http.PlaceHolderAndELConfigTests.SimpleController"/>
|
||||||
|
|
||||||
|
<b:import resource="userservice.xml"/>
|
||||||
|
</b:beans>
|
|
@ -0,0 +1,38 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!--
|
||||||
|
~ Copyright 2002-2018 the original author or authors.
|
||||||
|
~
|
||||||
|
~ Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
~ you may not use this file except in compliance with the License.
|
||||||
|
~ You may obtain a copy of the License at
|
||||||
|
~
|
||||||
|
~ http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
~
|
||||||
|
~ Unless required by applicable law or agreed to in writing, software
|
||||||
|
~ distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
~ See the License for the specific language governing permissions and
|
||||||
|
~ limitations under the License.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<b:beans xmlns:b="http://www.springframework.org/schema/beans"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xmlns="http://www.springframework.org/schema/security"
|
||||||
|
xsi:schemaLocation="
|
||||||
|
http://www.springframework.org/schema/security
|
||||||
|
http://www.springframework.org/schema/security/spring-security.xsd
|
||||||
|
http://www.springframework.org/schema/beans
|
||||||
|
http://www.springframework.org/schema/beans/spring-beans.xsd">
|
||||||
|
|
||||||
|
<http pattern="${pattern.nofilters}" security="none"/>
|
||||||
|
|
||||||
|
<http auto-config="true" use-expressions="false">
|
||||||
|
<intercept-url pattern="/**" access="ROLE_NUNYA"/>
|
||||||
|
</http>
|
||||||
|
|
||||||
|
<b:bean name="propertyPlaceholderConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"/>
|
||||||
|
|
||||||
|
<b:bean name="unsecured" class="org.springframework.security.config.http.PlaceHolderAndELConfigTests.SimpleController"/>
|
||||||
|
|
||||||
|
<b:import resource="userservice.xml"/>
|
||||||
|
</b:beans>
|
Loading…
Reference in New Issue