1.為什么使用Spring ?
1). 方便解耦黔姜,簡化開發(fā)
通過Spring提供的IoC容器墩蔓,可以將對象之間的依賴關(guān)系交由Spring進行控制攘烛,避免硬編碼所造成的過度程序耦合舶赔。
2). AOP編程的支持
通過Spring提供的AOP功能湃交,方便進行面向切面的編程熟空,如性能監(jiān)測、事務管理搞莺、日志記錄等息罗。
3). 聲明式事務的支持
4). 方便集成各種優(yōu)秀框架
5). 降低Java EE API的使用難度
如對JDBC,JavaMail才沧,遠程調(diào)用等提供了簡便封裝迈喉。
2.Spring的優(yōu)點?
1.降低了組件之間的耦合性 温圆,實現(xiàn)了軟件各層之間的解耦
2.可以使用容易提供的眾多服務弊添,如事務管理,消息服務等
3.容器提供單例模式支持
4.容器提供了AOP技術(shù)捌木,利用它很容易實現(xiàn)如權(quán)限攔截油坝,運行期監(jiān)控等功能
5.容器提供了眾多的輔助類,能加快應用的開發(fā)
6.spring對于主流的應用框架提供了集成支持刨裆,如hibernate澈圈,JPA,Struts等
7.spring屬于低侵入式設計帆啃,代碼的污染極低
8.獨立于各種應用服務器
9.spring的DI機制降低了業(yè)務對象替換的復雜性
10.Spring的高度開放性瞬女,并不強制應用完全依賴于Spring,開發(fā)者可以自由選擇spring的部分或全部
3.什么是IOC努潘,什么是DI诽偷,他們有什么區(qū)別坤学?
依賴注入DI是一個程序設計模式和架構(gòu)模型, 一些時候也稱作控制反轉(zhuǎn)报慕,盡管在技術(shù)上來講深浮,依賴注入是一個IOC的特殊實現(xiàn),依賴注入是指一個對象應用另外一個對象來提供一個特殊的能力眠冈,例如:把一個 數(shù)據(jù)庫連接已參數(shù)的形式傳到一個對象的結(jié)構(gòu)方法里面而不是在那個對象內(nèi)部自行創(chuàng)建一個連接飞苇。控制反轉(zhuǎn)和依賴注入的基本思想就是把類的依賴從類內(nèi)部轉(zhuǎn)化到外部以減少依賴
應用控制反轉(zhuǎn)蜗顽,對象在被創(chuàng)建的時候布卡,由一個調(diào)控系統(tǒng)內(nèi)所有對象的外界實體,將其所依賴的對象的引用雇盖,傳遞給它忿等。也可以說,依賴被注入到對象中崔挖。所以贸街,控制反轉(zhuǎn)是,關(guān)于一個對象如何獲取他所依賴的對象的引用虚汛,這個責任的反轉(zhuǎn)匾浪。
4. 什么是IoC,為什么使用IoC ?
IoC全稱Iversion of Controller卷哩,控制反轉(zhuǎn)蛋辈。
當某個角色需要另外一個角色協(xié)助的時候,在傳統(tǒng)的程序設計過程中将谊,通常由調(diào)用者來創(chuàng)建被調(diào)用者的實例對象冷溶。但在spring中創(chuàng)建被調(diào)用者的工作不再由調(diào)用者來完成,因此稱為控制反轉(zhuǎn)尊浓。創(chuàng)建被調(diào)用者的工作由spring來完成逞频,然后注入調(diào)用者 直接使用。
它能指導我們?nèi)绾卧O計出松耦合栋齿、更優(yōu)良的程序苗胀。
5.什么是AOP,為什么使用AOP ?
AOP全稱:Aspect-Oriented Programming瓦堵,面向切面編程基协。
AOP,面向切面編程菇用,就是把可重用的功能提取出來澜驮,然后將這些通用功能在合適的時候織入到應用程序中,比如事務管理惋鸥、權(quán)限控制杂穷、日志記錄悍缠、性能統(tǒng)計等。
AOP并沒有幫助我們解決任何新的問題耐量,它只是提供了一種更好的辦法飞蚓,能夠用更少的工作量來解決現(xiàn)有的一些問題,使得系統(tǒng)更加健壯拴鸵,可維護性更好玷坠。
6.Spring中AOP的應用場景蜗搔、Aop原理劲藐、好處?
AOP--Aspect Oriented Programming面向切面編程樟凄;用來封裝橫切關(guān)注點聘芜,具體可以在下面的場景中使用:
Authentication 權(quán)限、Caching 緩存缝龄、Context passing 內(nèi)容傳遞汰现、Error handling 錯誤處理Lazy loading懶加載、Debugging調(diào)試叔壤、logging, tracing, profiling and monitoring 記錄跟蹤優(yōu)化 校準瞎饲、Performance optimization 性能優(yōu)化、Persistence 持久化炼绘、Resource pooling 資源池嗅战、Synchronization 同步、Transactions 事務俺亮。
原理:AOP是面向切面編程驮捍,是通過動態(tài)代理
的方式為程序添加統(tǒng)一功能,集中解決一些公共問題脚曾。
優(yōu)點:
1.各個步驟之間的良好隔離性耦合性大大降低
2.源代碼無關(guān)性东且,再擴展功能的同時不對源碼進行修改操作
7.什么是Spring的事務管理?
事務就是對一系列的數(shù)據(jù)庫操作(比如插入多條數(shù)據(jù))進行統(tǒng)一的提交或回滾操作本讥,如果插入成功珊泳,那么一起成功,如果中間有一條出現(xiàn)異常拷沸,那么回滾之前的所有操作色查。這樣可以防止出現(xiàn)臟數(shù)據(jù),防止數(shù)據(jù)庫數(shù)據(jù)出現(xiàn)問題堵漱。
開發(fā)中為了避免這種情況一般都會進行事務管理综慎。
Spring的聲明式事務通常是指在配置文件中對事務進行配置聲明,其中包括了很多聲明屬性勤庐,它是通過Spring Proxy幫你做代理示惊,自己不用額外的寫代碼好港,只要在Spring配置文件中聲明即可;通常用在數(shù)據(jù)庫的操作里面米罚;
編程式事務就是指通過硬編碼的方式做事務處理钧汹,這種處理方式需要寫代碼,事務中的邏輯可以自己定制录择;可以是數(shù)據(jù)庫的東東拔莱,也可以是其他的操作。
Spring中也有自己的事務管理機制隘竭,一般是使用TransactionMananger進行管理塘秦,可以通過Spring的注入來完成此功能。
8.Spring框架支持以下五種bean的作用域?
- singleton : 默認值动看,bean在每個Spring ioc 容器中只有一個實例尊剔。
- prototype:一個bean的定義可以有多個實例。
- request:每次http請求都會創(chuàng)建一個bean菱皆,該作用域僅在基于web的Spring ApplicationContext情形下有效须误。
- session:在一個HTTP Session中,一個bean定義對應一個實例仇轻。該作用域僅在基于web的Spring ApplicationContext情形下有效京痢。
- global-session:在一個全局的HTTP Session中,一個bean定義對應一個實例篷店。該作用域僅在基于web的Spring ApplicationContext情形下有效祭椰。
9.什么是Spring的MVC框架?
Spring 配備構(gòu)建Web 應用的全功能MVC框架船庇。Spring可以很便捷地和其他MVC框架集成吭产,如Struts,Spring 的MVC框架用控制反轉(zhuǎn)把業(yè)務對象和控制邏輯清晰地隔離鸭轮。它也允許以聲明的方式把請求參數(shù)和業(yè)務對象綁定臣淤。
spring mvc是一個基于mvc的web框架。spring mvc是spring框架的一個模塊窃爷,springmvc和spring無需通過中間整合層進行整合邑蒋。
10.Spring MVC的請求流程?
- 第一步:發(fā)起請求到前端控制器(DispatcherServlet)
- 第二步:前端控制器請求HandlerMapping查找Handler可以根據(jù)xml配置、注解進行查找
- 第三步:處理器映射器HandlerMapping向前端控制器返回Handler
- 第四步:前端控制器調(diào)用處理器適配器去執(zhí)行Handler
- 第五步:處理器適配器去執(zhí)行Handler
- 第六步:Handler執(zhí)行完成給適配器返回ModelAndView
- 第七步:處理器適配器向前端控制器返回ModelAndView按厘。ModelAndView是springmvc框架的一個底層對象医吊,包括 Model和view
- 第八步:前端控制器請求視圖解析器去進行視圖解析,根據(jù)邏輯視圖名解析成真正的視圖(jsp)
- 第九步:視圖解析器向前端控制器返回View
- 第十步:前端控制器進行視圖渲染逮京。視圖渲染將模型數(shù)據(jù)(在ModelAndView對象中)填充到request域
- 第十一步:前端控制器向用戶響應結(jié)果
11.Springmvc的優(yōu)點卿堂?
1.它是基于組件技術(shù)的.全部的應用對象,無論控制器和視圖,還是業(yè)務對象之類的都是 java組件.并且和Spring提供的其他基礎(chǔ)結(jié)構(gòu)緊密集成.
2.不依賴于Servlet API(目標雖是如此,但是在實現(xiàn)的時候確實是依賴于Servlet的)
- 可以任意使用各種視圖技術(shù),而不僅僅局限于JSP
4 . 支持各種請求資源的映射策略
5 .它應是易于擴展的
12.Spring MVC 和 Struts2 對比?
1). Struts2是類級別的攔截, 一個類對應一個request上下文,SpringMVC是方法級別的攔截草描,一個方法對應一個request上下文蓬推,而方法同時又跟一個url對應距贷,所以說從架構(gòu)本身上SpringMVC 就容易實現(xiàn)restful url
2). 由上邊原因庇麦,SpringMVC的方法之間基本上獨立的冈爹,獨享request response數(shù)據(jù),請求數(shù)據(jù)通過參數(shù)獲取逛绵,處理結(jié)果通過ModelMap交回給框架怀各,方法之間不共享變量,而Struts2搞的就比較亂术浪,雖然方法之間也是獨立的瓢对,但其所有Action變量是共享的,這不會影響程序運行添吗,卻給我們編碼 讀程序時帶來麻煩沥曹,每次來了請求就創(chuàng)建一個Action份名,一個Action對象對應一個request上下文碟联。
3). 由于Struts2需要針對每個request進行封裝,把request僵腺,session等servlet生命周期的變量封裝成一個一個Map鲤孵,供給每個Action使用,并保證線程安全辰如,所以在原則上普监,是比較耗費內(nèi)存的。
4). SpringMVC集成了Ajax琉兜,使用非常方便凯正,只需一個注解@ResponseBody就可以實現(xiàn),然后直接返回響應文本即可豌蟋,而Struts2攔截器集成了Ajax廊散,在Action中處理時一般必須安裝插件或者自己寫代碼集成進去,使用起來也相對不方便梧疲。
5). springmvc面向方法開發(fā)的(更接近service接口的開發(fā)方式)允睹,struts2面向類開發(fā)。
6). springmvc可以單例開發(fā)幌氮,struts2只能是多例開發(fā)缭受。
13.如何啟用注解?
<context:annotation-config/>
如果使用
<context:component-scan base-package="com.tgb.web.controller.annotation"> </context:component-scan>
則上面內(nèi)容可以省略
14.web.xml的配置
<!--springmvc前端控制器 -->
<servlet>
<servlet-name>spring</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--
contextConfigLocation配置的springmvc加載的配置文件(配置處理器映射器/適配器等)
如果不配置contextConfigLocation,默認加載的是/WEB-INF/servlet名稱-servlet.xml(springmvc-servlet.xml)
-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<!--
第一種:*.do该互,訪問以.do結(jié)尾由DispatcherServlet進行解析
第二種:/米者,所有訪問的地址都由DispatcherServlet進行解析,對于靜態(tài)文件的解析需要配置不讓DispatcherServlet進行解析此種方式可以實現(xiàn)RESTful風格的url
第三種:/*宇智,這樣配置不對蔓搞,使用這種配置陆盘,最終要轉(zhuǎn)發(fā)到一個jsp頁面時,仍然會由DispatcherServlet解析jsp地址败明,不能根據(jù)jsp頁面找到handler隘马,會報錯
-->
<url-pattern>*.do</url-pattern>
</servlet-mapping>
15.注解的處理器映射器和適配器?
spring3.1之后使用org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping
注解映射器。
spring3.1之后使用org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter
注解適配器妻顶。
使用 mvc:annotation-driven
代替上邊注解映射器和注解適配器配置
16.spring 與 mybatis整合過程?
第一步:整合dao層
mybatis和spring整合酸员,通過spring管理mapper接口。
使用mapper的掃描器自動掃描mapper接口在spring中進行注冊讳嘱。
第二步:整合service層
通過spring管理 service接口幔嗦。
使用配置方式將service接口配置在spring配置文件中。
實現(xiàn)事務控制沥潭。
第三步:整合springmvc
由于springmvc是spring的模塊邀泉,不需要整合
主要配置有:
1). mybatis配置文件sqlMapConfig.xml配置別名自動掃描(實體類)
2). mapper掃描器(接口,數(shù)據(jù)庫訪問接口)
3). 數(shù)據(jù)庫連接池配置
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
17.視圖解析器配置前綴和后綴?
<!-- 視圖解析器解析jsp時钝鸽,默認使用jstl標簽汇恤,classpath下的得有jstl的包-->
<bean>
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!--配置jsp路徑的前綴-->
<property name="prefix" value="/WEB-INF/jsp/"/>
<!--配置jsp路徑的后綴-->
<property name="suffix" value=".jsp"/>
</bean>
18.sqlMapConfig.xml,mybatis自己的配置文件?
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!--全局setting配置拔恰,根據(jù)需要添加-->
<!--配置別名-->
<typeAliases>
<!--批量掃描包名-->
<package name="com.mz.ssm.po" />
</typeAliases>
<!--配置mapper
由于使用spring和mybatis的整合進行mapper掃描因谎,這里不需要配置了
必須遵循mapper.xml和mapper.java文件同名且在一個目錄
-->
<!-- <mappers>
</mappers> -->
</configuration>
19.配置數(shù)據(jù)源?
<!-- 加載db.properties文件中的內(nèi)容,db.properties文件中key命名有一定的特殊規(guī)則 -->
<context:property-placeholder location="classpath:db.properties" />
<!-- 配置數(shù)據(jù)源颜懊,dbcp -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close">
<property name="driverClassName" value="${jdbc.driver}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
<property name="maxActive" value="30" />
<property name="maxIdle" value="5" />
</bean>
<!-- sqlSessionFactory -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 數(shù)據(jù)庫連接池 -->
<property name="dataSource" ref="dataSource" />
<!-- 加載mybatis的全局配置文件 -->
<property name="configLocation value="classpath:mybatis/sqlMapConfig.xml />
</bean>
<!-- mapper掃描器 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- 掃描包路徑财岔,如果需要掃描多個包,中間使用半角逗號隔開 -->
<property name="basePackage" value="cn.mz.ssm.mapper"></property>
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
</bean>
20.事務控制(applicationContext-transaction.xml)?
在applicationContext-transaction.xml
中使用spring聲明式事務控制方法河爹。
<!-- 事務管理器
對mybatis操作數(shù)據(jù)庫事物控制匠璧,spring使用jdbc的事物控制類
-->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<!-- 數(shù)據(jù)源
dataSource在applicationContext-dao.xml中配置了
-->
<property name="dataSource" ref="dataSource"/>
</bean>
<!-- 通知 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<!-- 傳播行為 -->
<tx:method name="save*" propagation="REQUIRED" />
<tx:method name="delete*" propagation="REQUIRED" />
<tx:method name="insert*" propagation="REQUIRED" />
<tx:method name="update*" propagation="REQUIRED" />
<tx:method name="find*" propagation="SUPPORTS" read-only="true" />
<tx:method name="get*" propagation="SUPPORTS" read-only="true" />
<tx:method name="select*" propagation="SUPPORTS" read-only="true" />
</tx:attributes>
</tx:advice>
<!-- aop -->
<aop:config>
<aop:advisor advice-ref="txAdvice" pointcut="execution(* cn.mz.ssm.serviceImpl..(..))" />
</aop:config>
21.加載spring配置?
<!-- 加載spring容器 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/classes/spring/applicationContext-*.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.contextConfigLocation </listener-class>
<、listener>
22.靜態(tài)資源訪問不被攔截?
<resources mapping="/resources/**" location="/resources/" />
<resources mapping="/images/**" location="/images/" />
<resources mapping="/js/**" location="/js/" />
23.@RequestMapping的作用?
1). url映射
2). 窄化請求映射
3). 限制http請求方法
24.controller方法的返回值?
1 返回ModelAndView
需要方法結(jié)束時咸这,定義ModelAndView夷恍,將model和view分別進行設置。
2 返回string
如果controller方法返回string炊苫,
1). 表示返回邏輯視圖名裁厅。真正視圖(jsp路徑)=前綴+邏輯視圖名+后綴
2). redirect重定向:返回字符串格式為:"redirect:queryItem.action"
3). forward頁面轉(zhuǎn)發(fā):返回字符串格式為:“forward:queryItem.action”
3 返回void
在controller方法形參上可以定義request和response,使用request或 response指定響應結(jié)果:
1). 使用request轉(zhuǎn)向頁面侨艾,如下:request.getRequestDispatcher("頁面路徑").forward(request, response);
2). 也可以通過response頁面重定向:response.sendRedirect("url")
3). 也可以通過response指定響應結(jié)果执虹,例如響應json數(shù)據(jù)如下:
response.setCharacterEncoding("utf-8");
response.setContentType("application/json;charset=utf-8");
response.getWriter().write("json串");
25.參數(shù)綁定
1 默認支持的類型
直接在controller方法形參上定義下邊類型的對象,就可以使用這些對象唠梨。在參數(shù)綁定過程中袋励,如果遇到下邊類型直接進行綁定。
1). HttpServletRequest:通過request對象獲取請求信息
2). HttpServletResponse:通過response處理響應信息
3). HttpSession:通過session對象得到session中存放的對象
4). Model/ModelMap:model是一個接口,modelMap是一個接口實現(xiàn) 茬故。作用:將model數(shù)據(jù)填充到request域盖灸。
2 簡單類型
通過@RequestParam對簡單類型的參數(shù)進行綁定。
如果不使用@RequestParam磺芭,要求request傳入?yún)?shù)名稱和controller方法的形參名稱一致赁炎,方可綁定成功。
如果使用@RequestParam钾腺,不用限制request傳入?yún)?shù)名稱和controller方法的形參名稱一致徙垫。
通過required屬性指定參數(shù)是否必須要傳入,如果設置為true放棒,沒有傳入?yún)?shù)姻报,會報錯。
3 pojo綁定
頁面中input的name和controller的pojo形參中的屬性名稱一致间螟,將頁面中數(shù)據(jù)綁定到pojo吴旋。(usename,age;不需要user.username,user.age)
4 自定義參數(shù)綁定實現(xiàn)日期類型綁定
對于controller形參中pojo對象厢破,如果屬性中有日期類型荣瑟,需要自定義參數(shù)綁定。將請求日期數(shù)據(jù)串轉(zhuǎn)成 日期類型溉奕,要轉(zhuǎn)換的日期類型和pojo中日期屬性的類型保持一致褂傀。
26. 亂碼處理?
1). post亂碼
在web.xml添加post亂碼filter:CharacterEncodingFilter
2). 對于get請求中文參數(shù)出現(xiàn)亂碼解決方法有兩個:
a. 修改tomcat配置文件添加編碼與工程編碼一致,如下:
<Connector URIEncoding="utf-8" connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>
b. 對參數(shù)進行重新編碼:
String userName = new String(request.getParamter("userName").getBytes("ISO8859-1"),"utf-8")
ISO8859-1是tomcat默認編碼加勤,需要將tomcat編碼后的內(nèi)容按utf-8編碼
27. 集合類型綁定
1). 數(shù)組綁定:
controller方法參數(shù)使用:(Integer[] itemId)
頁面統(tǒng)一使用: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']"/>
28.spring 校驗 ?
1). 項目中,通常使用較多是前端的校驗同波,比如頁面中js校驗鳄梅。對于安全要求較高點建議在服務端進行校驗。
2). springmvc使用hibernate的校驗框架validation(和hibernate沒有任何關(guān)系)未檩。
校驗思路:頁面提交請求的參數(shù)戴尸,請求到controller方法中,使用validation進行校驗冤狡。如果校驗出錯孙蒙,將錯誤信息展示到頁面。
29.數(shù)據(jù)回顯?
1). @ModelAttribute還可以將方法的返回值傳到頁面:在方法上加注解@ModelAttribute
2). 使用最簡單方法使用model悲雳,可以不用@ModelAttribute:model.addAttribute("id", id);
3). springmvc默認對pojo數(shù)據(jù)進行回顯挎峦。pojo數(shù)據(jù)傳入controller方法后,springmvc自動將pojo數(shù)據(jù)放到request域合瓢,key等于pojo類型(首字母小寫)
4). public String testParam(PrintWriter out, @RequestParam("username") String username) { //out直接輸出
30.異常處理?
springmvc提供全局異常處理器(一個系統(tǒng)只有一個異常處理器)進行統(tǒng)一異常處理坦胶。
系統(tǒng)遇到異常,在程序中手動拋出,dao拋給service顿苇、service給controller峭咒、controller拋給前端控制器,前端控制器調(diào)用全局異常處理器纪岁。
<!-- 全局異常處理器
只要實現(xiàn)HandlerExceptionResolver接口就是全局異常處理器
-->
<bean class="cn.mz.ssm.exception.CustomExceptionResolver></bean>
31.上傳圖片?
1). 在頁面form中提交enctype="multipart/form-data"的數(shù)據(jù)時凑队,需要springmvc對multipart類型的數(shù)據(jù)進行解析。
2). 在springmvc.xml中配置multipart類型解析器幔翰。
<!-- 文件上傳 -->
<bean id="multipartResolver"
class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<!-- 設置上傳文件的最大尺寸為5MB -->
<property name="maxUploadSize">
<value>5242880</value>
</property>
3). 方法中使用:MultipartFile attach (單個文件上傳) 或者 MultipartFile[] attachs (多個文件上傳)
32.Json處理
1). 加載json轉(zhuǎn)換的jar包:springmvc中使用jackson的包進行json轉(zhuǎn)換(@requestBody和@responseBody使用下邊的包進行json轉(zhuǎn))
2). 配置json轉(zhuǎn)換器顽决。在注解適配器RequestMappingHandlerAdapter中加入messageConverters。如果使用<mvc:annotation-driven /> 則會自動加入导匣。
3). ajax
//請求json才菠,輸出json
function requestJson() {
$.ajax({
type:'post',
url:'${pageContext.request.contextPath}/requestJson.do',
contentType:'application/json;charset=utf-8',
//數(shù)據(jù)格式是json串,商品信息
data:'{"name":"手機","price":999}',
success:function(data){//返回json結(jié)果
alert(data);
}
});
}
4). Controller (ResponseBody贡定、RequestBody)
//請求json串(商品信息)赋访,輸出json(商品信息)
//@RequestBody將請求的商品信息的json串轉(zhuǎn)成itemsCustom對象
//@ResponseBody將itemsCustom轉(zhuǎn)成json輸出
@RequestMapping("/requestJson")
public @ResponseBody IntemsCustom requestJson(@RequestBody ItemCustom itemsCustom) {
//@ResponseBody將itemsCustom轉(zhuǎn)成json輸出
return itemsCustom;
}
5). 注意ajax中contentType如果不設置為json類型,則傳的參數(shù)為key/value類型缓待。上面設置后蚓耽,傳的是json類型。
33.攔截器?
1). 定義攔截器旋炒,實現(xiàn)HandlerInterceptor接口步悠。接口中提供三個方法。
a. preHandle :進入 Handler方法之前執(zhí)行瘫镇,用于身份認證鼎兽、身份授權(quán),比如身份認證铣除,如果認證通過表示當前用戶沒有登陸谚咬,需要此方法攔截不再向下執(zhí)行
b. postHandle:進入Handler方法之后,返回modelAndView之前執(zhí)行尚粘,應用場景從modelAndView出發(fā):將公用的模型數(shù)據(jù)(比如菜單導航)在這里傳到視圖择卦,也可以在這里統(tǒng)一指定視圖
c. afterCompletion:執(zhí)行Handler完成執(zhí)行此方法,應用場景:統(tǒng)一異常處理郎嫁,統(tǒng)一日志處理
2). 攔截器配置:
a. 針對HandlerMapping配置(不推薦):springmvc攔截器針對HandlerMapping進行攔截設置秉继,如果在某個HandlerMapping中配置攔截,經(jīng)過該 HandlerMapping映射成功的handler最終使用該 攔截器泽铛。 (一般不推薦使用)
b. 類似全局的攔截器:springmvc配置類似全局的攔截器尚辑,springmvc框架將配置的類似全局的攔截器注入到每個HandlerMapping中
<!-- 攔截器 -->
<mvc:intercepters>
<!-- 多個攔截器,順序執(zhí)行 -->
<mvc:intercepter>
<!-- /**表示所有url包括子url路徑 -->
<mvc:mapping path="/**"/>
<bean class="cn.mz.ssm.intercepter.HandlerIntercepter1"></bean>
</mvc:intercepter>
<mvc:intercepter>
<mvc:mapping path="/**"/>
<bean class="cn.mz.ssm.intercepter.HandlerIntercepter2"></bean>
</mvc:intercepter>
</mvc:intercepters>
34.spring中自動裝配的方式有哪些厚宰?
1腌巾、No:即不啟用自動裝配遂填。
2、byName:通過屬性的名字的方式查找JavaBean依賴的對象并為其注入澈蝙。比如說類Computer有個屬性printer吓坚,指定其autowire屬性為byName后,Spring IoC容器會在配置文件中查找id/name屬性為printer的bean灯荧,然后使用Seter方法為其注入礁击。
3、byType:通過屬性的類型查找JavaBean依賴的對象并為其注入逗载。比如類Computer有個屬性printer哆窿,類型為Printer,那么厉斟,指定其autowire屬性為byType后挚躯,Spring IoC容器會查找Class屬性為Printer的bean,使用Seter方法為其注入擦秽。
4码荔、constructor:通byType一樣,也是通過類型查找依賴對象感挥。與byType的區(qū)別在于它不是使用Seter方法注入缩搅,而是使用構(gòu)造子注入。
5触幼、autodetect:在byType和constructor之間自動的選擇注入方式硼瓣。
6、default:由上級標簽<beans>的default-autowire屬性確定置谦。
35.Spring常見創(chuàng)建對象的注解堂鲤?
@Component@Controller@ Service@ Repository
36.Spring中用到的設計模式?
簡單工廠霉祸、工廠方法筑累、單例模式、適配器丝蹭、包裝器、代理坪蚁、觀察者奔穿、策略、模板方法
37.Spring管理事務有幾種方式敏晤?
有兩種方式:
1贱田、編程式事務,在代碼中硬編碼嘴脾。(不推薦使用)
2男摧、聲明式事務蔬墩,在配置文件中配置(推薦使用)
聲明式事務又分為兩種:
a、基于XML的聲明式事務
b耗拓、基于注解的聲明式事務
38.spring中的核心類有那些拇颅,各有什么作用?
BeanFactory:產(chǎn)生一個新的實例乔询,可以實現(xiàn)單例模式
BeanWrapper:提供統(tǒng)一的get及set方法
ApplicationContext:提供框架的實現(xiàn)樟插,包括BeanFactory的所有功能
39.Bean的調(diào)用方式有哪些?
有三種方式可以得到Bean并進行調(diào)用:
1竿刁、使用BeanWrapper
HelloWorld hw=new HelloWorld();
BeanWrapper bw=new BeanWrapperImpl(hw);
bw.setPropertyvalue(”msg”,”HelloWorld”);
system.out.println(bw.getPropertyCalue(”msg”));
2黄锤、使用BeanFactory
InputStream is=new FileInputStream(”config.xml”);
XmlBeanFactory factory=new XmlBeanFactory(is);
HelloWorld hw=(HelloWorld) factory.getBean(”HelloWorld”);
system.out.println(hw.getMsg());
3、使用ApplicationConttext
ApplicationContext actx=new FleSystemXmlApplicationContext(”config.xml”);
HelloWorld hw=(HelloWorld) actx.getBean(”HelloWorld”);
System.out.println(hw.getMsg());
40.spring有兩種代理方式食拜?
-
若目標對象實現(xiàn)了若干接口鸵熟,spring使用JDK的
java.lang.reflect.Proxy
類代理。優(yōu)點:因為有接口负甸,所以使系統(tǒng)更加松耦合 缺點:為每一個目標類創(chuàng)建接口
-
若目標對象沒有實現(xiàn)任何接口流强,spring使用
CGLIB
庫生成目標對象的子類。優(yōu)點:因為代理類與目標類是繼承關(guān)系惑惶,所以不需要有接口的存在煮盼。 缺點:因為沒有使用接口,所以系統(tǒng)的耦合性沒有使用JDK的動態(tài)代理好带污。