一、Spring面試題
1、Spring 在ssm中起什麼作用?
Spring:輕量級框架作用:Bean工廠,用來管理Bean的生命週期和框架集成。兩大核心:①. IOC/DI(控制反轉/依賴注入) :把dao依賴注入到service層,service層反轉給action層,Spring頂層容器為BeanFactory。②. AOP:面向切面編程2、Spring的事務?
編程式事務管理:編程方式管理事務,極大靈活性,難維護。聲明式事務管理:可以將業務代碼和事務管理分離,用註解和xml配置來管理事務。3、IOC 在項目中的作用?
作用:Ioc解決對象之間的依賴問題,把所有Bean的依賴關係通過配置文件或註解關聯起來,降低了耦合度。4、Spring的配置文件中的內容?
開啟事務註解驅動事務管理器開啟註解功能,並配置掃描包配置數據庫配置SQL會話工廠,別名,映射文件不用編寫Dao層的實現類5、Spring下的註解?
註冊:@Controller @Service @Component注入:@Autowired @Resource請求地址:@RequestMapping返回具體數據類型而非跳轉:@ResponseBody
<constructor-arg>
setter方法注入:通過setter方法初始化
<property>
接口注入
7、Spring主要使用了什麼模式?
工廠模式:每個Bean的創建通過方法單例模式:默認的每個Bean的作用域都是單例代理模式:關於Aop的實現通過代理模式8、IOC,AOP的實現原理?
IOC:通過反射機制生成對象注入AOP:動態代理二、SpringMvc面試題
1、SpringMvc 的控制器是不是單例模式,如果是,有什麼問題,怎麼解決?
問題:單例模式,在多線程訪問時有線程安全問題解決方法:不要用同步,在控制器裡面不能寫字段2、SpringMvc 中控制器的註解?
@Controller:該註解表明該類扮演控制器的角色3、@RequestMapping 註解用在類上的作用?
作用:用來映射一個URL到一個類或者一個特定的處理方法上4、前臺多個參數,這些參數都是一個對象,快速得到對象?
方法:直接在方法中聲明這個對象,SpringMvc就自動把屬性賦值到這個對象裡面5、SpringMvc中函數的返回值?
String,ModelAndView,List,Set 等
一般String,Ajax請求,返回一個List集合
6、SpringMvc中的轉發和重定向?
轉發: return:“hello”重定向 :return:“redirect:hello.jsp”7、SpringMvc和Ajax之間的相互調用?
通過JackSon框架把java裡面對象直接轉換成js可識別的json對象,具體步驟如下:
加入JackSon.jar在配置文件中配置json的映射在接受Ajax方法裡面直接返回Object,list等,方法前面需要加上註解@ResponseBody8、SpringMvc的工作流程圖?
9、Struts2 和 SpringMvc的區別?
入口不同:Struts2:filter過濾器SpringMvc:一個Servlet即前端控制器開發方式不同:Struts2:基於類開發,傳遞參數通過類的屬性,只能設置為多例SpringMvc:基於方法開發(一個url對應一個方法),請求參數傳遞到方法形參,可以為單例也可以為多例(建議單例)請求方式不同:Struts2:值棧村塾請求和響應的數據,通過OGNL存取數據SpringMvc:通過參數解析器將request請求內容解析,給方法形參賦值,將數據和視圖封裝成ModelAndView對象,最後又將ModelAndView中的模型數據通過request域傳輸到頁面,jsp視圖解析器默認使用的是jstl。三、Mybatis面試題
1、Ibatis和Mybatis?
Ibatis:2010年,apache的Ibatis框架停止更新,並移交給了google團隊,同時更名為MyBatis。從2010年後Ibatis在沒更新過,徹底變成了一個孤兒框架。一個沒人維護的框架註定被mybatis拍在沙灘上。Mybatis:Ibatis的升級版本。2、什麼是Mybatis的接口綁定,有什麼好處?
Mybatis實現了DAO接口與xml映射文件的綁定,自動為我們生成接口的具體實現,使用起來變得更加省事和方便。
3、什麼情況用註解,什麼情況用xml綁定?
註解使用情況:Sql語句簡單時xml綁定使用情況:xml綁定 (@RequestMap用來綁定xml文件)4、Mybatis在核心處理類叫什麼?
SqlSession
5、查詢表名和返回實體Bean對象不一致,如何處理?
映射鍵值對即可
<result>
column:數據庫中表的列名property:實體Bean中的屬性名
6、Mybatis的好處?
把Sql語句從Java中獨立出來。封裝了底層的JDBC,API的調用,並且能夠將結果集自動轉換成JavaBean對象,簡化了Java數據庫編程的重複工作。自己編寫Sql語句,更加的靈活。入參無需用對象封裝(或者map封裝),使用@Param註解7、Mybatis配置一對多?
<collection>
property:屬性名column:共同列ofType:集合中元素的類型select:要連接的查詢
8、Mybatis配置一對一?
<association>
property:屬性名select:要連接的查詢column:共同列javaType:集合中元素的類型
9 、${} 和 #{}的區別?
${}:簡單字符串替換,把${}直接替換成變量的值,不做任何轉換,這種是取值以後再去編譯SQL語句。#{}:預編譯處理,sql中的#{}替換成?,補全預編譯語句,有效的防止Sql語句注入,這種取值是編譯好SQL語句再取值。總結:一般用#{}來進行列的代替10、獲取上一次自動生成的主鍵值?
select last _insert_id()
11、Mybatis如何分頁,分頁原理?
RowBounds對象分頁在Sql內直接書寫,帶有物理分頁12、Mybatis工作原理?
原理:
通過SqlSessionFactoryBuilder從mybatis-config.xml配置文件中構建出SqlSessionFactory。SqlSessionFactory開啟一個SqlSession,通過SqlSession實例獲得Mapper對象並且運行Mapper映射的Sql語句。完成數據庫的CRUD操作和事務提交,關閉SqlSession。