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并沒有幫助我們解決任何新的問題,它只是提供了一種更好的辦法,能夠用更少的作業量來解決現有的一些問題,使得系統更加健壯,可維護性更好,
4、什么是Spring的事務管理?
事務就是對一系列的資料庫操作(比如插入多條資料)進行統一的提交或回滾操作,如果插入成功,那么一起成功,如果中間有一條出現例外,那么回滾之前的所有操作,這樣可以防止出現臟資料,防止資料庫資料出現問題,開發中為了避免這種情況一般都會進行事務管理,
Spring的宣告式事務通常是指在組態檔中對事務進行配置宣告,其中包括了很多宣告屬性,它是通過Spring Proxy幫你做代理,自己不用額外的寫代碼,只要在Spring組態檔中宣告即可;通常用在資料庫的操作里面;
編程式事務就是指通過硬編碼的方式做事務處理,這種處理方式需要寫代碼,事務中的邏輯可以自己定制;可以是資料庫的東東,也可以是其他的操作,
Spring中也有自己的事務管理機制,一般是使用TransactionMananger進行管理,可以通過Spring的注入來完成此功能,
5、Spring框架支持以下五種bean的作用域:
(1)singleton : 默認值,bean在每個Spring ioc 容器中只有一個實體,
(2)prototype:一個bean的定義可以有多個實體,
(3)request:每次http請求都會創建一個bean,該作用域僅在基于web的Spring ApplicationContext情形下有效,
(4)session:在一個HTTP Session中,一個bean定義對應一個實體,該作用域僅在基于web的Spring ApplicationContext情形下有效,
(5)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-scanbase-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方法的回傳值
1.回傳ModelAndView
需要方法結束時,定義ModelAndView,將model和view分別進行設定,
2.回傳string
如果controller方法回傳string:
(1)表示回傳邏輯視圖名,真正視圖(jsp路徑)=前綴+邏輯視圖名+后綴
(2)redirect重定向:回傳字串格式為:“redirect:queryItem.action”
(3)forward頁面轉發:回傳字串格式為:“forward:queryItem.action”
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、引數系結:
1.默認支持的型別
直接在controller方法形參上定義下邊型別的物件,就可以使用這些物件,在引數系結程序中,如果遇到下邊型別直接進行系結,
(1) HttpServletRequest:通過request物件獲取請求資訊;
(2) HttpServletResponse:通過response處理回應資訊;
(3) HttpSession:通過session物件得到session中存放的物件;
(4)Model/ModelMap:model是一個介面,modelMap是一個介面實作 ,作用:將model資料填充到request域,
2.簡單型別
通過@RequestParam對簡單型別的引數進行系結,
如果不使用@RequestParam,要求request傳入引數名稱和controller方法的形參名稱一致,方可系結成功,
如果使用@RequestParam,不用限制request傳入引數名稱和controller方法的形參名稱一致,
通過required屬性指定引數是否必須要傳入,如果設定為true,沒有傳入引數,會報錯,
3.pojo系結
頁面中input的name和controller的pojo形參中的屬性名稱一致,將頁面中資料系結到pojo,(usename,age;不需要 user.username,user.age),
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請求中文引數出現亂碼解決方法有兩個:
-
修改tomcat組態檔添加編碼與工程編碼一致,如下:
<Connector URIEncoding="utf-8" connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/> -
對引數進行重新編碼:
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>();
頁面: 姓名:"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型別,
30、 攔截器:
(1)定義攔截器,實作HandlerInterceptor介面,介面中提供三個方法,
- preHandle :進入 Handler方法之前執行,用于身份認證、身份授權,比如身份認證,如果認證通過表示當前用戶沒有登陸,需要此方法攔截不再向下執行,
- postHandle:進入Handler方法之后,回傳modelAndView之前執行,應用場景從modelAndView出發:將公用的模型資料(比如選單導航)在這里傳到視圖,也可以在這里統一指定視圖,
- afterCompletion:執行Handler完成執行此方法,應用場景:統一例外處理,統一日志處理,
(2) 攔截器配置:
- 針對HandlerMapping配置(不推薦):springmvc攔截器針對HandlerMapping進行攔截設定,如果在某個HandlerMapping中配置攔截, 經過該 HandlerMapping映射成功的handler最終使用該攔截器, (一般不推薦使用)
- 類似全域的攔截器:springmvc配置類似全域的攔截器,springmvc框架將配置的類似全域的攔截器注入到每個HandlerMapping中

Java知識點遠遠不止這么一點,這還只是整理出來的一點點,因為篇幅問題,不太好放置出所有的內容,但是我這已整理好了海量的Java學習資料,也有今年最新的Java面試資料,有需要的可以點擊進入,暗號:cszq,也可以 關注+私信 我!


轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/116277.html
標籤:AI
