SSM框架面試題及答案整理

一、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

6、Spring DI 的三種方式?

構造器注入:通過構造方法初始化

<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等,方法前面需要加上註解@ResponseBody

8、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。