瀏覽代碼

Merge pull request #5260 from jzheaux/gh-4939-FormLoginBeanDefinitionParserTests

FormLoginBeanDefinitionParserTests groovy->java
Josh Cummings 7 年之前
父節點
當前提交
359a73eff2

+ 0 - 153
config/src/test/groovy/org/springframework/security/config/http/FormLoginBeanDefinitionParserTests.groovy

@@ -1,153 +0,0 @@
-package org.springframework.security.config.http
-
-import org.springframework.mock.web.MockFilterChain
-import org.springframework.mock.web.MockHttpServletRequest
-import org.springframework.mock.web.MockHttpServletResponse
-import org.springframework.security.web.WebAttributes
-
-/**
- *
- * @author Luke Taylor
- */
-class FormLoginBeanDefinitionParserTests extends AbstractHttpConfigTests {
-
-	def 'form-login default login page'() {
-		setup:
-			MockHttpServletRequest request = new MockHttpServletRequest(method:'GET',requestURI:'/login')
-			MockHttpServletResponse response = new MockHttpServletResponse()
-			MockFilterChain chain = new MockFilterChain()
-			httpAutoConfig {
-				csrf(disabled:true)
-			}
-			createAppContext()
-		when:
-			springSecurityFilterChain.doFilter(request,response,chain)
-		then:
-			response.getContentAsString() == """<html><head><title>Login Page</title></head><body onload='document.f.username.focus();'>
-<h3>Login with Username and Password</h3><form name='f' action='/login' method='POST'>
-<table>
-	<tr><td>User:</td><td><input type='text' name='username' value=''></td></tr>
-	<tr><td>Password:</td><td><input type='password' name='password'/></td></tr>
-	<tr><td colspan='2'><input name="submit" type="submit" value="Login"/></td></tr>
-</table>
-</form></body></html>"""
-	}
-
-	def 'form-login default login page custom attributes'() {
-		setup:
-			MockHttpServletRequest request = new MockHttpServletRequest(method:'GET',requestURI:'/login')
-			MockHttpServletResponse response = new MockHttpServletResponse()
-			MockFilterChain chain = new MockFilterChain()
-			httpAutoConfig {
-				'form-login'('login-processing-url':'/login_custom','username-parameter':'custom_user','password-parameter':'custom_password')
-				csrf(disabled:true)
-			}
-			createAppContext()
-		when:
-			springSecurityFilterChain.doFilter(request,response,chain)
-		then:
-			response.getContentAsString() == """<html><head><title>Login Page</title></head><body onload='document.f.custom_user.focus();'>
-<h3>Login with Username and Password</h3><form name='f' action='/login_custom' method='POST'>
-<table>
-	<tr><td>User:</td><td><input type='text' name='custom_user' value=''></td></tr>
-	<tr><td>Password:</td><td><input type='password' name='custom_password'/></td></tr>
-	<tr><td colspan='2'><input name="submit" type="submit" value="Login"/></td></tr>
-</table>
-</form></body></html>"""
-	}
-
-	def 'openid-login default login page'() {
-		setup:
-			MockHttpServletRequest request = new MockHttpServletRequest(method:'GET',requestURI:'/login')
-			MockHttpServletResponse response = new MockHttpServletResponse()
-			MockFilterChain chain = new MockFilterChain()
-			httpAutoConfig {
-				'openid-login'()
-				csrf(disabled:true)
-			}
-			createAppContext()
-		when:
-			springSecurityFilterChain.doFilter(request,response,chain)
-		then:
-			response.getContentAsString() == """<html><head><title>Login Page</title></head><body onload='document.f.username.focus();'>
-<h3>Login with Username and Password</h3><form name='f' action='/login' method='POST'>
-<table>
-	<tr><td>User:</td><td><input type='text' name='username' value=''></td></tr>
-	<tr><td>Password:</td><td><input type='password' name='password'/></td></tr>
-	<tr><td colspan='2'><input name="submit" type="submit" value="Login"/></td></tr>
-</table>
-</form><h3>Login with OpenID Identity</h3><form name='oidf' action='/login/openid' method='POST'>
-<table>
-	<tr><td>Identity:</td><td><input type='text' size='30' name='openid_identifier'/></td></tr>
-	<tr><td colspan='2'><input name="submit" type="submit" value="Login"/></td></tr>
-</table>
-</form></body></html>"""
-	}
-
-	def 'openid-login default login page custom attributes'() {
-		setup:
-			MockHttpServletRequest request = new MockHttpServletRequest(method:'GET',requestURI:'/login')
-			MockHttpServletResponse response = new MockHttpServletResponse()
-			MockFilterChain chain = new MockFilterChain()
-			httpAutoConfig {
-				'openid-login'('login-processing-url':'/login_custom')
-				csrf(disabled:true)
-			}
-			createAppContext()
-		when:
-			springSecurityFilterChain.doFilter(request,response,chain)
-		then:
-			response.getContentAsString() == """<html><head><title>Login Page</title></head><body onload='document.f.username.focus();'>
-<h3>Login with Username and Password</h3><form name='f' action='/login' method='POST'>
-<table>
-	<tr><td>User:</td><td><input type='text' name='username' value=''></td></tr>
-	<tr><td>Password:</td><td><input type='password' name='password'/></td></tr>
-	<tr><td colspan='2'><input name="submit" type="submit" value="Login"/></td></tr>
-</table>
-</form><h3>Login with OpenID Identity</h3><form name='oidf' action='/login_custom' method='POST'>
-<table>
-	<tr><td>Identity:</td><td><input type='text' size='30' name='openid_identifier'/></td></tr>
-	<tr><td colspan='2'><input name="submit" type="submit" value="Login"/></td></tr>
-</table>
-</form></body></html>"""
-	}
-
-	def 'form-login forward authentication failure handler'() {
-		setup:
-		MockHttpServletRequest request = new MockHttpServletRequest(method:'POST',servletPath:'/login')
-		request.setParameter("username", "bob")
-		request.setParameter("password", "invalidpassword")
-		MockHttpServletResponse response = new MockHttpServletResponse()
-		MockFilterChain chain = new MockFilterChain()
-		httpAutoConfig {
-			'form-login'('authentication-failure-forward-url':'/failure_forward_url')
-			csrf(disabled:true)
-		}
-		createAppContext()
-		when:
-		springSecurityFilterChain.doFilter(request,response,chain)
-		then:
-		response.getStatus() == 200
-		response.forwardedUrl == "/failure_forward_url"
-		request.getAttribute(WebAttributes.AUTHENTICATION_EXCEPTION) != null;
-	}
-
-	def 'form-login forward authentication success handler'() {
-		setup:
-		MockHttpServletRequest request = new MockHttpServletRequest(method:'POST',servletPath:'/login')
-		request.setParameter("username", "bob")
-		request.setParameter("password", "bobspassword")
-		MockHttpServletResponse response = new MockHttpServletResponse()
-		MockFilterChain chain = new MockFilterChain()
-		httpAutoConfig {
-			'form-login'('authentication-success-forward-url':'/success_forward_url')
-			csrf(disabled:true)
-		}
-		createAppContext()
-		when:
-		springSecurityFilterChain.doFilter(request,response,chain)
-		then:
-		response.getStatus() == 200
-		response.forwardedUrl == "/success_forward_url"
-	}
-}

+ 166 - 0
config/src/test/java/org/springframework/security/config/http/FormLoginBeanDefinitionParserTests.java

@@ -0,0 +1,166 @@
+/*
+ * 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.springframework.beans.factory.annotation.Autowired;
+import org.springframework.security.config.test.SpringTestRule;
+import org.springframework.security.web.WebAttributes;
+import org.springframework.test.web.servlet.MockMvc;
+
+import static org.hamcrest.core.IsNot.not;
+import static org.hamcrest.core.IsNull.nullValue;
+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.content;
+import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.forwardedUrl;
+import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.request;
+import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
+
+
+/**
+ *
+ * @author Luke Taylor
+ * @author Josh Cummings
+ */
+public class FormLoginBeanDefinitionParserTests {
+	private static final String CONFIG_LOCATION_PREFIX =
+			"classpath:org/springframework/security/config/http/FormLoginBeanDefinitionParserTests";
+
+	@Rule
+	public final SpringTestRule spring = new SpringTestRule();
+
+	@Autowired
+	MockMvc mvc;
+
+	@Test
+	public void getLoginWhenAutoConfigThenShowsDefaultLoginPage()
+		throws Exception {
+
+		this.spring.configLocations(this.xml("Simple")).autowire();
+
+		String expectedContent =
+				"<html><head><title>Login Page</title></head><body onload='document.f.username.focus();'>\n" +
+				"<h3>Login with Username and Password</h3><form name='f' action='/login' method='POST'>\n" +
+				"<table>\n" +
+				"	<tr><td>User:</td><td><input type='text' name='username' value=''></td></tr>\n" +
+				"	<tr><td>Password:</td><td><input type='password' name='password'/></td></tr>\n" +
+				"	<tr><td colspan='2'><input name=\"submit\" type=\"submit\" value=\"Login\"/></td></tr>\n" +
+				"</table>\n" +
+				"</form></body></html>";
+
+		this.mvc.perform(get("/login")).andExpect(content().string(expectedContent));
+	}
+
+	@Test
+	public void getLoginWhenConfiguredWithCustomAttributesThenLoginPageReflects()
+			throws Exception {
+
+		this.spring.configLocations(this.xml("WithCustomAttributes")).autowire();
+
+		String expectedContent =
+				"<html><head><title>Login Page</title></head><body onload='document.f.custom_user.focus();'>\n" +
+						"<h3>Login with Username and Password</h3><form name='f' action='/signin' method='POST'>\n" +
+						"<table>\n" +
+						"	<tr><td>User:</td><td><input type='text' name='custom_user' value=''></td></tr>\n" +
+						"	<tr><td>Password:</td><td><input type='password' name='custom_pass'/></td></tr>\n" +
+						"	<tr><td colspan='2'><input name=\"submit\" type=\"submit\" value=\"Login\"/></td></tr>\n" +
+						"</table>\n" +
+						"</form></body></html>";
+
+		this.mvc.perform(get("/login")).andExpect(content().string(expectedContent));
+	}
+
+	@Test
+	public void getLoginWhenConfiguredForOpenIdThenLoginPageReflects()
+		throws Exception {
+
+		this.spring.configLocations(this.xml("WithOpenId")).autowire();
+
+		String expectedContent =
+				"<html><head><title>Login Page</title></head><body onload='document.f.username.focus();'>\n" +
+				"<h3>Login with Username and Password</h3><form name='f' action='/login' method='POST'>\n" +
+				"<table>\n" +
+				"	<tr><td>User:</td><td><input type='text' name='username' value=''></td></tr>\n" +
+				"	<tr><td>Password:</td><td><input type='password' name='password'/></td></tr>\n" +
+				"	<tr><td colspan='2'><input name=\"submit\" type=\"submit\" value=\"Login\"/></td></tr>\n" +
+				"</table>\n" +
+				"</form><h3>Login with OpenID Identity</h3><form name='oidf' action='/login/openid' method='POST'>\n" +
+				"<table>\n" +
+				"	<tr><td>Identity:</td><td><input type='text' size='30' name='openid_identifier'/></td></tr>\n" +
+				"	<tr><td colspan='2'><input name=\"submit\" type=\"submit\" value=\"Login\"/></td></tr>\n" +
+				"</table>\n" +
+				"</form></body></html>";
+
+		this.mvc.perform(get("/login")).andExpect(content().string(expectedContent));
+	}
+
+	@Test
+	public void getLoginWhenConfiguredForOpenIdWithCustomAttributesThenLoginPageReflects()
+			throws Exception {
+
+		this.spring.configLocations(this.xml("WithOpenIdCustomAttributes")).autowire();
+
+		String expectedContent =
+				"<html><head><title>Login Page</title></head><body onload='document.f.username.focus();'>\n" +
+						"<h3>Login with Username and Password</h3><form name='f' action='/login' method='POST'>\n" +
+						"<table>\n" +
+						"	<tr><td>User:</td><td><input type='text' name='username' value=''></td></tr>\n" +
+						"	<tr><td>Password:</td><td><input type='password' name='password'/></td></tr>\n" +
+						"	<tr><td colspan='2'><input name=\"submit\" type=\"submit\" value=\"Login\"/></td></tr>\n" +
+						"</table>\n" +
+						"</form><h3>Login with OpenID Identity</h3><form name='oidf' action='/signin' method='POST'>\n" +
+						"<table>\n" +
+						"	<tr><td>Identity:</td><td><input type='text' size='30' name='openid_identifier'/></td></tr>\n" +
+						"	<tr><td colspan='2'><input name=\"submit\" type=\"submit\" value=\"Login\"/></td></tr>\n" +
+						"</table>\n" +
+						"</form></body></html>";
+
+		this.mvc.perform(get("/login")).andExpect(content().string(expectedContent));
+	}
+
+	@Test
+	public void failedLoginWhenConfiguredWithCustomAuthenticationFailureThenForwardsAccordingly()
+		throws Exception {
+
+		this.spring.configLocations(this.xml("WithAuthenticationFailureForwardUrl")).autowire();
+
+		this.mvc.perform(post("/login")
+							.param("username", "bob")
+							.param("password", "invalidpassword"))
+				.andExpect(status().isOk())
+				.andExpect(forwardedUrl("/failure_forward_url"))
+				.andExpect(request().attribute(WebAttributes.AUTHENTICATION_EXCEPTION, not(nullValue())));
+	}
+
+	@Test
+	public void successfulLoginWhenConfiguredWithCustomAuthenticationSuccessThenForwardsAccordingly()
+		throws Exception {
+
+		this.spring.configLocations(this.xml("WithAuthenticationSuccessForwardUrl")).autowire();
+
+		this.mvc.perform(post("/login")
+				.param("username", "user")
+				.param("password", "password"))
+				.andExpect(status().isOk())
+				.andExpect(forwardedUrl("/success_forward_url"));
+	}
+
+	private String xml(String configName) {
+		return CONFIG_LOCATION_PREFIX + "-" + configName + ".xml";
+	}
+}

+ 32 - 0
config/src/test/resources/org/springframework/security/config/http/FormLoginBeanDefinitionParserTests-Simple.xml

@@ -0,0 +1,32 @@
+<?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">
+		<csrf disabled="true"/>
+	</http>
+
+	<b:import resource="userservice.xml"/>
+</b:beans>

+ 35 - 0
config/src/test/resources/org/springframework/security/config/http/FormLoginBeanDefinitionParserTests-WithAuthenticationFailureForwardUrl.xml

@@ -0,0 +1,35 @@
+<?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">
+		<form-login
+				authentication-failure-forward-url="/failure_forward_url"/>
+
+		<csrf disabled="true"/>
+	</http>
+
+	<b:import resource="userservice.xml"/>
+</b:beans>

+ 35 - 0
config/src/test/resources/org/springframework/security/config/http/FormLoginBeanDefinitionParserTests-WithAuthenticationSuccessForwardUrl.xml

@@ -0,0 +1,35 @@
+<?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">
+		<form-login
+				authentication-success-forward-url="/success_forward_url"/>
+
+		<csrf disabled="true"/>
+	</http>
+
+	<b:import resource="userservice.xml"/>
+</b:beans>

+ 37 - 0
config/src/test/resources/org/springframework/security/config/http/FormLoginBeanDefinitionParserTests-WithCustomAttributes.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">
+		<form-login
+				login-processing-url="/signin"
+				username-parameter="custom_user"
+				password-parameter="custom_pass"/>
+
+		<csrf disabled="true"/>
+	</http>
+
+	<b:import resource="userservice.xml"/>
+</b:beans>

+ 33 - 0
config/src/test/resources/org/springframework/security/config/http/FormLoginBeanDefinitionParserTests-WithOpenId.xml

@@ -0,0 +1,33 @@
+<?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">
+		<openid-login/>
+		<csrf disabled="true"/>
+	</http>
+
+	<b:import resource="userservice.xml"/>
+</b:beans>

+ 35 - 0
config/src/test/resources/org/springframework/security/config/http/FormLoginBeanDefinitionParserTests-WithOpenIdCustomAttributes.xml

@@ -0,0 +1,35 @@
+<?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">
+		<openid-login
+				login-processing-url="/signin"/>
+
+		<csrf disabled="true"/>
+	</http>
+
+	<b:import resource="userservice.xml"/>
+</b:beans>

+ 1 - 1
config/src/test/resources/org/springframework/security/config/http/userservice.xml

@@ -24,6 +24,6 @@
 			http://www.springframework.org/schema/beans
 			http://www.springframework.org/schema/beans/spring-beans.xsd">
 	<user-service>
-		<user name="user" password="password" authorities="ROLE_USER"/>
+		<user name="user" password="{noop}password" authorities="ROLE_USER"/>
 	</user-service>
 </b:beans>