Merge branch 'develop' of https://gitee.com/saturneric/ASE
This commit is contained in:
commit
bbc2fc090b
@ -58,44 +58,6 @@ public class JSONParameter {
|
|||||||
return JSON.toJSONString(object);
|
return JSON.toJSONString(object);
|
||||||
}
|
}
|
||||||
|
|
||||||
// 根据对象构造获得标准的JSON响应字符串返回
|
|
||||||
public String getJSONStandardRespond(Integer status, String msg, Object dataObject){
|
|
||||||
JSONBaseRespondObject respondObject = new JSONBaseRespondObject(status, msg);
|
|
||||||
respondObject.setData(dataObject);
|
|
||||||
return getJSONString(respondObject);
|
|
||||||
}
|
|
||||||
|
|
||||||
// 获得标准的JSON响应字符串返回(404状态)
|
|
||||||
public String getJSONStandardRespond404(String msg){
|
|
||||||
JSONBaseRespondObject respondObject = new JSONBaseRespondObject(404, msg);
|
|
||||||
return getJSONString(respondObject);
|
|
||||||
}
|
|
||||||
|
|
||||||
// 获得标准的JSON响应字符串返回(500状态)
|
|
||||||
public String getJSONStandardRespond500(String msg){
|
|
||||||
JSONBaseRespondObject respondObject = new JSONBaseRespondObject(500, msg);
|
|
||||||
return getJSONString(respondObject);
|
|
||||||
}
|
|
||||||
|
|
||||||
// 获得标准的JSON响应字符串返回(200状态)
|
|
||||||
public String getJSONStandardRespond200(Object dataObject){
|
|
||||||
JSONBaseRespondObject respondObject = new JSONBaseRespondObject(200, "ok");
|
|
||||||
respondObject.setData(dataObject);
|
|
||||||
return getJSONString(respondObject);
|
|
||||||
}
|
|
||||||
|
|
||||||
// 获得标准的JSON响应字符串返回(403状态)
|
|
||||||
public String getJSONStandardRespond403(){
|
|
||||||
JSONBaseRespondObject respondObject = new JSONBaseRespondObject(403, "Forbidden");
|
|
||||||
return getJSONString(respondObject);
|
|
||||||
}
|
|
||||||
|
|
||||||
// 获得标准的JSON响应字符串返回(401状态)
|
|
||||||
public String getJSONStandardRespond401(){
|
|
||||||
JSONBaseRespondObject respondObject = new JSONBaseRespondObject(401, "Unauthorized");
|
|
||||||
return getJSONString(respondObject);
|
|
||||||
}
|
|
||||||
|
|
||||||
// 由JSON对象获得对应的Java对象
|
// 由JSON对象获得对应的Java对象
|
||||||
public <T> T getJavaObject(JSONObject json, Class<T> type){
|
public <T> T getJavaObject(JSONObject json, Class<T> type){
|
||||||
return json.toJavaObject(type);
|
return json.toJavaObject(type);
|
||||||
|
@ -0,0 +1,80 @@
|
|||||||
|
package com.codesdream.ase.component.datamanager;
|
||||||
|
|
||||||
|
import com.codesdream.ase.component.json.respond.EmptyDataObjectRespond;
|
||||||
|
import com.codesdream.ase.component.json.respond.JSONBaseRespondObject;
|
||||||
|
import org.springframework.stereotype.Component;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
|
||||||
|
|
||||||
|
@Component
|
||||||
|
public class QuickJSONRespond {
|
||||||
|
@Resource
|
||||||
|
private JSONParameter jsonParameter;
|
||||||
|
|
||||||
|
// 根据对象构造获得标准的JSON响应字符串返回
|
||||||
|
public String getJSONStandardRespond(Integer status, String msg, String info, Object dataObject){
|
||||||
|
JSONBaseRespondObject respondObject = new JSONBaseRespondObject(status, msg);
|
||||||
|
if(info != null) respondObject.setInfo(info);
|
||||||
|
else respondObject.setInfo(null);
|
||||||
|
|
||||||
|
respondObject.setData(dataObject);
|
||||||
|
return jsonParameter.getJSONString(respondObject);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获得标准的JSON响应字符串返回特定状态码的和解释息
|
||||||
|
public String getJSONStandardRespond(Integer code, String msg, String info){
|
||||||
|
JSONBaseRespondObject respondObject = new JSONBaseRespondObject(code, msg);
|
||||||
|
if(info != null) respondObject.setInfo(info);
|
||||||
|
else respondObject.setInfo(null);
|
||||||
|
respondObject.setData(null);
|
||||||
|
return jsonParameter.getJSONString(respondObject);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获得标准的JSON响应字符串返回(404状态)
|
||||||
|
public String getRespond404(String info){
|
||||||
|
return getJSONStandardRespond(404, "Not Found", info);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获得标准的JSON响应字符串返回(500状态)
|
||||||
|
public String getRespond500(String info){
|
||||||
|
return getJSONStandardRespond(500, "Internal Server Error", info);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获得标准的JSON响应字符串返回(200状态)
|
||||||
|
public String getRespond200(String info){
|
||||||
|
return getJSONStandardRespond(200, "Ok", info);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获得标准的JSON响应字符串返回(200状态)
|
||||||
|
public String getRespond200(String info, Object object){
|
||||||
|
return getJSONStandardRespond(200, "Ok", info, object);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获得标准的JSON响应字符串返回(403状态)
|
||||||
|
public String getRespond403(String info){
|
||||||
|
return getJSONStandardRespond(403, "Forbidden", info);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获得标准的JSON响应字符串返回(403状态)
|
||||||
|
public String getRespond406(String info){
|
||||||
|
return getJSONStandardRespond(406, "Not Acceptable", info);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获得标准的JSON响应字符串返回(501态)
|
||||||
|
public String getRespond501(String info){
|
||||||
|
return getJSONStandardRespond(501, "Not Implemented", info) ;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获得标准的JSON响应字符串返回(401状态)
|
||||||
|
public String getRespond401(String info){
|
||||||
|
return getJSONStandardRespond(401, "Unauthorized", info);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获得标准的JSON响应字符串返回(400状态)
|
||||||
|
public String getRespond400(String info){
|
||||||
|
return getJSONStandardRespond(400, "Bad Request", info);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,19 @@
|
|||||||
|
package com.codesdream.ase.component.json.request;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
public class UserRegisterChecker {
|
||||||
|
|
||||||
|
// 学号
|
||||||
|
private String studentId;
|
||||||
|
|
||||||
|
// 密码
|
||||||
|
private String password;
|
||||||
|
|
||||||
|
// 密保问题
|
||||||
|
private String userQuestion;
|
||||||
|
|
||||||
|
// 密保答案
|
||||||
|
private String userAnswer;
|
||||||
|
}
|
@ -0,0 +1,12 @@
|
|||||||
|
package com.codesdream.ase.component.json.respond;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
public class ErrorInfoJSONRespond {
|
||||||
|
String exception = null;
|
||||||
|
String exceptionMessage = null;
|
||||||
|
Date date = null;
|
||||||
|
}
|
@ -17,6 +17,9 @@ public class JSONBaseRespondObject extends JSONBaseObject {
|
|||||||
// 存放响应信息提示
|
// 存放响应信息提示
|
||||||
private String msg = "";
|
private String msg = "";
|
||||||
|
|
||||||
|
// 额外信息
|
||||||
|
private String info = null;
|
||||||
|
|
||||||
// 状态
|
// 状态
|
||||||
private Integer status = 200;
|
private Integer status = 200;
|
||||||
|
|
||||||
|
@ -9,7 +9,8 @@ public class UserLoginCheckerJSONRespond {
|
|||||||
Boolean userExist = null;
|
Boolean userExist = null;
|
||||||
Boolean userBanned = null;
|
Boolean userBanned = null;
|
||||||
Boolean loginStatus = null;
|
Boolean loginStatus = null;
|
||||||
String respondInformation = "";
|
String respondInformation = null;
|
||||||
String token = null;
|
String token = null;
|
||||||
|
String uid = null;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package com.codesdream.ase.component.permission;
|
package com.codesdream.ase.component.permission;
|
||||||
|
|
||||||
import com.codesdream.ase.component.datamanager.JSONParameter;
|
import com.codesdream.ase.component.datamanager.JSONParameter;
|
||||||
|
import com.codesdream.ase.component.datamanager.QuickJSONRespond;
|
||||||
import com.codesdream.ase.component.json.respond.UserLoginCheckerJSONRespond;
|
import com.codesdream.ase.component.json.respond.UserLoginCheckerJSONRespond;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import org.springframework.security.access.AccessDeniedException;
|
import org.springframework.security.access.AccessDeniedException;
|
||||||
@ -19,7 +20,7 @@ import java.io.IOException;
|
|||||||
public class ASEAccessDeniedHandler implements AccessDeniedHandler {
|
public class ASEAccessDeniedHandler implements AccessDeniedHandler {
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
private JSONParameter jsonParameter;
|
private QuickJSONRespond quickJSONRespond;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void handle(HttpServletRequest request, HttpServletResponse response, AccessDeniedException accessDeniedException)
|
public void handle(HttpServletRequest request, HttpServletResponse response, AccessDeniedException accessDeniedException)
|
||||||
@ -27,7 +28,7 @@ public class ASEAccessDeniedHandler implements AccessDeniedHandler {
|
|||||||
log.info("ASEAccessDeniedHandler Found!");
|
log.info("ASEAccessDeniedHandler Found!");
|
||||||
|
|
||||||
// 对无权限操作返回403
|
// 对无权限操作返回403
|
||||||
response.getWriter().print(jsonParameter.getJSONStandardRespond403());
|
response.getWriter().print(quickJSONRespond.getRespond403(null));
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package com.codesdream.ase.component.permission;
|
package com.codesdream.ase.component.permission;
|
||||||
|
|
||||||
import com.codesdream.ase.component.datamanager.JSONParameter;
|
import com.codesdream.ase.component.datamanager.JSONParameter;
|
||||||
|
import com.codesdream.ase.component.datamanager.QuickJSONRespond;
|
||||||
import com.codesdream.ase.component.json.respond.JSONBaseRespondObject;
|
import com.codesdream.ase.component.json.respond.JSONBaseRespondObject;
|
||||||
import com.codesdream.ase.component.json.respond.UserLoginCheckerJSONRespond;
|
import com.codesdream.ase.component.json.respond.UserLoginCheckerJSONRespond;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
@ -19,13 +20,14 @@ import java.io.IOException;
|
|||||||
@Component
|
@Component
|
||||||
public class ASEAuthenticationEntryPoint implements AuthenticationEntryPoint {
|
public class ASEAuthenticationEntryPoint implements AuthenticationEntryPoint {
|
||||||
@Resource
|
@Resource
|
||||||
private JSONParameter jsonParameter;
|
private QuickJSONRespond quickJSONRespond;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void commence(HttpServletRequest request, HttpServletResponse response, AuthenticationException authException)
|
public void commence(HttpServletRequest request, HttpServletResponse response, AuthenticationException authException)
|
||||||
throws IOException, ServletException {
|
throws IOException {
|
||||||
|
|
||||||
// 对匿名用户返回401
|
// 对匿名用户返回401
|
||||||
response.getWriter().print(jsonParameter.getJSONStandardRespond401());
|
response.getWriter().print(quickJSONRespond.getRespond401(null));
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
package com.codesdream.ase.component.permission;
|
package com.codesdream.ase.component.permission;
|
||||||
|
|
||||||
import com.codesdream.ase.component.datamanager.JSONParameter;
|
import com.codesdream.ase.component.datamanager.JSONParameter;
|
||||||
|
import com.codesdream.ase.component.datamanager.QuickJSONRespond;
|
||||||
|
import com.codesdream.ase.component.json.respond.ErrorInfoJSONRespond;
|
||||||
import com.codesdream.ase.component.json.respond.UserLoginCheckerJSONRespond;
|
import com.codesdream.ase.component.json.respond.UserLoginCheckerJSONRespond;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import org.springframework.security.core.AuthenticationException;
|
import org.springframework.security.core.AuthenticationException;
|
||||||
@ -12,6 +14,7 @@ import javax.servlet.ServletException;
|
|||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
// 认证失败返回
|
// 认证失败返回
|
||||||
@Slf4j
|
@Slf4j
|
||||||
@ -19,21 +22,25 @@ import java.io.IOException;
|
|||||||
public class ASEAuthenticationFailureHandler extends SimpleUrlAuthenticationFailureHandler {
|
public class ASEAuthenticationFailureHandler extends SimpleUrlAuthenticationFailureHandler {
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
private JSONParameter jsonParameter;
|
private QuickJSONRespond quickJSONRespond;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onAuthenticationFailure(HttpServletRequest request, HttpServletResponse response, AuthenticationException exception)
|
public void onAuthenticationFailure(HttpServletRequest request, HttpServletResponse response, AuthenticationException exception)
|
||||||
throws IOException
|
throws IOException
|
||||||
{
|
{
|
||||||
log.info("ASEAuthenticationFailureHandler Login Fail!");
|
log.info("ASEAuthenticationFailureHandler Login Fail!");
|
||||||
UserLoginCheckerJSONRespond respond = new UserLoginCheckerJSONRespond();
|
|
||||||
|
|
||||||
respond.setUserExist(null);
|
// 填写异常信息存储对象
|
||||||
respond.setUserBanned(null);
|
ErrorInfoJSONRespond errorInfoJSONRespond = new ErrorInfoJSONRespond();
|
||||||
respond.setLoginStatus(false);
|
errorInfoJSONRespond.setDate(new Date());
|
||||||
respond.setRespondInformation("Authentication Failed");
|
errorInfoJSONRespond.setExceptionMessage(exception.getMessage());
|
||||||
|
errorInfoJSONRespond.setException(exception.getClass().getSimpleName());
|
||||||
|
|
||||||
// 填充response对象
|
// 认证失败返回406
|
||||||
response.getWriter().write(jsonParameter.getJSONStandardRespond200(respond));
|
response.getWriter().write(quickJSONRespond.getJSONStandardRespond(
|
||||||
|
406,
|
||||||
|
"Not Acceptable",
|
||||||
|
"Authentication Failure",
|
||||||
|
errorInfoJSONRespond));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,7 @@ package com.codesdream.ase.component.permission;
|
|||||||
|
|
||||||
import com.codesdream.ase.component.auth.JSONTokenAuthenticationToken;
|
import com.codesdream.ase.component.auth.JSONTokenAuthenticationToken;
|
||||||
import com.codesdream.ase.component.datamanager.JSONParameter;
|
import com.codesdream.ase.component.datamanager.JSONParameter;
|
||||||
|
import com.codesdream.ase.component.datamanager.QuickJSONRespond;
|
||||||
import com.codesdream.ase.component.json.respond.UserLoginCheckerJSONRespond;
|
import com.codesdream.ase.component.json.respond.UserLoginCheckerJSONRespond;
|
||||||
import com.codesdream.ase.model.permission.User;
|
import com.codesdream.ase.model.permission.User;
|
||||||
|
|
||||||
@ -27,7 +28,7 @@ import java.util.Optional;
|
|||||||
@Component
|
@Component
|
||||||
public class ASEAuthenticationSuccessHandler extends SavedRequestAwareAuthenticationSuccessHandler {
|
public class ASEAuthenticationSuccessHandler extends SavedRequestAwareAuthenticationSuccessHandler {
|
||||||
@Resource
|
@Resource
|
||||||
private JSONParameter jsonParameter;
|
private QuickJSONRespond quickJSONRespond;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
private IAuthService authService;
|
private IAuthService authService;
|
||||||
@ -40,7 +41,6 @@ public class ASEAuthenticationSuccessHandler extends SavedRequestAwareAuthentica
|
|||||||
UserLoginCheckerJSONRespond respond = new UserLoginCheckerJSONRespond();
|
UserLoginCheckerJSONRespond respond = new UserLoginCheckerJSONRespond();
|
||||||
respond.setUserExist(authentication.isAuthenticated());
|
respond.setUserExist(authentication.isAuthenticated());
|
||||||
respond.setLoginStatus(authentication.isAuthenticated());
|
respond.setLoginStatus(authentication.isAuthenticated());
|
||||||
respond.setRespondInformation("Authentication Success");
|
|
||||||
|
|
||||||
// 获得 JSONTokenAuthenticationToken
|
// 获得 JSONTokenAuthenticationToken
|
||||||
JSONTokenAuthenticationToken authenticationToken = (JSONTokenAuthenticationToken) authentication;
|
JSONTokenAuthenticationToken authenticationToken = (JSONTokenAuthenticationToken) authentication;
|
||||||
@ -55,7 +55,8 @@ public class ASEAuthenticationSuccessHandler extends SavedRequestAwareAuthentica
|
|||||||
}
|
}
|
||||||
else respond.setToken("");
|
else respond.setToken("");
|
||||||
|
|
||||||
response.getWriter().write(jsonParameter.getJSONStandardRespond200(respond));
|
// 认证成功返回200
|
||||||
|
response.getWriter().write(quickJSONRespond.getRespond200("Authentication Success", respond));
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -43,10 +43,8 @@ public class ASESecurityAuthenticationProvider implements AuthenticationProvider
|
|||||||
// 判断用户是否存在
|
// 判断用户是否存在
|
||||||
UserDetails userInfo = userDetailsService.loadUserByUsername(username);
|
UserDetails userInfo = userDetailsService.loadUserByUsername(username);
|
||||||
|
|
||||||
log.info(String.format("SecurityAuthentication: %s %s", username, password));
|
|
||||||
|
|
||||||
if (userInfo == null) {
|
if (userInfo == null) {
|
||||||
throw new UsernameNotFoundException("User IS Not Existing");
|
throw new UsernameNotFoundException("User Not Exist");
|
||||||
}
|
}
|
||||||
|
|
||||||
// 判断密码是否正确
|
// 判断密码是否正确
|
||||||
|
@ -49,16 +49,24 @@ public class ASEUsernamePasswordAuthenticationFilter extends UsernamePasswordAut
|
|||||||
throw new AuthenticationServiceException("Authentication method not supported: NOT Ajax Method.");
|
throw new AuthenticationServiceException("Authentication method not supported: NOT Ajax Method.");
|
||||||
}
|
}
|
||||||
|
|
||||||
Optional<UserLoginChecker> checker = jsonParameter.getJavaObjectByRequest(request, UserLoginChecker.class);
|
Optional<UserLoginChecker> checkerOptional = jsonParameter.getJavaObjectByRequest(request, UserLoginChecker.class);
|
||||||
if(!checker.isPresent()) throw new BadCredentialsException("Invalid AJAX JSON Request");
|
if(!checkerOptional.isPresent()) throw new BadCredentialsException("Invalid AJAX JSON Request");
|
||||||
|
|
||||||
if (!checker.get().getCheckType().equals("UsernamePasswordChecker"))
|
UserLoginChecker checker = checkerOptional.get();
|
||||||
|
|
||||||
|
if(checker.getUsername() == null
|
||||||
|
|| checker.getPassword() == null
|
||||||
|
|| checker.getClientCode() == null
|
||||||
|
|| checker.getCheckType() == null)
|
||||||
|
throw new AuthenticationServiceException("Request Data IS Incomplete");
|
||||||
|
|
||||||
|
if (!checker.getCheckType().equals("UsernamePasswordChecker"))
|
||||||
throw new AuthenticationServiceException("Authentication not supported: NOT Username Password Type.");
|
throw new AuthenticationServiceException("Authentication not supported: NOT Username Password Type.");
|
||||||
|
|
||||||
// 获得相应的用户名密码
|
// 获得相应的用户名密码
|
||||||
String username = checker.get().getUsername();
|
String username = checker.getUsername();
|
||||||
String password = checker.get().getPassword();
|
String password = checker.getPassword();
|
||||||
String clientCode = checker.get().getClientCode();
|
String clientCode = checker.getClientCode();
|
||||||
|
|
||||||
if (username == null) username = "";
|
if (username == null) username = "";
|
||||||
if (password == null) password = "";
|
if (password == null) password = "";
|
||||||
|
@ -1,23 +1,31 @@
|
|||||||
package com.codesdream.ase.controller;
|
package com.codesdream.ase.controller;
|
||||||
|
|
||||||
import com.codesdream.ase.component.error.ErrorResponse;
|
import com.codesdream.ase.component.error.ErrorResponse;
|
||||||
|
import com.codesdream.ase.component.json.respond.ErrorInfoJSONRespond;
|
||||||
import org.springframework.http.HttpStatus;
|
import org.springframework.http.HttpStatus;
|
||||||
import org.springframework.http.ResponseEntity;
|
import org.springframework.http.ResponseEntity;
|
||||||
|
import org.springframework.security.authentication.AuthenticationServiceException;
|
||||||
|
import org.springframework.security.core.AuthenticationException;
|
||||||
import org.springframework.web.bind.annotation.ControllerAdvice;
|
import org.springframework.web.bind.annotation.ControllerAdvice;
|
||||||
import org.springframework.web.bind.annotation.ExceptionHandler;
|
import org.springframework.web.bind.annotation.ExceptionHandler;
|
||||||
|
import org.springframework.web.bind.annotation.RestControllerAdvice;
|
||||||
import org.springframework.web.context.request.WebRequest;
|
import org.springframework.web.context.request.WebRequest;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Date;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ControllerAdvice
|
@RestControllerAdvice
|
||||||
public class ASEControllerAdvice {
|
public class ASEControllerAdvice {
|
||||||
@ExceptionHandler(value = {RuntimeException.class})
|
@ExceptionHandler(value = {RuntimeException.class})
|
||||||
public final ResponseEntity<Object> handleRuntimeException(RuntimeException e, WebRequest webRequest){
|
public final Object handleRuntimeException(RuntimeException e, WebRequest webRequest){
|
||||||
List<String> details = new ArrayList<>();
|
ErrorInfoJSONRespond errorInfoJSONRespond = new ErrorInfoJSONRespond();
|
||||||
details.add(e.getLocalizedMessage());
|
errorInfoJSONRespond.setDate(new Date());
|
||||||
ErrorResponse errorResponse = new ErrorResponse("Runtime Error", details);
|
errorInfoJSONRespond.setExceptionMessage(e.getMessage());
|
||||||
return new ResponseEntity<>(errorResponse, HttpStatus.INTERNAL_SERVER_ERROR);
|
errorInfoJSONRespond.setException(e.getClass().getName());
|
||||||
|
return errorInfoJSONRespond;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
package com.codesdream.ase.controller;
|
package com.codesdream.ase.controller;
|
||||||
|
|
||||||
|
import com.codesdream.ase.component.datamanager.QuickJSONRespond;
|
||||||
import com.codesdream.ase.component.error.ErrorResponse;
|
import com.codesdream.ase.component.error.ErrorResponse;
|
||||||
|
import com.codesdream.ase.component.json.respond.ErrorInfoJSONRespond;
|
||||||
import org.springframework.boot.web.servlet.error.ErrorController;
|
import org.springframework.boot.web.servlet.error.ErrorController;
|
||||||
import org.springframework.http.HttpStatus;
|
import org.springframework.http.HttpStatus;
|
||||||
import org.springframework.http.ResponseEntity;
|
import org.springframework.http.ResponseEntity;
|
||||||
@ -9,8 +11,10 @@ import org.springframework.ui.Model;
|
|||||||
import org.springframework.web.bind.annotation.ControllerAdvice;
|
import org.springframework.web.bind.annotation.ControllerAdvice;
|
||||||
import org.springframework.web.bind.annotation.ExceptionHandler;
|
import org.springframework.web.bind.annotation.ExceptionHandler;
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.ResponseBody;
|
||||||
import org.springframework.web.context.request.WebRequest;
|
import org.springframework.web.context.request.WebRequest;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
@ -19,7 +23,7 @@ import java.util.List;
|
|||||||
@Controller
|
@Controller
|
||||||
public class ASEErrorController implements ErrorController {
|
public class ASEErrorController implements ErrorController {
|
||||||
|
|
||||||
@RequestMapping("/error")
|
/* @RequestMapping("/error")
|
||||||
public String handleError(HttpServletRequest request, Model model){
|
public String handleError(HttpServletRequest request, Model model){
|
||||||
Integer statusCode = (Integer) request.getAttribute("javax.servlet.error.status_code");
|
Integer statusCode = (Integer) request.getAttribute("javax.servlet.error.status_code");
|
||||||
Exception exception = (Exception) request.getAttribute("javax.servlet.error.exception");
|
Exception exception = (Exception) request.getAttribute("javax.servlet.error.exception");
|
||||||
@ -49,7 +53,36 @@ public class ASEErrorController implements ErrorController {
|
|||||||
model.addAttribute("exception_date", new Date());
|
model.addAttribute("exception_date", new Date());
|
||||||
}
|
}
|
||||||
return "error";
|
return "error";
|
||||||
|
}*/
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private QuickJSONRespond quickJSONRespond;
|
||||||
|
|
||||||
|
@RequestMapping("/error")
|
||||||
|
@ResponseBody
|
||||||
|
public String handleError(HttpServletRequest request){
|
||||||
|
Integer statusCode = (Integer) request.getAttribute("javax.servlet.error.status_code");
|
||||||
|
Exception exception = (Exception) request.getAttribute("javax.servlet.error.exception");
|
||||||
|
|
||||||
|
// 检查返回的状态
|
||||||
|
if (statusCode == HttpStatus.NOT_FOUND.value()) return quickJSONRespond.getRespond404(null);
|
||||||
|
ErrorInfoJSONRespond errorInfoJSONRespond = new ErrorInfoJSONRespond();
|
||||||
|
|
||||||
|
// 检查是否含有引发异常
|
||||||
|
if (exception.getCause() == null) {
|
||||||
|
errorInfoJSONRespond.setException(exception.getClass().getName());
|
||||||
|
errorInfoJSONRespond.setExceptionMessage(exception.getMessage());
|
||||||
|
} else {
|
||||||
|
errorInfoJSONRespond.setException(exception.getCause().getClass().getName());
|
||||||
|
errorInfoJSONRespond.setExceptionMessage(exception.getCause().getMessage());
|
||||||
|
}
|
||||||
|
errorInfoJSONRespond.setDate(new Date());
|
||||||
|
|
||||||
|
return quickJSONRespond.getJSONStandardRespond(
|
||||||
|
statusCode,
|
||||||
|
"Error Controller Handle",
|
||||||
|
null,
|
||||||
|
errorInfoJSONRespond);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -2,6 +2,7 @@ package com.codesdream.ase.controller;
|
|||||||
|
|
||||||
import com.alibaba.fastjson.JSONObject;
|
import com.alibaba.fastjson.JSONObject;
|
||||||
import com.codesdream.ase.component.datamanager.JSONParameter;
|
import com.codesdream.ase.component.datamanager.JSONParameter;
|
||||||
|
import com.codesdream.ase.component.datamanager.QuickJSONRespond;
|
||||||
import com.codesdream.ase.component.json.respond.JSONStandardFailedRespond;
|
import com.codesdream.ase.component.json.respond.JSONStandardFailedRespond;
|
||||||
import com.codesdream.ase.component.json.respond.JSONBaseRespondObject;
|
import com.codesdream.ase.component.json.respond.JSONBaseRespondObject;
|
||||||
import com.codesdream.ase.component.permission.ASEUsernameEncoder;
|
import com.codesdream.ase.component.permission.ASEUsernameEncoder;
|
||||||
@ -30,6 +31,9 @@ public class LoginController {
|
|||||||
@Resource
|
@Resource
|
||||||
private JSONParameter jsonParameter;
|
private JSONParameter jsonParameter;
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private QuickJSONRespond quickJSONRespond;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
private IUserService userService;
|
private IUserService userService;
|
||||||
|
|
||||||
@ -61,11 +65,11 @@ public class LoginController {
|
|||||||
// 构造返回对象
|
// 构造返回对象
|
||||||
UserLoginCheckerJSONRespond respond = new UserLoginCheckerJSONRespond();
|
UserLoginCheckerJSONRespond respond = new UserLoginCheckerJSONRespond();
|
||||||
respond.setUserExist(existStatus);
|
respond.setUserExist(existStatus);
|
||||||
return jsonParameter.getJSONStandardRespond200(respond);
|
return quickJSONRespond.getRespond200(null, respond);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
// 返回失败对象
|
// 返回失败对象
|
||||||
return jsonParameter.getJSONStandardRespond500("Error");
|
return quickJSONRespond.getRespond400("CheckType Mismatch");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -81,12 +85,12 @@ public class LoginController {
|
|||||||
|
|
||||||
if(loginChecker.getCheckType().equals("UIDGeneratorChecker")) {
|
if(loginChecker.getCheckType().equals("UIDGeneratorChecker")) {
|
||||||
UserLoginCheckerJSONRespond respond = new UserLoginCheckerJSONRespond();
|
UserLoginCheckerJSONRespond respond = new UserLoginCheckerJSONRespond();
|
||||||
respond.setRespondInformation(userService.getUsernameByStudentId(loginChecker.getUsername()));
|
respond.setUid(userService.getUsernameByStudentId(loginChecker.getUsername()));
|
||||||
return jsonParameter.getJSONStandardRespond200(respond);
|
return quickJSONRespond.getRespond200(null, respond);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
// 返回失败对象
|
// 返回失败对象
|
||||||
return jsonParameter.getJSONStandardRespond500("Error");
|
return quickJSONRespond.getRespond400("CheckType Mismatch");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
package com.codesdream.ase.controller;
|
package com.codesdream.ase.controller;
|
||||||
|
|
||||||
|
import com.codesdream.ase.component.datamanager.JSONParameter;
|
||||||
|
import com.codesdream.ase.component.datamanager.QuickJSONRespond;
|
||||||
|
import com.codesdream.ase.component.json.request.UserRegisterChecker;
|
||||||
import com.codesdream.ase.model.information.BaseStudentInfo;
|
import com.codesdream.ase.model.information.BaseStudentInfo;
|
||||||
import com.codesdream.ase.model.permission.User;
|
import com.codesdream.ase.model.permission.User;
|
||||||
import com.codesdream.ase.service.BaseInformationService;
|
import com.codesdream.ase.service.BaseInformationService;
|
||||||
@ -8,10 +11,11 @@ import org.springframework.stereotype.Controller;
|
|||||||
import org.springframework.ui.Model;
|
import org.springframework.ui.Model;
|
||||||
import org.springframework.web.bind.annotation.PostMapping;
|
import org.springframework.web.bind.annotation.PostMapping;
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.ResponseBody;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import java.util.Map;
|
import java.util.Optional;
|
||||||
|
|
||||||
@Controller
|
@Controller
|
||||||
public class RegisterController {
|
public class RegisterController {
|
||||||
@ -21,61 +25,73 @@ public class RegisterController {
|
|||||||
@Resource
|
@Resource
|
||||||
private BaseInformationService baseInformationService;
|
private BaseInformationService baseInformationService;
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private JSONParameter jsonParameter;
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private QuickJSONRespond quickJSONRespond;
|
||||||
|
|
||||||
@RequestMapping(value = "/register")
|
@RequestMapping(value = "/register")
|
||||||
String registerView(Model model){
|
String registerView(Model model){
|
||||||
return "register";
|
return "register";
|
||||||
}
|
}
|
||||||
|
|
||||||
// 处理注册表单
|
// 处理注册表单
|
||||||
@PostMapping(value = "/register")
|
@PostMapping(value = "/register/do_register")
|
||||||
String doRegister(Model model, HttpServletRequest request){
|
@ResponseBody
|
||||||
Map<String, String[]> parameterMap= request.getParameterMap();
|
String doRegister(HttpServletRequest request){
|
||||||
|
|
||||||
// 进行处理前的检查
|
Optional<UserRegisterChecker> registerCheckerOptional =
|
||||||
if(parameterMap.containsKey("student-id")
|
jsonParameter.getJavaObjectByRequest(request, UserRegisterChecker.class);
|
||||||
&& parameterMap.containsKey("password")
|
|
||||||
&& parameterMap.containsKey("retry-password")
|
|
||||||
&& parameterMap.containsKey("user-question")
|
|
||||||
&& parameterMap.containsKey("user-answer")
|
|
||||||
) {
|
|
||||||
// 获得提交学号
|
|
||||||
String student_id = parameterMap.get("student-id")[0].toString();
|
|
||||||
// 获得密保问题
|
|
||||||
String user_question = parameterMap.get("user-question")[0].toString();
|
|
||||||
// 获得密保答案
|
|
||||||
String user_answer = parameterMap.get("user-answer")[0].toString();
|
|
||||||
|
|
||||||
// 检查用户的基本信息是否录入系统
|
|
||||||
if(!baseInformationService.checkStudentInfo(student_id))
|
|
||||||
throw new RuntimeException("Student ID Not Found In Base Information Service");
|
|
||||||
|
|
||||||
// 查找对应的基本信息
|
|
||||||
BaseStudentInfo studentInfo = baseInformationService.findStudentInfoByStudentId(student_id);
|
|
||||||
|
|
||||||
// 根据基本信息生成对应用户
|
|
||||||
User user = userService.getUserByStudentInfo(studentInfo);
|
|
||||||
|
|
||||||
// 填充密保问题
|
|
||||||
user.getUserAuth().setUserQuestion(user_question);
|
|
||||||
user.getUserAuth().setUserAnswer(user_answer);
|
|
||||||
user.getUserAuth().setMail("");
|
|
||||||
|
|
||||||
String password = parameterMap.get("password")[0].toString();
|
|
||||||
String retry_password = parameterMap.get("retry-password")[0].toString();
|
|
||||||
|
|
||||||
if (password.equals(retry_password)) {
|
|
||||||
user.setPassword(password);
|
|
||||||
userService.save(user);
|
|
||||||
// 返回登录界面
|
|
||||||
return "login";
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
throw new RuntimeException("Retry Password Not Correct");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
// 检查JSON是否完整
|
||||||
|
if(!registerCheckerOptional.isPresent()){
|
||||||
|
return quickJSONRespond.getRespond400("Illegal JSON Format");
|
||||||
}
|
}
|
||||||
|
|
||||||
return "register";
|
// 检查数据是否完整
|
||||||
|
UserRegisterChecker registerChecker = registerCheckerOptional.get();
|
||||||
|
if(registerChecker.getPassword() == null
|
||||||
|
|| registerChecker.getStudentId() == null
|
||||||
|
|| registerChecker.getUserAnswer() == null
|
||||||
|
|| registerChecker.getUserQuestion() == null){
|
||||||
|
return quickJSONRespond.getRespond400("Incomplete Data");
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获得提交学号
|
||||||
|
String student_id = registerChecker.getStudentId();
|
||||||
|
// 获得密保问题
|
||||||
|
String user_question = registerChecker.getUserQuestion();
|
||||||
|
// 获得密保答案
|
||||||
|
String user_answer = registerChecker.getUserAnswer();
|
||||||
|
|
||||||
|
// 检查用户的基本信息是否录入系统
|
||||||
|
if(!baseInformationService.checkStudentInfo(student_id))
|
||||||
|
return quickJSONRespond.getRespond500("StudentID Base Information Not Found");
|
||||||
|
|
||||||
|
// 检查学号是否已被注册
|
||||||
|
if(userService.checkIfUserExists(userService.getUsernameByStudentId(student_id)).getKey()){
|
||||||
|
return quickJSONRespond.getRespond500("StudentID Already Used");
|
||||||
|
}
|
||||||
|
|
||||||
|
// 查找对应的基本信息
|
||||||
|
BaseStudentInfo studentInfo = baseInformationService.findStudentInfoByStudentId(student_id);
|
||||||
|
|
||||||
|
// 根据基本信息生成对应用户
|
||||||
|
User user = userService.getUserByStudentInfo(studentInfo);
|
||||||
|
|
||||||
|
// 填充密保问题
|
||||||
|
user.getUserAuth().setUserQuestion(user_question);
|
||||||
|
user.getUserAuth().setUserAnswer(user_answer);
|
||||||
|
user.getUserAuth().setMail("");
|
||||||
|
|
||||||
|
String password = registerChecker.getPassword();
|
||||||
|
|
||||||
|
user.setPassword(password);
|
||||||
|
userService.save(user);
|
||||||
|
|
||||||
|
// 成功注册
|
||||||
|
return quickJSONRespond.getRespond200("Register Success");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
package com.codesdream.ase.service;
|
package com.codesdream.ase.service;
|
||||||
|
|
||||||
import com.codesdream.ase.component.permission.UserAuthoritiesGenerator;
|
import com.codesdream.ase.component.permission.UserAuthoritiesGenerator;
|
||||||
|
import com.codesdream.ase.exception.UserNotFoundException;
|
||||||
import com.codesdream.ase.model.permission.User;
|
import com.codesdream.ase.model.permission.User;
|
||||||
|
import org.springframework.security.authentication.AuthenticationServiceException;
|
||||||
import org.springframework.security.core.userdetails.UserDetails;
|
import org.springframework.security.core.userdetails.UserDetails;
|
||||||
import org.springframework.security.core.userdetails.UserDetailsService;
|
import org.springframework.security.core.userdetails.UserDetailsService;
|
||||||
import org.springframework.security.core.userdetails.UsernameNotFoundException;
|
import org.springframework.security.core.userdetails.UsernameNotFoundException;
|
||||||
@ -21,9 +23,14 @@ public class ASEUserDetailsService implements UserDetailsService {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
@Transactional
|
@Transactional
|
||||||
public UserDetails loadUserByUsername(String s) throws UsernameNotFoundException {
|
public UserDetails loadUserByUsername(String s) {
|
||||||
User user = userService.findUserByUsername(s);
|
try {
|
||||||
user.setAuthorities(userAuthoritiesGenerator.grantedAuthorities(user));
|
User user = userService.findUserByUsername(s);
|
||||||
return user;
|
user.setAuthorities(userAuthoritiesGenerator.grantedAuthorities(user));
|
||||||
|
return user;
|
||||||
|
} catch (UserNotFoundException e){
|
||||||
|
throw new AuthenticationServiceException("User Not Exist");
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user