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。
前面若有不正确的地方还但愿你们多多指教,但愿和志同道合的朋友一块儿学习,一块儿进步,先更新到这里,下次继续补充。