一、Spring面试题
1、Spring 在ssm中起什么作用?
Spring:轻量级框架
作用:Bean工厂,用来管理Bean的生命周期和框架集成。
两大核心:
1、IOC/DI(控制反转/依赖注入) :把dao依赖注入到service层,service层反转给action层,Spring顶层容器为BeanFactory。
2、AOP:面向切面编程
2、Spring的事务?
编程式事务管理:编程方式管理事务,极大灵活性,难维护。
声明式事务管理:可以将业务代码和事务管理分离,用注解和xml配置来管理事务。
3、IOC 在项目中的作用?
作用:Ioc解决对象之间的依赖问题,把所有Bean的依赖关系通过配置文件或注解关联起来,降低了耦合度。
4、Spring的配置文件中的内容?
开启事务注解驱动
事务管理器
开启注解功能,并配置扫描包
配置数据库
配置SQL会话工厂,别名,映射文件
不用编写Dao层的实现类
5、Spring下的注解?
-
注册:
1、@controller 控制器(注入服务)
2、@service 服务(注入dao)
3、@repository dao(实现dao访问)
4、@component (把普通pojo实例化到spring容器中,相当于配置文件中的<bean id="" class=""/>)
@Component,@Service,@Controller,@Repository注解的类,并把这些类纳入进spring容器中管理。
- 注入:@Autowired @Resource
@Autowired 与@Resource的区别:
1、 @Autowired与@Resource都可以用来装配bean. 都可以写在字段上,或写在setter方法上。(相同点)
2、 @Autowired默认按类型装配(这个注解是属业spring的),默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为false,如:@Autowired(required=false) ,如果我们想使用名称装配可以结合@Qualifier注解进行使用,如下:
@Autowired()
@Qualifier(
"baseDao") private
BaseDao baseDao;
3、@Resource(这个注解属于J2EE的),默认按照名称进行装配,名称可以通过name属性进行指定,如果没有指定name属性,当注解写在字段上时,默认取字段名进行安装名称查找,如果注解写在setter方法上默认取属性名进行装配。当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配。
@Resource(name=
"baseDao") private
BaseDao baseDao;
推荐使用:@Resource注解在字段上,这样就不用写setter方法了,并且这个注解是属于J2EE的,减少了与spring的耦合。这样代码看起就比较优雅。
总结:@Autowired是默认类型装配,该注解属于spring,默认情况下依赖对象必须存在,若为null,则设置required=flase
@Resource是默认名称装配,名称通过name属性来指定,无指定name属性并且写在字段上,默认按字段名进行安装名称查找,若在setter方法上则属性名进行装配 请求地址:@RequestMapping
返回具体数据类型而非跳转:@ResponseBody
6、Spring DI 的三种方式?
构造器注入:通过构造方法初始化
<constructor-arg index="0" type="java.lang.String" value="宝马"></constructor-arg>
setter方法注入:通过setter方法初始化
<property name="id" value="1111"></property>
接口注入
7、Spring主要使用了什么模式?
工厂模式:每个Bean的创建通过方法
单例模式:默认的每个Bean的作用域都是单例
代理模式:关于Aop的实现通过代理模式
8、IOC,AOP的实现原理?
IOC:通过反射机制生成对象注入
AOP:动态代理
二、SpringMvc面试题
1、SpringMvc 的控制器是不是单例模式,如果是,有什么问题,怎么解决? (默认下是单例模式)
问题:单例模式,在多线程访问时有线程安全问题
解决方法:不要用同步,在控制器里面不能写字段
2、SpringMvc 中控制器的注解?
@Controller:该注解表明该类扮演控制器的角色
@RestController:相当于@ResponseBody + @Controller合在一起
3、@RequestMapping 注解用在类上的作用?
作用:用来映射一个URL到一个类或者一个特定的处理方法上
4、前台多个参数,这些参数都是一个对象,快速得到对象?
方法:直接在方法中声明这个对象,SpringMvc就自动把属性赋值到这个对象里面
例子:
如何在前台(以js页面为例)把众多参数对应的封装成对象数组:
// 提交
saveRoleAccount: function() {
// 定义传入后台的参数
var param = {
jsonStr: '',
deleteIds: '',
roleId: ''
}
roleId = GLOBAL.ID;
deleteIds = $("#deleteIds").val(deleteIdArr.join()).val();
// 定义user对象,放对象的参数
var user = {};
// 获取user对象的属性值
user.userAccount = $this.val();
//电话号码
user.userPhoneNumber = $phone.val();
//用户id
user.id = id;
// 定义arr对象数组 放入的是对象 比如:[{a1,b1,c1},{a2,b2,c2},{a3,b3,c3},{a4,b4,c4},{a5,b5,c5}]
var arr = [];
// 把对象放入对象数组arr中
arr.push(user);
// JSON.stringify() 方法是将一个JavaScript值(对象或者数组)转换为一个 JSON字符串
// 把arr字符串放入jsonStr 中,所以我们只需要把jsonStr 传入后台就能得到arr中所有的参数
param.jsonStr = JSON.stringify(arr);
param.roleId = roleId;
param.deleteIds = deleteIds;
// 调用方法,在这个方法通过ajax里把值传入后台
submitAccount(param);
}
**后台接收:**
/**
* saveAccountRole:(设置账号角色). <br/>
* @param jsonStr 前台数据 json字符串
* @param deleteIds 删除id
* @param roleId 角色id
*/
@RequestMapping(value = "/auth/saveAccountRole.do", method = RequestMethod.POST)
@ResponseBody
public String saveAccountRole(String jsonStr, String deleteIds, Long roleId) {
//获取角色list数据(对象数组)
List < SysUserRole > userList = new ArrayList < SysUserRole > ();
if (StringUtils.isNotBlank(jsonStr)) {
userList = JSON.parseArray(jsonStr, SysUserRole.class);
}
try {
//保存角色信息
authservice.saveRoleAccount(userList, deleteIds, roleId);
} catch(Exception e) {
return JSONUtil.error(e.getMessage());
}
return JSONUtil.success("保存成功");
}
5、SpringMvc中函数的返回值?
String,ModelAndView,List,Set 等
一般String,Ajax请求,返回一个List集合
6、SpringMvc中的转发和重定向?
转发:return:“hello”
-
重定向 :return:“redirect:hello.jsp”
转发在服务器端完成的;重定向是在客户端完成的
转发的速度快;重定向速度慢
转发的是同一次请求;重定向是两次不同请求
转发不会执行转发后的代码;重定向会执行重定向之后的代码
转发地址栏没有变化;重定向地址栏有变化
转发必须是在同一台服务器下完成;重定向可以在不同的服务器下完成<pre xml:space="preserve" style="margin: 0px; padding: 0px; border: 0px; line-height: 1.57143em; font-family: Monaco, Courier, monospace;">
Forward是在服务器端的跳转,就是客户端一个请求发给服务器,
</pre><pre xml:space="preserve" style="margin: 0px; padding: 0px; border: 0px; line-height: 1.57143em; font-family: Monaco, Courier, monospace;">
服务器直接将请求相关的参数的信息原封不动的传递到该服务器的其他jsp或servlet去处理,
</pre><pre xml:space="preserve" style="margin: 0px; padding: 0px; border: 0px; line-height: 1.57143em; font-family: Monaco, Courier, monospace;">
而sendredirect
</pre>
7、SpringMvc和Ajax之间的相互调用?
通过JackSon框架把java里面对象直接转换成js可识别的json对象,具体步骤如下:
加入JackSon.jar
在配置文件中配置json的映射
在接受Ajax方法里面直接返回Object,list等,方法前面需要加上注解@ResponseBody
8、SpringMvc的工作流程图?
简述:
1.请求到达DispatcherServlet
DispatcherServlet需要确认请求是要请求哪个控制器(Controller),DispatcherServlet会查询一个或多个处理器映射(handlerMappings),处理映射器会根据请求所携带的url信息来进行决策
2.请求到达控制器(Controller)
找到url对应的控制器,DispatcherServlet会将请求发送给对应的控制器,到了控制器,请求就会卸下其负载(用户提交的信息)并耐心等待控制器处(Controller)理这些信息。
3.控制器(Controller)处理完毕后返回信息
在完成逻辑处理后,通常会产生一些信息即处理结果,这些信息需要返回给用户,并在浏览器上显示。
4.控制器将模型数据打包,并标出用于渲染的视图名(Controller返回的地址)
控制器将请求连同模型和视图名发回给DispatcherServlet
5.DispatcherServlet解析返回视图名
DispatcherServlet将会拿着返回的视图名去视图解析器中匹配一个特定是视图实现,他可能是也可能不是jsp
6.DispatcherServlet渲染视图
那请求的任务基本也就完成了,最后一站就是视图实现,需要使用的数据在DispatcherServlet中。渲染结束,视图将通过响应返回给用户。
9、Struts2 和 SpringMvc的区别?
入口不同:
Struts2:filter过滤器
SpringMvc:一个Servlet即前端控制器
开发方式不同:
Struts2:基于类开发,传递参数通过类的属性,只能设置为多例(一个类一个action)
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="title" property="title" javaType="java.lang.String"/>
column:数据库中表的列名
property:实体Bean中的属性名
6、Mybatis的好处?
把Sql语句从Java中独立出来。
封装了底层的JDBC,API的调用,并且能够将结果集自动转换成JavaBean对象,简化了Java数据库编程的重复工作。
自己编写Sql语句,更加的灵活。
入参无需用对象封装(或者map封装),使用@Param注解
7、Mybatis配置一对多?
<collection property="topicComment" column="id"
ofType="com.tmf.bbs.pojo.Comment" select="selectComment" />
property:属性名
column:共同列
ofType:集合中元素的类型
select:要连接的查询
8、Mybatis配置一对一?
<association property="topicType" select="selectType"
column="topics_type_id" javaType="com.tmf.bbs.pojo.Type"/>
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。