1、Spring面試題前端
Spring:輕量級框架java
做用:Bean工廠,用來管理Bean的生命週期和框架集成。nginx
兩大核心: 一、IOC/DI(控制反轉/依賴注入) :把dao依賴注入到service層,service層反轉給action層,Spring頂層容器爲BeanFactory。 二、AOP:面向切面編程程序員
編程式事務管理:編程方式管理事務,極大靈活性,難維護。面試
聲明式事務管理:能夠將業務代碼和事務管理分離,用註解和xml配置來管理事務。sql
做用:Ioc解決對象之間的依賴問題,把全部Bean的依賴關係經過配置文件或註解關聯起來,下降了耦合度。數據庫
開啓事務註解驅動apache
事務管理器編程
開啓註解功能,並配置掃描包json
配置數據庫
配置SQL會話工廠,別名,映射文件
不用編寫Dao層的實現類
註冊:@Controller @Service @Component
注入:@Autowired @Resource
請求地址:@RequestMapping
返回具體數據類型而非跳轉:@ResponseBody
構造器注入:經過構造方法初始化
<constructor-arg index="0" type="java.lang.String" value="寶馬"></constructor-arg>複製代碼
setter方法注入:經過setter方法初始化
<property name="id" value="1111"></property>`複製代碼
接口注入
工廠模式:每一個Bean的建立經過方法
單例模式:默認的每一個Bean的做用域都是單例
代理模式:關於Aop的實現經過代理模式
IOC:經過反射機制生成對象注入
AOP:動態代理
問題:單例模式,在多線程訪問時有線程安全問題
解決方法:不要用同步,在控制器裏面不能寫字段
@Controller:該註解代表該類扮演控制器的角色
做用:用來映射一個URL到一個類或者一個特定的處理方法上
方法:直接在方法中聲明這個對象,SpringMvc就自動把屬性賦值到這個對象裏面
String,ModelAndView,List,Set 等
通常String,Ajax請求,返回一個List集合
轉發: return:「hello」
重定向 :return:「redirect:hello.jsp」
經過JackSon框架把java裏面對象直接轉換成js可識別的json對象,具體步驟以下:
加入JackSon.jar
在配置文件中配置json的映射
在接受Ajax方法裏面直接返回Object,list等,方法前面須要加上註解@ResponseBody
Struts2:filter過濾器
SpringMvc:一個Servlet即前端控制器
Struts2:基於類開發,傳遞參數經過類的屬性,只能設置爲多例
SpringMvc:基於方法開發(一個url對應一個方法),請求參數傳遞到方法形參,能夠爲單例也能夠爲多例(建議單例)
Struts2:值棧村塾請求和響應的數據,經過OGNL存取數據
SpringMvc:經過參數解析器將request請求內容解析,給方法形參賦值,將數據和視圖封裝成ModelAndView對象,最後又將ModelAndView中的模型數據經過request域傳輸到頁面,jsp視圖解析器默認使用的是jstl。
Ibatis:2010年,apache的Ibatis框架中止更新,並移交給了google團隊,同時改名爲MyBatis。從2010年後Ibatis在沒更新過,完全變成了一個孤兒框架。一個沒人維護的框架註定被mybatis拍在沙灘上。
Mybatis:Ibatis的升級版本。
Mybatis實現了DAO接口與xml映射文件的綁定,自動爲咱們生成接口的具體實現,使用起來變得更加省事和方便。
註解使用狀況:Sql語句簡單時
xml綁定使用狀況:xml綁定 (@RequestMap用來綁定xml文件)
SqlSession
映射鍵值對便可
<result column="title" property="title" javaType="java.lang.String"/>`複製代碼
column:數據庫中表的列名
property:實體Bean中的屬性名
把Sql語句從Java中獨立出來。
封裝了底層的JDBC,API的調用,而且可以將結果集自動轉換成JavaBean對象,簡化了Java數據庫編程的重複工做。
本身編寫Sql語句,更加的靈活。
入參無需用對象封裝(或者map封裝),使用@Param註解
<collection property="topicComment" column="id"`
ofType="com.tmf.bbs.pojo.Comment" select="selectComment" />複製代碼
property:屬性名
column:共同列
ofType:集合中元素的類型
select:要鏈接的查詢
<association property="topicType" select="selectType"`
column="topics_type_id" javaType="com.tmf.bbs.pojo.Type"/>複製代碼
property:屬性名
select:要鏈接的查詢
column:共同列
javaType:集合中元素的類型
* ${}:簡單字符串替換,把${}直接替換成變量的值,不作任何轉換,這種是取值之後再去編譯SQL語句。
* #{}:預編譯處理,sql中的#{}替換成?,補全預編譯語句,有效的防止Sql語句注入,這種取值是編譯好SQL語句再取值。複製代碼
select last _insert_id()複製代碼
RowBounds對象分頁
在Sql內直接書寫,帶有物理分頁
經過SqlSessionFactoryBuilder從mybatis-config.xml配置文件中構建出SqlSessionFactory。
SqlSessionFactory開啓一個SqlSession,經過SqlSession實例得到Mapper對象而且運行Mapper映射的Sql語句。
完成數據庫的CRUD操做和事務提交,關閉SqlSession。
前面若有不正確的地方還但願你們多多指教,但願和志同道合的朋友一塊兒學習,一塊兒進步,先更新到這裏,下次繼續補充。