WebMvcConfig.java
4.87 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
package isa.qa.config;
import com.fasterxml.jackson.databind.ObjectMapper;
import isa.qa.core.AuthenticationFailedException;
import isa.qa.core.Result;
import isa.qa.properties.FileProperties;
import lombok.AllArgsConstructor;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.MediaType;
import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.HandlerExceptionResolver;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.NoHandlerFoundException;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.DefaultServletHandlerConfigurer;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.nio.file.AccessDeniedException;
import java.util.List;
import static io.undertow.util.StatusCodes.NOT_FOUND;
import static isa.qa.core.ResultCodeEnums.*;
/**
* Web Mvc Config
*
* @author May
* @version 1.0
* @date 2018/11/21 10:47
*/
@Configuration
@AllArgsConstructor
public class WebMvcConfig implements WebMvcConfigurer {
/**
* LOGGER
*/
private static final Logger LOGGER = LoggerFactory.getLogger(WebMvcConfig.class);
private static final String CHARSET_UTF_8 = "UTF-8";
private static final String HEADER_CONTENT_TYPE = "Content-type";
private final ObjectMapper objectMapper;
private final FileProperties fileProperties;
/**
* 解决跨域问题
*/
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**")
.allowedMethods("HEAD", "GET", "PUT", "POST", "DELETE", "PATCH");
}
/**
* 发现如果继承了WebMvcConfigurationSupport,则在yml中配置的相关内容会失效。 需要重新指定静态资源
*/
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/**").addResourceLocations("classpath:/static/");
registry.addResourceHandler("/files/**").addResourceLocations("file:" + fileProperties.getBasePath());
}
/**
* 配置servlet处理
*/
@Override
public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
configurer.enable();
}
/**
* 统一异常处理
*/
@Override
public void configureHandlerExceptionResolvers(
List<HandlerExceptionResolver> exceptionResolvers) {
exceptionResolvers.add((request, response, handler, e) -> {
Result result = new Result();
if (e instanceof IllegalArgumentException) {
result.setCode(BAD_REQUEST).setMessage(e.getMessage());
LOGGER.info(e.getMessage());
} else if (e instanceof AuthenticationFailedException) {
result.setCode(UNAUTHORIZED).setMessage(e.getMessage());
} else if (e instanceof NoHandlerFoundException) {
result.setCode(NOT_FOUND)
.setMessage("接口 [" + request.getRequestURI() + "] 不存在");
} else if (e instanceof AccessDeniedException) {
result.setCode(UNAUTHORIZED).setMessage("没有足够的权限访问该接口");
} else {
result.setCode(INTERNAL_SERVER_ERROR)
.setMessage("接口 [" + request.getRequestURI() + "] 内部错误,请联系管理员");
String message;
if (handler instanceof HandlerMethod) {
HandlerMethod handlerMethod = (HandlerMethod) handler;
message = String.format("接口 [%s] 出现异常,方法:%s.%s,异常摘要:%s",
request.getRequestURI(),
handlerMethod.getBean().getClass().getName(),
handlerMethod.getMethod().getName(),
e.getMessage());
} else {
message = e.getMessage();
}
LOGGER.error(message, e);
}
responseResult(response, result);
return new ModelAndView();
});
}
/**
* 为Response设置Encoding、header等参数
*/
private void responseResult(HttpServletResponse response, Result result) {
response.setCharacterEncoding(CHARSET_UTF_8);
response.setHeader(HEADER_CONTENT_TYPE, MediaType.APPLICATION_JSON_UTF8_VALUE);
response.setStatus(200);
try {
response.getWriter().write(objectMapper.writeValueAsString(result));
} catch (IOException ex) {
LOGGER.error(ex.getMessage());
}
}
}