Spring MVC 和 Spring 總結

1. 爲何使用Spring ?html

    1). 方便解耦,簡化開發前端

         經過Spring提供的IoC容器,能夠將對象之間的依賴關係交由Spring進行控制,避免硬編碼所形成的過分程序耦合。web

    2). AOP編程的支持ajax

         經過Spring提供的AOP功能,方便進行面向切面的編程,如性能監測、事務管理、日誌記錄等。spring

    3). 聲明式事務的支持sql

    4). 方便集成各類優秀框架數據庫

    5). 下降Java EE API的使用難度編程

         如對JDBC,JavaMail,遠程調用等提供了簡便封裝json

2. 什麼是IoC,爲什使用IoC ?數組

    IoC全稱Iversion of Controller,控制反轉。

    這概念是說你不用建立對象,而只須要描述它如何被建立。你不在代碼裏直接組裝你的組件和服務,可是要在配置文件裏描述哪些組件須要哪些服務,以後一個容器(IOC容器)負責把他們組裝起來。

    它能指導咱們如何設計出鬆耦合、更優良的程序。

3. 什麼是AOP,爲何使用AOP ?

    AOP全稱:Aspect-Oriented Programming,面向切面編程。

     AOP,面向切面編程,就是把可重用的功能提取出來,而後將這些通用功能在合適的時候織入到應用程序中,好比事務管理權限控制日誌記錄、性能統計等。

    AOP並無幫助咱們解決任何新的問題,它只是提供了一種更好的辦法,可以用更少的工做量來解決現有的一些問題,使得系統更加健壯,可維護性更好。

4. 什麼是Spring的事務管理?

    事務就是對一系列的數據庫操做(好比插入多條數據)進行統一的提交或回滾操做,若是插入成功,那麼一塊兒成功,若是中間有一條出現異常,那麼回滾以前的全部操做。這樣能夠防止出現髒數據,防止數據庫數據出現問題。

    開發中爲了不這種狀況通常都會進行事務管理。

    Spring的聲明式事務一般是指在配置文件中對事務進行配置聲明,其中包括了不少聲明屬性,它是經過Spring Proxy幫你作代理,本身不用額外的寫代碼,只要在Spring配置文件中聲明便可;一般用在數據庫的操做裏面;

    編程式事務就是指經過硬編碼的方式作事務處理,這種處理方式須要寫代碼,事務中的邏輯能夠本身定製;能夠是數據庫的東東,也能夠是其餘的操做。

    Spring中也有本身的事務管理機制,通常是使用TransactionMananger進行管理,能夠經過Spring的注入來完成此功能。

5. Spring框架支持如下五種bean的做用域:

    singleton : 默認值,bean在每一個Spring ioc 容器中只有一個實例。

    prototype:一個bean的定義能夠有多個實例。

    request:每次http請求都會建立一個bean,該做用域僅在基於web的Spring ApplicationContext情形下有效。 

    session:在一個HTTP Session中,一個bean定義對應一個實例。該做用域僅在基於web的Spring ApplicationContext情形下有效。

    global-session:在一個全局的HTTP Session中,一個bean定義對應一個實例。該做用域僅在基於web的Spring ApplicationContext情形下有效。

6. 什麼是Spring的MVC框架?

    Spring 配備構建Web 應用的全功能MVC框架。Spring能夠很便捷地和其餘MVC框架集成,如Struts,Spring 的MVC框架用控制反轉把業務對象和控制邏輯清晰地隔離。它也容許以聲明的方式把請求參數和業務對象綁定。

    spring mvc是一個基於mvc的web框架。spring mvc是spring框架的一個模塊,springmvc和spring無需經過中間整合層進行整合。

7. 如何啓用註解:

    <context:annotation-config/>

    若是使用<context:component-scan base-package="com.tgb.web.controller.annotation"> </context:component-scan>  則上面內容能夠省略 

8. Spring MVC的請求流程:

    第一步:發起請求到前端控制器(DispatcherServlet)

    第二步:前端控制器請求HandlerMapping查找Handler能夠根據xml配置、註解進行查找

    第三步:處理器映射器HandlerMapping向前端控制器返回Handler

    第四步:前端控制器調用處理器適配器去執行Handler

    第五步:處理器適配器去執行Handler

    第六步:Handler執行完成給適配器返回ModelAndView

    第七步:處理器適配器向前端控制器返回ModelAndView。ModelAndView是springmvc框架的一個底層對象,包括 Model和view

    第八步:前端控制器請求視圖解析器去進行視圖解析,根據邏輯視圖名解析成真正的視圖(jsp)

    第九步:視圖解析器向前端控制器返回View

    第十步:前端控制器進行視圖渲染。視圖渲染將模型數據(在ModelAndView對象中)填充到request域

    第十一步:前端控制器向用戶響應結果

9. web.xml的配置

    

10. 註解的處理器映射器和適配器

      spring3.1以後使用org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping註解映射器。

      在spring3.1以後使用org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter註解適配器。

      使用 mvc:annotation-driven代替上邊註解映射器和註解適配器配置

11. spring 與 mybatis整合過程

      第一步:整合dao層

         mybatis和spring整合,經過spring管理mapper接口。

         使用mapper的掃描器自動掃描mapper接口在spring中進行註冊。

      第二步:整合service層

         經過spring管理 service接口。

         使用配置方式將service接口配置在spring配置文件中。

         實現事務控制。

      第三步:整合springmvc

         因爲springmvc是spring的模塊,不須要整合。

      主要配置有:

      1). mybatis配置文件sqlMapConfig.xml配置別名自動掃描(實體類)

      2). mapper掃描器(接口,數據庫訪問接口)

      3). 數據庫鏈接池配置

      4). 聲明式事務配置

      5). 啓用註解掃描:<context:component-scan base-package="cn.itcast.ssm.controller"></context:component-scan>

      6). 配置註解映射器和適配器: <mvc:annotation-driven></mvc:annotation-driven>

      7). 視圖解析器:<bean  class="org.springframework.web.servlet.view.InternalResourceViewResolver">

      8). 配置控制類: DispatcherServlet前端控制器

      9). 配置spring配置文件加載類:ClassLoadListener

12. 前端控制器從上邊的文件中加載處理映射器、適配器、視圖解析器等組件,若是不在springmvc.xml中配置,使用默認加載的 DispatcherSerlvet.properties。 

13. 視圖解析器配置前綴和後綴:  

      

14. sqlMapConfig.xml,mybatis本身的配置文件。

      

15. 配置數據源:

     

16. 事務控制(applicationContext-transaction.xml),在applicationContext-transaction.xml中使用spring聲明式事務控制方法。

      

17. 加載spring配置

      

18. 靜態資源訪問不被攔截:

      <resources mapping="/resources/**" location="/resources/" />

      <resources mapping="/images/**" location="/images/" />

      <resources mapping="/js/**" location="/js/" />

19. @RequestMapping的做用

      1). url映射

      2). 窄化請求映射

      3). 限制http請求方法

20. controller方法的返回值

      20.1 返回ModelAndView 

              須要方法結束時,定義ModelAndView,將model和view分別進行設置。 

     20.2 返回string

               若是controller方法返回string,

               1). 表示返回邏輯視圖名。真正視圖(jsp路徑)=前綴+邏輯視圖名+後綴

               2). redirect重定向:返回字符串格式爲:"redirect:queryItem.action"

               3). forward頁面轉發:返回字符串格式爲:「forward:queryItem.action」

      20.3 返回void

               在controller方法形參上能夠定義request和response,使用request或response指定響應結果:

               1). 使用request轉向頁面,以下:request.getRequestDispatcher("頁面路徑").forward(request, response);

               2). 也能夠經過response頁面重定向:response.sendRedirect("url")

               3). 也能夠經過response指定響應結果,例如響應json數據以下:

                    response.setCharacterEncoding("utf-8");

                    response.setContentType("application/json;charset=utf-8");

                    response.getWriter().write("json串");

21. 參數綁定:

      21.1 默認支持的類型

               直接在controller方法形參上定義下邊類型的對象,就可使用這些對象。在參數綁定過程當中,若是遇到下邊類型直接進行綁定。

               1). HttpServletRequest:經過request對象獲取請求信息

               2). HttpServletResponse:經過response處理響應信息

               3). HttpSession:經過session對象獲得session中存放的對象

               4). Model/ModelMap:model是一個接口,modelMap是一個接口實現 。做用:將model數據填充到request域。

      21.2 簡單類型

              經過@RequestParam對簡單類型的參數進行綁定。

              若是不使用@RequestParam,要求request傳入參數名稱和controller方法的形參名稱一致,方可綁定成功。

              若是使用@RequestParam,不用限制request傳入參數名稱和controller方法的形參名稱一致。

              經過required屬性指定參數是否必需要傳入,若是設置爲true,沒有傳入參數,會報錯。

      21.3 pojo綁定

              頁面中input的name和controller的pojo形參中的屬性名稱一致,將頁面中數據綁定到pojo。(usename,age;不須要user.username,user.age)

      21.4 自定義參數綁定實現日期類型綁定

              對於controller形參中pojo對象,若是屬性中有日期類型,須要自定義參數綁定。將請求日期數據串轉成 日期類型,要轉換的日期類型和pojo中日期屬性的類型保持一致。

22. Spring MVC 和 Struts2 對比

      1). Struts2是類級別的攔截, 一個類對應一個request上下文,SpringMVC是方法級別的攔截,一個方法對應一個request上下文,而方法同時又跟一個url對應,因此說從架構自己上SpringMVC 就容易實現restful url

      2). 由上邊緣由,SpringMVC的方法之間基本上獨立的,獨享request response數據,請求數據經過參數獲取,處理結果經過ModelMap交回給框架,方法之間不共享變量,而Struts2搞的就比較亂,雖然方法

           之間也是獨立的,但其全部Action變量是共享的,這不會影響程序運行,卻給咱們編碼 讀程序時帶來麻煩,每次來了請求就建立一個Action,一個Action對象對應一個request上下文。

      3). 因爲Struts2須要針對每一個request進行封裝,把request,session等servlet生命週期的變量封裝成一個一個Map,供給每一個Action使用,並保證線程安全,因此在原則上,是比較耗費內存的。

      4). SpringMVC集成了Ajax,使用很是方便,只需一個註解@ResponseBody就能夠實現,而後直接返回響應文本便可,而Struts2攔截器集成了Ajax,在Action中處理時通常必須安裝插件或者本身

           寫代碼集成進去,使用起來也相對不方便。

      5). springmvc面向方法開發的(更接近service接口的開發方式),struts2面向類開發。

      6). springmvc能夠單例開發,struts2只能是多例開發。

23. 亂碼處理

      1). post亂碼

           在web.xml添加post亂碼filter:CharacterEncodingFilter

      2). 對於get請求中文參數出現亂碼解決方法有兩個:

           a. 修改tomcat配置文件添加編碼與工程編碼一致,以下:

               <Connector URIEncoding="utf-8" connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>

           b. 對參數進行從新編碼:

               String userName = new  String(request.getParamter("userName").getBytes("ISO8859-1"),"utf-8")

               ISO8859-1是tomcat默認編碼,須要將tomcat編碼後的內容按utf-8編碼

24. 集合類型綁定

      1). 數組綁定:

           controller方法參數使用:(Integer[] itemId)

           頁面統一使用:itemId 做爲name

      2). list綁定:

           pojo屬性名爲:itemsList

           頁面:itemsList[index].屬性名

      3). map 綁定:

           pojo屬性名爲:Map<String, Object> itemInfo = new HashMap<String, Object>(); 

           頁面: <td>姓名:<inputtype="text"name="itemInfo['name']"/>

25. spring 校驗           

      1). 項目中,一般使用較可能是前端的校驗,好比頁面中js校驗。對於安全要求較高點建議在服務端進行校驗。

      2). springmvc使用hibernate的校驗框架validation(和hibernate沒有任何關係)。

           校驗思路:頁面提交請求的參數,請求到controller方法中,使用validation進行校驗。若是校驗出錯,將錯誤信息展現到頁面。

26. 數據回顯 

      1). @ModelAttribute還能夠將方法的返回值傳到頁面:在方法上加註解@ModelAttribute

      2). 使用最簡單方法使用model,能夠不用@ModelAttribute:model.addAttribute("id", id);

      3). springmvc默認對pojo數據進行回顯。pojo數據傳入controller方法後,springmvc自動將pojo數據放到request域,key等於pojo類型(首字母小寫)

      4). public String testParam(PrintWriter out, @RequestParam("username") String username) { //out直接輸出

27. 異常處理

      springmvc提供全局異常處理器(一個系統只有一個異常處理器)進行統一異常處理。

      系統遇到異常,在程序中手動拋出,dao拋給service、service給controller、controller拋給前端控制器,前端控制器調用全局異常處理器。

      

28. 上傳圖片

      1). 在頁面form中提交enctype="multipart/form-data"的數據時,須要springmvc對multipart類型的數據進行解析。

      2). 在springmvc.xml中配置multipart類型解析器。

             

        3). 方法中使用:MultipartFile attach (單個文件上傳) 或者  MultipartFile[] attachs (多個文件上傳)

29. Json處理

       1). 加載json轉換的jar包:springmvc中使用jackson的包進行json轉換(@requestBody和@responseBody使用下邊的包進行json轉)

       2). 配置json轉換器。在註解適配器RequestMappingHandlerAdapter中加入messageConverters。若是使用<mvc:annotation-driven /> 則會自動加入。

       3). ajax

         

       4). Controller (ResponseBody、RequestBody)

        

       5). 注意ajax中contentType若是不設置爲json類型,則傳的參數爲key/value類型。上面設置後,傳的是json類型。

             詳見:http://www.cnblogs.com/Jtianlin/p/5224885.html

30. 攔截器:

      1). 定義攔截器,實現HandlerInterceptor接口。接口中提供三個方法。

            a. preHandle :進入 Handler方法以前執行,用於身份認證、身份受權,好比身份認證,若是認證經過表示當前用戶沒有登錄,須要此方法攔截再也不向下執行

            b. postHandle:進入Handler方法以後,返回modelAndView以前執行,應用場景從modelAndView出發:將公用的模型數據(好比菜單導航)在這裏傳到視圖,也能夠在這裏統一指定視圖

            c. afterCompletion:執行Handler完成執行此方法,應用場景:統一異常處理,統一日誌處理

      2). 攔截器配置:

           a. 針對HandlerMapping配置(不推薦):springmvc攔截器針對HandlerMapping進行攔截設置,若是在某個HandlerMapping中配置攔截,通過該 HandlerMapping映射成功的handler

               最終使用該 攔截器。  (通常不推薦使用)

           b. 相似全局的攔截器:springmvc配置相似全局的攔截器,springmvc框架將配置的相似全局的攔截器注入到每一個HandlerMapping中

            

31. 如何啓用註解:

      <context:annotation-config/>

      若是使用<context:component-scan base-package="com.tgb.web.controller.annotation"> </context:component-scan>  則上面內容能夠省略 

      使用 mvc:annotation-driven代替註解映射器和註解適配器配置

相關文章
相關標籤/搜索