JAVA-877 Update "Redirect after login" article
This commit is contained in:
		
							parent
							
								
									20b8b8c903
								
							
						
					
					
						commit
						02ce642cbd
					
				| @ -2,6 +2,8 @@ package org.baeldung.security; | ||||
| 
 | ||||
| import java.io.IOException; | ||||
| import java.util.Collection; | ||||
| import java.util.HashMap; | ||||
| import java.util.Map; | ||||
| 
 | ||||
| import javax.servlet.http.HttpServletRequest; | ||||
| import javax.servlet.http.HttpServletResponse; | ||||
| @ -47,26 +49,21 @@ public class MySimpleUrlAuthenticationSuccessHandler implements AuthenticationSu | ||||
|     } | ||||
| 
 | ||||
|     protected String determineTargetUrl(final Authentication authentication) { | ||||
|         boolean isUser = false; | ||||
|         boolean isAdmin = false; | ||||
| 
 | ||||
|         Map<String, String> roleTargetUrlMap = new HashMap<>(); | ||||
|         roleTargetUrlMap.put("ROLE_USER", "/homepage.html"); | ||||
|         roleTargetUrlMap.put("ROLE_ADMIN", "/console.html"); | ||||
| 
 | ||||
|         final Collection<? extends GrantedAuthority> authorities = authentication.getAuthorities(); | ||||
|         for (final GrantedAuthority grantedAuthority : authorities) { | ||||
|             if (grantedAuthority.getAuthority().equals("ROLE_USER")) { | ||||
|                 isUser = true; | ||||
|                 break; | ||||
|             } else if (grantedAuthority.getAuthority().equals("ROLE_ADMIN")) { | ||||
|                 isAdmin = true; | ||||
|                 break; | ||||
| 
 | ||||
|             String authorityName = grantedAuthority.getAuthority(); | ||||
|             if(roleTargetUrlMap.containsKey(authorityName)) { | ||||
|                 return roleTargetUrlMap.get(authorityName); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         if (isUser) { | ||||
|             return "/homepage.html"; | ||||
|         } else if (isAdmin) { | ||||
|             return "/console.html"; | ||||
|         } else { | ||||
|             throw new IllegalStateException(); | ||||
|         } | ||||
|         throw new IllegalStateException(); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
| @ -83,12 +80,4 @@ public class MySimpleUrlAuthenticationSuccessHandler implements AuthenticationSu | ||||
|         session.removeAttribute(WebAttributes.AUTHENTICATION_EXCEPTION); | ||||
|     } | ||||
| 
 | ||||
|     public void setRedirectStrategy(final RedirectStrategy redirectStrategy) { | ||||
|         this.redirectStrategy = redirectStrategy; | ||||
|     } | ||||
| 
 | ||||
|     protected RedirectStrategy getRedirectStrategy() { | ||||
|         return redirectStrategy; | ||||
|     } | ||||
| 
 | ||||
| } | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user