Merge pull request #181 from Doha2012/master

add password validator and change password
This commit is contained in:
Eugen 2015-04-01 22:38:37 +03:00
commit deac7873f0
30 changed files with 493 additions and 256 deletions

View File

@ -67,6 +67,14 @@
<scope>test</scope> <scope>test</scope>
</dependency> </dependency>
<!-- Password Validation -->
<dependency>
<groupId>org.passay</groupId>
<artifactId>passay</artifactId>
<version>1.0</version>
</dependency>
<!-- Spring Data JPA dependencies --> <!-- Spring Data JPA dependencies -->
<dependency> <dependency>
<groupId>org.springframework.data</groupId> <groupId>org.springframework.data</groupId>

View File

@ -32,4 +32,6 @@ public interface IUserService {
User getUserByID(long id); User getUserByID(long id);
void changeUserPassword(User user, String password); void changeUserPassword(User user, String password);
boolean checkIfValidOldPassword(User user, String password);
} }

View File

@ -1,32 +1,32 @@
package org.baeldung.persistence.service; package org.baeldung.persistence.service;
import javax.validation.constraints.NotNull; import javax.validation.constraints.NotNull;
import javax.validation.constraints.Size;
import org.baeldung.validation.PasswordMatches; import org.baeldung.validation.PasswordMatches;
import org.baeldung.validation.ValidEmail; import org.baeldung.validation.ValidEmail;
import org.hibernate.validator.constraints.NotEmpty; import org.baeldung.validation.ValidPassword;
@PasswordMatches @PasswordMatches
public class UserDto { public class UserDto {
@NotNull @NotNull
@NotEmpty @Size(min = 1)
private String firstName; private String firstName;
@NotNull @NotNull
@NotEmpty @Size(min = 1)
private String lastName; private String lastName;
@NotNull @ValidPassword
@NotEmpty
private String password; private String password;
@NotNull @NotNull
@NotEmpty @Size(min = 1)
private String matchingPassword; private String matchingPassword;
@ValidEmail @ValidEmail
@NotNull @NotNull
@NotEmpty @Size(min = 1)
private String email; private String email;
public String getEmail() { public String getEmail() {

View File

@ -120,6 +120,11 @@ public class UserService implements IUserService {
repository.save(user); repository.save(user);
} }
@Override
public boolean checkIfValidOldPassword(final User user, final String oldPassword) {
return passwordEncoder.matches(oldPassword, user.getPassword());
}
private boolean emailExist(final String email) { private boolean emailExist(final String email) {
final User user = repository.findByEmail(email); final User user = repository.findByEmail(email);
if (user != null) { if (user != null) {

View File

@ -14,6 +14,8 @@ public class AuthenticationFailureListener implements ApplicationListener<Authen
public void onApplicationEvent(AuthenticationFailureBadCredentialsEvent e) { public void onApplicationEvent(AuthenticationFailureBadCredentialsEvent e) {
WebAuthenticationDetails auth = (WebAuthenticationDetails) e.getAuthentication().getDetails(); WebAuthenticationDetails auth = (WebAuthenticationDetails) e.getAuthentication().getDetails();
if (auth != null) {
loginAttemptService.loginFailed(auth.getRemoteAddress()); loginAttemptService.loginFailed(auth.getRemoteAddress());
} }
} }
}

View File

@ -14,6 +14,8 @@ public class AuthenticationSuccessEventListener implements ApplicationListener<A
public void onApplicationEvent(AuthenticationSuccessEvent e) { public void onApplicationEvent(AuthenticationSuccessEvent e) {
WebAuthenticationDetails auth = (WebAuthenticationDetails) e.getAuthentication().getDetails(); WebAuthenticationDetails auth = (WebAuthenticationDetails) e.getAuthentication().getDetails();
if (auth != null) {
loginAttemptService.loginSucceeded(auth.getRemoteAddress()); loginAttemptService.loginSucceeded(auth.getRemoteAddress());
} }
} }
}

View File

@ -49,6 +49,7 @@ public class MvcConfig extends WebMvcConfigurerAdapter {
registry.addViewController("/successRegister.html"); registry.addViewController("/successRegister.html");
registry.addViewController("/forgetPassword.html"); registry.addViewController("/forgetPassword.html");
registry.addViewController("/updatePassword.html"); registry.addViewController("/updatePassword.html");
registry.addViewController("/changePassword.html");
} }
@Override @Override

View File

@ -0,0 +1,38 @@
package org.baeldung.validation;
import java.util.Arrays;
import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;
import org.passay.DigitCharacterRule;
import org.passay.LengthRule;
import org.passay.PasswordData;
import org.passay.PasswordValidator;
import org.passay.RuleResult;
import org.passay.SpecialCharacterRule;
import org.passay.UppercaseCharacterRule;
import org.passay.WhitespaceRule;
import com.google.common.base.Joiner;
public class PasswordConstraintValidator implements ConstraintValidator<ValidPassword, String> {
@Override
public void initialize(final ValidPassword arg0) {
}
@Override
public boolean isValid(final String password, final ConstraintValidatorContext context) {
final PasswordValidator validator = new PasswordValidator(Arrays.asList(new LengthRule(8, 30), new UppercaseCharacterRule(1), new DigitCharacterRule(1), new SpecialCharacterRule(1), new WhitespaceRule()));
final RuleResult result = validator.validate(new PasswordData(password));
if (result.isValid()) {
return true;
}
context.disableDefaultConstraintViolation();
context.buildConstraintViolationWithTemplate(Joiner.on("\n").join(validator.getMessages(result))).addConstraintViolation();
return false;
}
}

View File

@ -0,0 +1,27 @@
package org.baeldung.validation;
import static java.lang.annotation.ElementType.ANNOTATION_TYPE;
import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.TYPE;
import static java.lang.annotation.RetentionPolicy.RUNTIME;
import java.lang.annotation.Documented;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;
import javax.validation.Constraint;
import javax.validation.Payload;
@Documented
@Constraint(validatedBy = PasswordConstraintValidator.class)
@Target({ TYPE, FIELD, ANNOTATION_TYPE })
@Retention(RUNTIME)
public @interface ValidPassword {
String message() default "Invalid Password";
Class<?>[] groups() default {};
Class<? extends Payload>[] payload() default {};
}

View File

@ -14,6 +14,7 @@ import org.baeldung.persistence.service.IUserService;
import org.baeldung.persistence.service.UserDto; import org.baeldung.persistence.service.UserDto;
import org.baeldung.registration.OnRegistrationCompleteEvent; import org.baeldung.registration.OnRegistrationCompleteEvent;
import org.baeldung.validation.EmailExistsException; import org.baeldung.validation.EmailExistsException;
import org.baeldung.web.error.InvalidOldPasswordException;
import org.baeldung.web.error.UserAlreadyExistException; import org.baeldung.web.error.UserAlreadyExistException;
import org.baeldung.web.error.UserNotFoundException; import org.baeldung.web.error.UserNotFoundException;
import org.baeldung.web.util.GenericResponse; import org.baeldung.web.util.GenericResponse;
@ -133,7 +134,6 @@ public class RegistrationController {
final String appUrl = "http://" + request.getServerName() + ":" + request.getServerPort() + request.getContextPath(); final String appUrl = "http://" + request.getServerName() + ":" + request.getServerPort() + request.getContextPath();
final SimpleMailMessage email = constructResetTokenEmail(appUrl, request.getLocale(), token, user); final SimpleMailMessage email = constructResetTokenEmail(appUrl, request.getLocale(), token, user);
mailSender.send(email); mailSender.send(email);
return new GenericResponse(messages.getMessage("message.resetPasswordEmail", null, request.getLocale())); return new GenericResponse(messages.getMessage("message.resetPasswordEmail", null, request.getLocale()));
} }
@ -168,6 +168,19 @@ public class RegistrationController {
return new GenericResponse(messages.getMessage("message.resetPasswordSuc", null, locale)); return new GenericResponse(messages.getMessage("message.resetPasswordSuc", null, locale));
} }
// change user password
@RequestMapping(value = "/user/updatePassword", method = RequestMethod.POST)
@ResponseBody
public GenericResponse changeUserPassword(final Locale locale, @RequestParam("password") final String password, @RequestParam("oldpassword") final String oldPassword) {
final User user = userService.findUserByEmail(SecurityContextHolder.getContext().getAuthentication().getName());
if (!userService.checkIfValidOldPassword(user, oldPassword)) {
throw new InvalidOldPasswordException();
}
userService.changeUserPassword(user, password);
return new GenericResponse(messages.getMessage("message.updatePasswordSuc", null, locale));
}
// NON-API // NON-API
private final SimpleMailMessage constructResendVerificationTokenEmail(final String contextPath, final Locale locale, final VerificationToken newToken, final User user) { private final SimpleMailMessage constructResendVerificationTokenEmail(final String contextPath, final Locale locale, final VerificationToken newToken, final User user) {

View File

@ -0,0 +1,23 @@
package org.baeldung.web.error;
public final class InvalidOldPasswordException extends RuntimeException {
private static final long serialVersionUID = 5861310537366287163L;
public InvalidOldPasswordException() {
super();
}
public InvalidOldPasswordException(final String message, final Throwable cause) {
super(message, cause);
}
public InvalidOldPasswordException(final String message) {
super(message);
}
public InvalidOldPasswordException(final Throwable cause) {
super(cause);
}
}

View File

@ -29,7 +29,7 @@ public class RestResponseEntityExceptionHandler extends ResponseEntityExceptionH
// 400 // 400
@Override @Override
protected ResponseEntity<Object> handleBindException(BindException ex, HttpHeaders headers, HttpStatus status, WebRequest request) { protected ResponseEntity<Object> handleBindException(final BindException ex, final HttpHeaders headers, final HttpStatus status, final WebRequest request) {
logger.error("400 Status Code", ex); logger.error("400 Status Code", ex);
final BindingResult result = ex.getBindingResult(); final BindingResult result = ex.getBindingResult();
final GenericResponse bodyOfResponse = new GenericResponse(result.getFieldErrors(), result.getGlobalErrors()); final GenericResponse bodyOfResponse = new GenericResponse(result.getFieldErrors(), result.getGlobalErrors());
@ -44,6 +44,13 @@ public class RestResponseEntityExceptionHandler extends ResponseEntityExceptionH
return handleExceptionInternal(ex, bodyOfResponse, new HttpHeaders(), HttpStatus.BAD_REQUEST, request); return handleExceptionInternal(ex, bodyOfResponse, new HttpHeaders(), HttpStatus.BAD_REQUEST, request);
} }
@ExceptionHandler({ InvalidOldPasswordException.class })
public ResponseEntity<Object> handleInvalidOldPassword(final RuntimeException ex, final WebRequest request) {
logger.error("400 Status Code", ex);
final GenericResponse bodyOfResponse = new GenericResponse(messages.getMessage("message.invalidOldPassword", null, request.getLocale()), "InvalidOldEmail");
return handleExceptionInternal(ex, bodyOfResponse, new HttpHeaders(), HttpStatus.BAD_REQUEST, request);
}
// 404 // 404
@ExceptionHandler({ UserNotFoundException.class }) @ExceptionHandler({ UserNotFoundException.class })
public ResponseEntity<Object> handleUserNotFound(final RuntimeException ex, final WebRequest request) { public ResponseEntity<Object> handleUserNotFound(final RuntimeException ex, final WebRequest request) {

View File

@ -65,3 +65,8 @@ message.resetPasswordSuc=Password reset successfully
message.resetYourPassword=Reset your password message.resetYourPassword=Reset your password
message.resetPasswordEmail=You should receive an Password Reset Email shortly message.resetPasswordEmail=You should receive an Password Reset Email shortly
message.error=Error Occurred message.error=Error Occurred
message.updatePasswordSuc=Password updated successfully
message.changePassword=Change Password
message.invalidOldPassword=Invalid Old Password
label.user.newPassword=New Password
label.user.oldPassword=Old Password

View File

@ -65,3 +65,8 @@ message.resetPasswordSuc=Contrase
message.resetYourPassword=Restablecer su contraseña message.resetYourPassword=Restablecer su contraseña
message.resetPasswordEmail=Te enviaremos un correo electrónico para restablecer su contraseña message.resetPasswordEmail=Te enviaremos un correo electrónico para restablecer su contraseña
message.error=Se produjo un error message.error=Se produjo un error
message.updatePasswordSuc=Contraseña actualizado correctamente
message.changePassword=Cambiar La Contraseña
message.invalidOldPassword=Inválida contraseña antigua
label.user.newPassword=Nueva Contraseña
label.user.oldPassword=Contraseña Anterior

View File

@ -5,25 +5,30 @@
<html> <html>
<head> <head>
<link href="<c:url value="/resources/bootstrap.css" />" rel="stylesheet"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
<title><spring:message code="label.pages.home.title"></spring:message></title> <title><spring:message code="label.pages.home.title"></spring:message></title>
</head> </head>
<body> <body>
<nav class="navbar navbar-default">
<div class="container-fluid">
<div class="navbar-header">
<a class="navbar-brand"href="<c:url value="/home.html" />"><spring:message code="label.pages.home.title"></spring:message></a>
</div>
<ul class="nav navbar-nav navbar-right">
<li><a href="<c:url value="/j_spring_security_logout" />"><spring:message code="label.pages.logout"></spring:message></a> </li>
</ul>
</div>
</nav>
<div class="container"> <div class="container">
<div class="span12">
<sec:authorize ifNotGranted="WRITE_PRIVILEGE"> <sec:authorize ifNotGranted="WRITE_PRIVILEGE">
<spring:message code="message.unauth"></spring:message> <spring:message code="message.unauth"></spring:message>
</sec:authorize> </sec:authorize>
<sec:authorize ifAnyGranted="WRITE_PRIVILEGE"> <sec:authorize ifAnyGranted="WRITE_PRIVILEGE">
<H1> <h1>
<spring:message code="label.pages.admin.message"></spring:message> <spring:message code="label.pages.admin.message"></spring:message>
</H1> </h1>
</sec:authorize> </sec:authorize>
<a href="<c:url value="/j_spring_security_logout" />"><spring:message
code="label.pages.logout"></spring:message></a> <a
href="<c:url value="/home.html" />"><spring:message
code="label.pages.home.title"></spring:message></a>
</div>
</div> </div>
</body> </body>
</html> </html>

View File

@ -7,17 +7,17 @@
<%@ page session="true"%> <%@ page session="true"%>
<html> <html>
<head> <head>
<link href="<c:url value="/resources/bootstrap.css" />" rel="stylesheet"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
<title><spring:message <title><spring:message
code="label.badUser.title"></spring:message></title> code="label.badUser.title"></spring:message></title>
</head> </head>
<body> <body>
<h1> <div class="container">
<div class="alert alert-error"> <h1 class="alert alert-danger">
${param.message} ${param.message}
</h1> </h1>
<br> <br>
<a href="<c:url value="/registration.html" />"><spring:message <a class="btn btn-default" href="<c:url value="/registration.html" />"><spring:message
code="label.form.loginSignUp"></spring:message></a> code="label.form.loginSignUp"></spring:message></a>
<c:if test="${param.expired}"> <c:if test="${param.expired}">
@ -27,7 +27,6 @@ code="label.form.loginSignUp"></spring:message></a>
<spring:message code="label.form.resendRegistrationToken"></spring:message> <spring:message code="label.form.resendRegistrationToken"></spring:message>
</button> </button>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script> <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script>
<script type="text/javascript"> <script type="text/javascript">
function resendToken(){ function resendToken(){
@ -50,5 +49,6 @@ $(document).ajaxStart(function() {
}); });
</script> </script>
</c:if> </c:if>
</div>
</body> </body>
</html> </html>

View File

@ -0,0 +1,72 @@
<!DOCTYPE html>
<%@ page contentType="text/html;charset=UTF-8" language="java"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form"%>
<%@ taglib prefix="spring" uri="http://www.springframework.org/tags"%>
<%@ taglib prefix="sec"
uri="http://www.springframework.org/security/tags"%>
<%@ page session="false"%>
<html>
<head>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
<meta http-equiv="Content-Type" content="text/html; charset=US-ASCII">
<title><spring:message code="message.changePassword"></spring:message></title>
</head>
<body>
<nav class="navbar navbar-default">
<div class="container-fluid">
<div class="navbar-header">
<a class="navbar-brand"href="#"><spring:message code="label.pages.home.title"></spring:message></a>
</div>
<ul class="nav navbar-nav navbar-right">
<li><a href="<c:url value="/j_spring_security_logout" />"><spring:message code="label.pages.logout"></spring:message></a> </li>
</ul>
</div>
</nav>
<div class="container">
<div class="row">
<div id="errormsg" class="alert alert-danger" style="display:none"></div>
<h1> <spring:message code="message.changePassword"></spring:message> </h1>
<div >
<br>
<label class="col-sm-2"><spring:message code="label.user.oldPassword"></spring:message></label>
<span class="col-sm-5"><input class="form-control" id="oldpass" name="oldpassword" type="password" value="" /></span>
<span class="col-sm-5"></span>
<br><br>
<label class="col-sm-2"><spring:message code="label.user.newPassword"></spring:message></label>
<span class="col-sm-5"><input class="form-control" id="pass" name="password" type="password" value="" /></span>
<span class="col-sm-5"></span>
<br><br>
<label class="col-sm-2"><spring:message code="label.user.confirmPass"></spring:message></label>
<span class="col-sm-5"><input class="form-control" id="passConfirm" type="password" value="" /></span>
<span id="error" class="alert alert-danger" style="display:none"><spring:message code="PasswordMatches.user"></spring:message></span>
<br><br>
<button class="btn btn-primary" type="submit" onclick="savePass()">
<spring:message code="message.changePassword"></spring:message>
</button>
</div>
</div>
</div>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script>
<script type="text/javascript">
function savePass(){
var pass = $("#pass").val();
var valid = pass == $("#passConfirm").val();
if(!valid) {
$("#error").show();
return;
}
$.post("<c:url value="/user/updatePassword"></c:url>",{password: pass, oldpassword: $("#oldpass").val()} ,function(data){
window.location.href = "<c:url value="/console.html"></c:url>" + "?message="+data.message;
})
.fail(function(data) {
$("#errormsg").show().html(data.responseJSON.message);
});
}
</script>
</body>
</html>

View File

@ -4,11 +4,26 @@
<%@taglib uri="http://www.springframework.org/tags" prefix="spring"%> <%@taglib uri="http://www.springframework.org/tags" prefix="spring"%>
<html> <html>
<head> <head>
<link href="<c:url value="/resources/bootstrap.css" />" rel="stylesheet"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
</head> </head>
<body> <body>
<nav class="navbar navbar-default">
<div class="container-fluid">
<div class="navbar-header">
<a class="navbar-brand"href="<c:url value="/home.html" />"><spring:message code="label.pages.home.title"></spring:message></a>
</div>
<ul class="nav navbar-nav navbar-right">
<li><a href="<c:url value="/j_spring_security_logout" />"><spring:message code="label.pages.logout"></spring:message></a> </li>
</ul>
</div>
</nav>
<div class="container"> <div class="container">
<div class="span12"> <c:if test="${param.message != null}">
<div class="alert alert-info">
${param.message}
</div>
</c:if>
<h1>This is the landing page for the admin</h1> <h1>This is the landing page for the admin</h1>
<sec:authorize access="hasRole('READ_PRIVILEGE')"> <sec:authorize access="hasRole('READ_PRIVILEGE')">
This text is only visible to a user This text is only visible to a user
@ -18,11 +33,9 @@
This text is only visible to an admin This text is only visible to an admin
<br /> <br />
</sec:authorize> </sec:authorize>
<a href="<c:url value="/j_spring_security_logout" />"><spring:message <a class="btn btn-default" href="<c:url value="/changePassword.html" />"><spring:message code="message.changePassword"></spring:message></a>
code="label.pages.logout"></spring:message></a> <a
href="<c:url value="/admin.html" />"><spring:message <a class="btn btn-default" href="<c:url value="/admin.html" />"><spring:message code="label.pages.admin"></spring:message></a>
code="label.pages.admin"></spring:message></a>
</div>
</div> </div>
</body> </body>

View File

@ -2,18 +2,16 @@
<%@taglib uri="http://www.springframework.org/tags" prefix="spring"%> <%@taglib uri="http://www.springframework.org/tags" prefix="spring"%>
<html> <html>
<head> <head>
<link href="<c:url value="/resources/bootstrap.css" />" rel="stylesheet"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
<title><spring:message code="label.pages.home.title"></spring:message></title> <title><spring:message code="label.pages.home.title"></spring:message></title>
</head> </head>
<body> <body>
<div class="container"> <div class="container">
<div class="span12"> <h1 class="alert alert-danger">
<h1 class="alert alert-error">
<spring:message code="message.email.config.error"></spring:message> <spring:message code="message.email.config.error"></spring:message>
</h1> </h1>
</div> </div>
</div>
</body> </body>
</html> </html>

View File

@ -8,16 +8,17 @@
<html> <html>
<head> <head>
<link href="<c:url value="/resources/bootstrap.css" />" rel="stylesheet"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
<title><spring:message code="label.pages.home.title"></spring:message></title> <title><spring:message code="label.pages.home.title"></spring:message></title>
</head> </head>
<body> <body>
<h1> <div class="container">
<h1 class="alert alert-info">
<spring:message code="auth.message.expired"></spring:message> <spring:message code="auth.message.expired"></spring:message>
</h1> </h1>
<br> <br>
<a href="<c:url value="/registration.html" />"><spring:message <a class="btn btn-default" href="<c:url value="registration.html" />"><spring:message
code="label.form.loginSignUp"></spring:message></a> code="label.form.loginSignUp"></spring:message></a>
</div>
</body> </body>
</html> </html>

View File

@ -8,37 +8,26 @@
<%@ page session="false"%> <%@ page session="false"%>
<html> <html>
<head> <head>
<link href="<c:url value="/resources/bootstrap.css" />" rel="stylesheet"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
<meta http-equiv="Content-Type" content="text/html; charset=US-ASCII"> <meta http-equiv="Content-Type" content="text/html; charset=US-ASCII">
<title><spring:message code="message.resetPassword"></spring:message></title> <title><spring:message code="message.resetPassword"></spring:message></title>
</head> </head>
<body> <body>
<div class="container"> <div class="container">
<div class="span12"> <h1><spring:message code="message.resetPassword"></spring:message></h1>
<h1>
<spring:message code="message.resetPassword"></spring:message>
</h1>
<div>
<br> <br>
<div class="row">
<tr> <label class="col-sm-1"><spring:message code="label.user.email"></spring:message></label>
<td><label><spring:message code="label.user.email"></spring:message></label></td> <span class="col-sm-5"><input class="form-control" id="email" name="email" type="email" value="" /></span>
<td><input id="email" name="email" type="email" value="" /></td> <button class="btn btn-primary" type="submit" onclick="resetPass()"><spring:message code="message.resetPassword"></spring:message></button>
</tr>
<button class="btn btn-primary" type="submit" onclick="resetPass()">
<spring:message code="message.resetPassword"></spring:message>
</button>
</div> </div>
<br> <br>
<a href="<c:url value="/registration.html" />"><spring:message code="label.form.loginSignUp"></spring:message></a> <a class="btn btn-default" href="<c:url value="registration.html" />"><spring:message code="label.form.loginSignUp"></spring:message></a>
<br> <br><br>
<a href="<c:url value="login.html" />"><spring:message code="label.form.loginLink"></spring:message></a> <a class="btn btn-default" href="<c:url value="login.html" />"><spring:message code="label.form.loginLink"></spring:message></a>
</div> </div>
</div>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script> <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script>
<script type="text/javascript"> <script type="text/javascript">
function resetPass(){ function resetPass(){

View File

@ -4,19 +4,26 @@
<html> <html>
<head> <head>
<link href="<c:url value="/resources/bootstrap.css" />" rel="stylesheet"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
<title><spring:message code="label.pages.home.title"></spring:message></title> <title><spring:message code="label.pages.home.title"></spring:message></title>
</head> </head>
<body> <body>
<nav class="navbar navbar-default">
<div class="container-fluid">
<div class="navbar-header">
<a class="navbar-brand"href="#"><spring:message code="label.pages.home.title"></spring:message></a>
</div>
<ul class="nav navbar-nav navbar-right">
<li><a href="<c:url value="/j_spring_security_logout" />"><spring:message code="label.pages.logout"></spring:message></a> </li>
</ul>
</div>
</nav>
<div class="container"> <div class="container">
<div class="span12">
<h1> <h1>
<spring:message code="label.pages.home.message"></spring:message> <spring:message code="label.pages.home.message"></spring:message>
</h1> </h1>
<a href="<c:url value="/j_spring_security_logout" />"><spring:message
code="label.pages.logout"></spring:message></a>
</div>
</div> </div>
</body> </body>
</html> </html>

View File

@ -5,14 +5,23 @@
<%@ page session="true"%> <%@ page session="true"%>
<html> <html>
<head> <head>
<link href="<c:url value="/resources/bootstrap.css" />" rel="stylesheet"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
<title><spring:message code="label.pages.home.title"></spring:message></title> <title><spring:message code="label.pages.home.title"></spring:message></title>
</head> </head>
<body> <body>
<nav class="navbar navbar-default">
<div class="container-fluid">
<div class="navbar-header">
<a class="navbar-brand"href="<c:url value="/home.html" />"><spring:message code="label.pages.home.title"></spring:message></a>
</div>
<ul class="nav navbar-nav navbar-right">
<li><a href="<c:url value="/j_spring_security_logout" />"><spring:message code="label.pages.logout"></spring:message></a> </li>
</ul>
</div>
</nav>
<div class="container"> <div class="container">
<div class="span12">
<sec:authorize access="hasRole('READ_PRIVILEGE')"> <sec:authorize access="hasRole('READ_PRIVILEGE')">
<spring:message code="label.pages.user.message"></spring:message> <spring:message code="label.pages.user.message"></spring:message>
<br /> <br />
@ -23,13 +32,7 @@
<br /> <br />
</sec:authorize> </sec:authorize>
${param.user} ${param.user}
<a href="<c:url value="/j_spring_security_logout" />"><spring:message <a class="btn btn-default" href="<c:url value="/admin.html" />"><spring:message code="label.pages.admin"></spring:message></a>
code="label.pages.logout"></spring:message></a> <a
href="<c:url value="/home.html" />"><spring:message
code="label.pages.home.title"></spring:message></a> <a
href="<c:url value="/admin.html" />"><spring:message
code="label.pages.admin"></spring:message></a>
</div>
</div> </div>
</body> </body>
</html> </html>

View File

@ -2,19 +2,17 @@
<%@taglib uri="http://www.springframework.org/tags" prefix="spring"%> <%@taglib uri="http://www.springframework.org/tags" prefix="spring"%>
<html> <html>
<head> <head>
<link href="<c:url value="/resources/bootstrap.css" />" rel="stylesheet"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
<title><spring:message code="label.pages.home.title"></spring:message></title> <title><spring:message code="label.pages.home.title"></spring:message></title>
</head> </head>
<body> <body>
<div class="container"> <div class="container">
<div class="span12"> <h1 class="alert alert-danger">
<h1 class="alert alert-error">
<spring:message code="message.sessionExpired"></spring:message> <spring:message code="message.sessionExpired"></spring:message>
</h1> </h1>
<a href="<c:url value="login.html" />"><spring:message <a class="btn btn-primary" href="<c:url value="login.html" />"><spring:message
code="label.form.loginLink"></spring:message></a> code="label.form.loginLink"></spring:message></a>
</div> </div>
</div>
</body> </body>
</html> </html>

View File

@ -11,24 +11,24 @@
<c:choose> <c:choose>
<c:when <c:when
test="${SPRING_SECURITY_LAST_EXCEPTION.message == 'User is disabled'}"> test="${SPRING_SECURITY_LAST_EXCEPTION.message == 'User is disabled'}">
<div class="alert alert-error"> <div class="alert alert-danger">
<spring:message code="auth.message.disabled"></spring:message> <spring:message code="auth.message.disabled"></spring:message>
</div> </div>
</c:when> </c:when>
<c:when <c:when
test="${SPRING_SECURITY_LAST_EXCEPTION.message == 'User account has expired'}"> test="${SPRING_SECURITY_LAST_EXCEPTION.message == 'User account has expired'}">
<div class="alert alert-error"> <div class="alert alert-danger">
<spring:message code="auth.message.expired"></spring:message> <spring:message code="auth.message.expired"></spring:message>
</div> </div>
</c:when> </c:when>
<c:when <c:when
test="${SPRING_SECURITY_LAST_EXCEPTION.message == 'blocked'}"> test="${SPRING_SECURITY_LAST_EXCEPTION.message == 'blocked'}">
<div class="alert alert-error"> <div class="alert alert-danger">
<spring:message code="auth.message.blocked"></spring:message> <spring:message code="auth.message.blocked"></spring:message>
</div> </div>
</c:when> </c:when>
<c:otherwise> <c:otherwise>
<div class="alert alert-error"> <div class="alert alert-danger">
<!-- <c:out value="${SPRING_SECURITY_LAST_EXCEPTION.message}"/> --> <!-- <c:out value="${SPRING_SECURITY_LAST_EXCEPTION.message}"/> -->
<spring:message code="message.badCredentials"></spring:message> <spring:message code="message.badCredentials"></spring:message>
</div> </div>
@ -38,7 +38,7 @@
<html> <html>
<head> <head>
<link href="<c:url value="/resources/bootstrap.css" />" rel="stylesheet"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
<title><spring:message code="label.pages.home.title"></spring:message></title> <title><spring:message code="label.pages.home.title"></spring:message></title>
<script type="text/javascript"> <script type="text/javascript">
function validate() { function validate() {
@ -60,6 +60,10 @@
} }
} }
</script> </script>
<style type="text/css">
.wrapper{width:400px;margin-left:auto;margin-right:auto}
label{padding-left:0 !important}
</style>
</head> </head>
<body> <body>
<c:if test="${param.message != null}"> <c:if test="${param.message != null}">
@ -69,38 +73,34 @@ ${param.message}
</c:if> </c:if>
<div class="container"> <div class="container">
<div class="span12"> <div class="row wrapper">
<h1> <h1>
<spring:message code="label.form.loginTitle"></spring:message> <spring:message code="label.form.loginTitle"></spring:message>
</h1> </h1>
<a href="?lang=en"><spring:message code="label.form.loginEnglish"></spring:message></a> <a href="?lang=en"><spring:message code="label.form.loginEnglish"></spring:message></a>
| <a href="?lang=es_ES"><spring:message | <a href="?lang=es_ES"><spring:message
code="label.form.loginSpanish"></spring:message></a> code="label.form.loginSpanish"></spring:message></a>
<br><br>
<form name='f' action="j_spring_security_check" method='POST' <form name='f' action="j_spring_security_check" method='POST'
onsubmit="return validate();"> onsubmit="return validate();">
<table>
<tr> <label class="col-sm-2"><spring:message code="label.form.loginEmail"></spring:message></label>
<td><label><spring:message <span class="col-sm-10"><input class="form-control" type='text' name='j_username' value=''></span>
code="label.form.loginEmail"></spring:message></label></td>
<td><input type='text' name='j_username' value=''></td> <br><br>
</tr> <label class="col-sm-2"><spring:message code="label.form.loginPass"></spring:message></label>
<tr> <span class="col-sm-10"><input class="form-control" type='password' name='j_password' /></span>
<td><label><spring:message
code="label.form.loginPass"></spring:message></label></td> <br><br>
<td><input type='password' name='j_password' /></td> <input class="btn btn-primary" name="submit" type="submit"
</tr> value=<spring:message code="label.form.submit"></spring:message> />
<tr>
<td><input class="btn btn-primary" name="submit" type="submit"
value=<spring:message code="label.form.submit"></spring:message> /></td>
</tr>
</table>
</form> </form>
<br> Current Locale : ${pageContext.response.locale} <br> <a <br> Current Locale : ${pageContext.response.locale} <br><br>
href="<c:url value="/registration.html" />"><spring:message <a class="btn btn-default" href="<c:url value="registration.html" />"><spring:message
code="label.form.loginSignUp"></spring:message></a> code="label.form.loginSignUp"></spring:message></a>
<br><br><br> <br><br>
<a href="<c:url value="/forgetPassword.html" />"><spring:message <a class="btn btn-default" href="<c:url value="/forgetPassword.html" />"><spring:message
code="message.resetPassword"></spring:message></a> code="message.resetPassword"></spring:message></a>
</div> </div>
</div> </div>

View File

@ -5,11 +5,11 @@
<html> <html>
<head> <head>
<link href="<c:url value="/resources/bootstrap.css" />" rel="stylesheet"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
<c:if test="${not empty SPRING_SECURITY_LAST_EXCEPTION}"> <c:if test="${not empty SPRING_SECURITY_LAST_EXCEPTION}">
<div id="error"> <h1 id="error" class="alert alert-danger">
<spring:message code="message.logoutError"></spring:message> <spring:message code="message.logoutError"></spring:message>
</div> </h1>
</c:if> </c:if>
<meta http-equiv="Content-Type" content="text/html; charset=US-ASCII"> <meta http-equiv="Content-Type" content="text/html; charset=US-ASCII">
<title><spring:message code="label.pages.home.title"></spring:message></title> <title><spring:message code="label.pages.home.title"></spring:message></title>
@ -17,16 +17,15 @@
<body> <body>
<div class="container"> <div class="container">
<div class="span12">
<c:if test="${param.logSucc == true}"> <c:if test="${param.logSucc == true}">
<div id="success"> <h1 id="success" class="alert alert-info">
<spring:message code="message.logoutSucc"></spring:message> <spring:message code="message.logoutSucc"></spring:message>
</div> </h1>
</c:if> </c:if>
<a href="<c:url value="login.html" />"><spring:message <a class="btn btn-primary" href="<c:url value="login.html" />"><spring:message
code="label.form.loginLink"></spring:message></a> code="label.form.loginLink"></spring:message></a>
</div> </div>
</div>
</body> </body>
</html> </html>

View File

@ -6,7 +6,13 @@
<html> <html>
<head> <head>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
<style>
.password-verdict{
color:#000;
}
</style>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script> <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script>
<script src="<c:url value="/resources/pwstrength.js" />"></script>
<meta http-equiv="Content-Type" content="text/html; charset=US-ASCII"> <meta http-equiv="Content-Type" content="text/html; charset=US-ASCII">
<title><spring:message code="label.form.title"></spring:message></title> <title><spring:message code="label.form.title"></spring:message></title>
</head> </head>
@ -57,6 +63,14 @@
</div> </div>
<script type="text/javascript"> <script type="text/javascript">
$(document).ready(function () {
options = {
common: {minChar:8},
ui: {showVerdictsInsideProgressBar:true}
};
$('#password').pwstrength(options);
});
function register(){ function register(){
event.preventDefault(); event.preventDefault();
$(".alert").html("").hide(); $(".alert").html("").hide();

View File

@ -10,13 +10,14 @@
</c:if> </c:if>
<html> <html>
<head> <head>
<link href="<c:url value="/resources/bootstrap.css" />" rel="stylesheet"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
<meta http-equiv="Content-Type" content="text/html; charset=US-ASCII"> <meta http-equiv="Content-Type" content="text/html; charset=US-ASCII">
<title><spring:message code="label.pages.home.title"></spring:message></title> <title><spring:message code="label.pages.home.title"></spring:message></title>
</head> </head>
<body> <body>
<div>
<spring:message code="message.regSucc"></spring:message> <h1 class="alert alert-info"><spring:message code="message.regSucc"></spring:message></h1>
<a href="<c:url value="login.html" />"><spring:message code="label.login"></spring:message></a> <a class="btn btn-primary" href="<c:url value="login.html" />"><spring:message code="label.login"></spring:message></a>
</div>
</body> </body>
</html> </html>

View File

@ -8,31 +8,26 @@
<%@ page session="false"%> <%@ page session="false"%>
<html> <html>
<head> <head>
<link href="<c:url value="/resources/bootstrap.css" />" rel="stylesheet"> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.2/css/bootstrap.min.css">
<meta http-equiv="Content-Type" content="text/html; charset=US-ASCII"> <meta http-equiv="Content-Type" content="text/html; charset=US-ASCII">
<title><spring:message code="message.updatePassword"></spring:message></title> <title><spring:message code="message.updatePassword"></spring:message></title>
</head> </head>
<body> <body>
<sec:authorize access="hasRole('READ_PRIVILEGE')"> <sec:authorize access="hasRole('READ_PRIVILEGE')">
<div class="container"> <div class="container">
<div class="span12"> <div class="row">
<H1> <h1> <spring:message code="message.resetYourPassword"></spring:message> </h1>
<spring:message code="message.resetYourPassword"></spring:message>
</H1>
<div > <div >
<br> <br>
<tr> <label class="col-sm-2"><spring:message code="label.user.password"></spring:message></label>
<td><label><spring:message code="label.user.password"></spring:message></label></td> <span class="col-sm-5"><input class="form-control" id="pass" name="password" type="password" value="" /></span>
<td><input id="pass" name="password" type="password" value="" /></td> <span class="col-sm-5"></span>
</tr> <br><br>
<tr> <label class="col-sm-2"><spring:message code="label.user.confirmPass"></spring:message></label>
<td><label><spring:message code="label.user.confirmPass"></spring:message></label></td> <span class="col-sm-5"><input class="form-control" id="passConfirm" type="password" value="" /></span>
<td> <span id="error" class="alert alert-danger" style="display:none"><spring:message code="PasswordMatches.user"></spring:message></span>
<input id="passConfirm" type="password" value="" />
<span id="error" class="alert alert-error" style="display:none"><spring:message code="PasswordMatches.user"></spring:message></span>
</td>
</tr>
<br><br> <br><br>
<button class="btn btn-primary" type="submit" onclick="savePass()"> <button class="btn btn-primary" type="submit" onclick="savePass()">
<spring:message code="message.updatePassword"></spring:message> <spring:message code="message.updatePassword"></spring:message>

File diff suppressed because one or more lines are too long