轉自:https://www.cnblogs.com/doudouxiaoye/p/5693399.html
1. 為什麼使用Spring ?
1). 友善解耦,簡化開發
通過Spring提供的IoC容器,可以将對象之間的依賴關系交由Spring進行控制,避免寫死所造成的過度程式耦合。
2). AOP程式設計的支援
通過Spring提供的AOP功能,友善進行面向切面的程式設計,如性能監測、事務管理、日志記錄等。
3). 聲明式事務的支援
4). 友善內建各種優秀架構
5). 降低Java EE API的使用難度
如對JDBC,JavaMail,遠端調用等提供了簡便封裝
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. 配置資料源:
如果想要具體指定想要掃描的包,可以寫成如下的形式:
<!-- 配置sqlSessionFactory -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 執行個體化sqlSessionFactory時需要使用上述配置好的資料源以及SQL映射檔案 -->
<property name="dataSource" ref="dataSource" />
<property name="configLocation" value="/WEB-INF/config/mybatis.xml"/>
<property name="mapperLocations" value="classpath:cn/haedu/cloudoffice/**/mapper/*Dao.xml" />
<!-- <property name="mapperLocations" value="classpath:mapper/modules/**/*Dao.xml" /> -->
</bean>
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串");
4)補充: response.getWriter().write()和@responseBody
- responseBody的使用
1、
@responseBody注解的作用是将controller的方法傳回的對象通過适當的轉換器轉換為指定的格式之後,寫入到response對象的body區,通常用來傳回JSON資料或者是XML
資料,需要注意的呢,在使用此注解之後不會再走試圖處理器,而是直接将資料寫入到輸入流中,他的效果等同于通過response對象輸出指定格式的資料。
2、
@RequestMapping("/login")
@ResponseBody
public User login(User user){
return user;
}
User字段:userName pwd
那麼在前台接收到的資料為:'{"userName":"xxx","pwd":"xxx"}'
效果等同于如下代碼:
@RequestMapping("/login")
public void login(User user, HttpServletResponse response){
response.getWriter.write(JSONObject.fromObject(user).toString());
}
轉:http://www.cnblogs.com/qiankun-site/p/5774325.html
- 差別: https://segmentfault.com/q/1010000003056355
前台ajax送出一個請求,spring mvc中用注解@ResponseBody與response.getWriter .write()有什麼差別呢?目前項目網頁版用@ResponseBody沒問題,但是webapp的時候用@Response的就報異常org.springframework.web.HttpMediaTypeNotAcceptableException: Could not find acceptable representation,而用response.getWriter .write()就沒問題。
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代替注解映射器和注解擴充卡配置