SpringMVC整合,出現(xiàn)注解沒有起作用的情況處理
SpringMVC整合注解沒有起作用
在spring的applicationContext.xml中配置問題
正確的配置:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" ? ? ? ?xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"? ? ? ? ?xmlns:context="http://www.springframework.org/schema/context" ? ? ? ?xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd ? ? ? ? http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd"> ? ? <!--啟動注解--> ? ? <context:annotation-config /> ? ? <!-- ?base-package 注解所在的包根據(jù)自己的需要劃分注解類使用的范圍 ?--> ? ? <context:component-scan base-package="main.com.talkweb"> ? ? ? ? <!--不再管理Controller 注解 ?因為它單獨給mvc-servler.xml去管理--> ? ? ? ? <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller" /> ? ? </context:component-scan> </beans>
明明有啟動注解,但有些注解還是沒起作用
<!--啟動注解--> ? ? <context:annotation-config />
后來發(fā)現(xiàn)原因是:下面這句作與springMVC的controller注解的排除關(guān)注時,把掃描注解的返回局限了
原來 base-package=”main.com.talkweb.Controller”:
!-- ?base-package 注解所在的包根據(jù)自己的需要劃分注解類使用的范圍 ?--> ? ? <context:component-scan base-package="main.com.talkweb.Controller"> ? ? ? ? <!--不再管理Controller 注解 ?因為它單獨給mvc-servler.xml去管理--> ? ? ? ? <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller" /> ? ? </context:component-scan>
現(xiàn)在的包范圍 base-package=“main.com.talkweb”:
!-- ?base-package 注解所在的包根據(jù)自己的需要劃分注解類使用的范圍 ?--> ? ? <context:component-scan base-package="main.com.talkweb"> ? ? ? ? <!--不再管理Controller 注解 ?因為它單獨給mvc-servler.xml去管理--> ? ? ? ? <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller" /> ? ? </context:component-scan>
注解方式整合SpringMVC
整合SpringMVC分析
web容器在啟動的時候,會掃描每個jar包下的META-INF/services/javax.servlet.ServletContainerInitializer文件,加載這個文件里面指定的類SpringServletContainerInitializer

spring的應(yīng)用一啟動就會加載WebApplicationInitializer接口下的所有組件并創(chuàng)建對象

WebApplicationInitializer接口下有三個抽象類

AbstractContextLoaderInitializer抽象類:
調(diào)用createRootApplicationContext()方法來創(chuàng)建根容器

AbstractDispatcherServletInitializer抽象類
調(diào)用createServletApplicationContext()方法創(chuàng)建一個web的IOC容器
調(diào)用createDispatcherServlet()方法創(chuàng)建了DispatchServlet
將創(chuàng)建的DispatchServlet添加到ServletContext中

AbstractAnnotationConfigDispatcherServletInitializer抽象類
使用注解的方式配置的DispatcherServlet初始化器
該類重寫AbstractContextLoaderInitializer父類的createRootApplicationContext()方法來創(chuàng)建根容器。調(diào)用getRootConfigClasses()方法傳入一個配置類

該類還重寫了AbstractDispatcherServletInitializer父類的createServletApplicationContext()方法來創(chuàng)建web的IOC容器。獲取配置類注冊到IOC容器中。

以注解方式來啟動SpringMVC,需要繼承AbstractAnnotationConfigDispatcherServletInitializer,然后實現(xiàn)抽象方法指定DispatcherServlet的配置信息
注解方式整合SpringMVC
自定義容器初始化器
/*web容器啟動的時候創(chuàng)建對象,調(diào)用方法來初始化容器以及前端控制器*/
public class MyWebAppInitializer extends AbstractAnnotationConfigDispatcherServletInitializer {
/*獲取根容器的配置類,相當(dāng)于Spring的配置文件,用來創(chuàng)建父容器*/
protected Class<?>[] getRootConfigClasses() {
return new Class[]{RootConfig.class};
}
/*獲取web容器的配置類,相當(dāng)于SpringMVC的配置文件,用來創(chuàng)建子容器*/
protected Class<?>[] getServletConfigClasses() {
return new Class[]{AppConfig.class};
}
/*獲取DispatcherServlet的映射信息*/
protected String[] getServletMappings() {
return new String[]{"/"};
}
}子容器配置類
//SpringMVC只掃描Controller,子容器
@ComponentScan(value = "springMVC", includeFilters = {
@ComponentScan.Filter(type = FilterType.ANNOTATION, classes = {Controller.class})
})
public class AppConfig {
}父容器配置類
//Spring的容器不掃描Controller,必須禁用默認(rèn)的過濾規(guī)則才會生效,父容器
@ComponentScan(value = "springMVC", excludeFilters = {
@ComponentScan.Filter(type = FilterType.ANNOTATION, classes = {Controller.class})
}, useDefaultFilters = false)
public class RootConfig {
}Service層
@Service
public class HelloService {
public String sayHello(String name){
return "hello " + name;
}
}Controller層
@Controller
public class HelloController {
@Autowired
HelloService helloService;
@ResponseBody
@RequestMapping("/hello")
public String hello(){
String hello = helloService.sayHello("張三");
return hello;
}
}定制SpringMVC
使用@EnableWebMvc開啟SpringMVC定制配置功能,相當(dāng)于在xml文件中使用<mvc:annotation-driven/>標(biāo)簽
@ComponentScan(value = {"controller", "service", "config", "springMVC"}, includeFilters = {
@ComponentScan.Filter(type = FilterType.ANNOTATION, classes = {Controller.class})
}, useDefaultFilters = false)
@EnableWebMvc
public class AppConfig {
}配置組件,包括視圖解析器、視圖映射、靜態(tài)資源映射、攔截器等等
@ComponentScan(value = {"controller", "service", "config", "springMVC"}, includeFilters = {
@ComponentScan.Filter(type = FilterType.ANNOTATION, classes = {Controller.class})
}, useDefaultFilters = false)
@EnableWebMvc
public class AppConfig extends WebMvcConfigurerAdapter{
//定制視圖解析器
@Override
public void configureViewResolvers(ViewResolverRegistry registry) {
registry.jsp("/WEB-INF/views/", ".jsp");
}
//定制靜態(tài)資源訪問
@Override
public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
/*相當(dāng)于在xml配置文件中使用<mvc:default-servlet-handler>標(biāo)簽,
* 將SpringMVC處理不了的請求交給Tomcat,這樣靜態(tài)資源就可以訪問了*/
configurer.enable();
}
//定制攔截器
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new MyInterceptor()).addPathPatterns("/**");
}
}總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
spring-AOP 及 AOP獲取request各項參數(shù)操作
這篇文章主要介紹了spring-AOP 及 AOP獲取request各項參數(shù)的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07
Java?8?的異步編程利器?CompletableFuture的實例詳解
這篇文章主要介紹了Java?8?的異步編程利器?CompletableFuture?詳解,本文通過一個例子給大家介紹下Java?8??CompletableFuture異步編程的相關(guān)知識,需要的朋友可以參考下2022-03-03
spring security中的csrf防御原理(跨域請求偽造)
這篇文章主要介紹了spring security中的csrf防御機制原理解析(跨域請求偽造),本文通過實例代碼詳解的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12

