1.Springmvc注解方式注入
之前定义统一异常处理类DemoExceptionResolver和切面定义LogAspectj都是配置文件进行配置。
使用@Component表示类,让<context:component-scan base-package="com.company"/>扫入spring容器。
@Aspect
@Component
public class LogAspectj {
private static final Logger LOGGER = LoggerFactory.getLogger(LogAspectj.class);
@AfterReturning(value = "@annotation(com.company.aspectj.Log)",returning = "ret")
public void LogAfterReturning(JoinPoint joinPoint,Object ret){
Object[] args = joinPoint.getArgs();
LOGGER.info("方法入参:{}",args);
LOGGER.info("返回值:{}",ret);
}
}
@Component
public class DemoExceptionResolver implements HandlerExceptionResolver {
private static final Logger LOG = LoggerFactory.getLogger(DemoExceptionResolver.class);
@Override
public ModelAndView resolveException(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex){
response.setHeader("Content-type", "text/html;charset=UTF-8");
response.setCharacterEncoding("UTF-8");
PrintWriter pw = null;
try {
pw = response.getWriter();
} catch (IOException e) {
LOG.error(e.getMessage(),e);
}
if (ex instanceof DemoException) {
pw.write(ex.getMessage());
} else {
pw.write("系统异常,请联系管理员");
}
return new ModelAndView();
}
}
同时将spring-mvc.xml相关配置去掉。
2.使用import导入其他配置文件
之前其他module下的配置文件是在web.xml配置classpath*:spring-*.xml进加载。
使用import标签进行导入。
- web.xml:只配置spring-mvc.xml,在spring-mvc.xml使用import标签。
<servlet>
<description>spring mvc servlet</description>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>
classpath:spring-mvc.xml
</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
- spring-mvc.xml:
<!--spring-mvc组件默认配置+启动注解等等-->
<mvc:annotation-driven/>
<context:component-scan base-package="com.company"/>
<!--@aspectj启动,子类代理-->
<aop:aspectj-autoproxy proxy-target-class="true"/>
<!--spring最多加载一个context:property-placeholder-->
<!--如果去掉jdbc.properties加载,demo-web启动会提示找不对应变量值-->
<context:property-placeholder location="classpath:redis.properties,classpath*:jdbc.properties"/>
<!--将spring-redis引入spring中-->
<import resource="spring-redis.xml"/> <import resource="spring-mybatis.xml"/>
3.其他变动
demo-base子工程下原来的代码中包名进行修改:将demo=>company。