一、SSL问题1、SSL在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下发表评论吗? 注册:@Controller @Service @Component注入:@Autowired @Resource请求地址:返回具体数据类型而不是@RequestMapping跳转: http://www.Sina
constructor-arg index="0" type=" Java.lang.string " value=" BMW "/constructor-arg
http://www.Sina.com/: http://www.Sina.com /
property name=" id " value=" 1111 "/property
@ResponseBody
7、Spring主要使用什么模式? 工厂模式:构造器注入单实例模式:通过构造方法初始化代理模式:setter方法注入8、IOC、AOP的实现原理? IOC: 通过setter方法初始化
AOP: 接口注入
二、SpringMvc问题1、SpringMvc的控制器是单模的吗? 如果是那样的话,有什么问题,怎么解决? 默认值为每个Bean的创建通过方法
默认的每个Bean的作用域都是单例
但是关于Aop的实现通过代理模式,通过反射机制生成对象注入
解决办法,动态代理
为什么设计成单设计模式?
1 .性能(3358www.Sina.com/)2.多例)单例模式,) 2、是否需要SpringMvc上的控制器评论? @ controller:http://www.Sina.com/3,@RequestMapping注释用于类的作用? 作用:在多线程进行访问的时候,有线程安全问题.4,前台多个参数,这些参数都是一个对象,是否快速获取对象? 方法不建议使用同步5、SpringMvc中函数的返回值? 字符串、ModelAndView、列表、Set等
返回常规String、Ajax请求和List集合
6、SpringMvc上的传输和重定向? 转发: Hello重定向: return:redirect : hello.JSP 7、SpringMvc和Ajax之间的交互调用?因为会影响性能.
加入犹豫不决的豌豆. 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的升级版本。
Mybatis实现了DAO接口与xml映射文件的绑定,自动为我们生成接口的具体实现,使用起来变得更加省事和方便。
3、什么情况用注解,什么情况用xml绑定?注解使用情况:Sql语句简单时
xml绑定使用情况:xml绑定 (@RequestMap用来绑定xml文件)
映射键值对即可
< result column="title" property="title" javaType="java.lang.String"/>column:数据库中表的列名
property:实体Bean中的属性名
${ } 仅仅为一个纯碎的 string 替换,在动态 SQL 解析阶段将会进行变量替换。
例如,Mapper.xml中如下的 sql: select * from user where name = ${name};
当我们传递的参数为 “Jack” 时,上述 sql 的解析为:
select * from user where name = "Jack";预编译之前的 SQL 语句已经不包含变量了,完全已经是常量数据了
#{}:预编译处理,sql中的#{}替换成?,补全预编译语句,有效的防止Sql语句注入,这种取值是编译好SQL语句再取值。例如,Mapper.xml中如下的 sql 语句:
select * from user where name = #{name};动态解析为:
select * from user where name = ?;一个 #{ } 被解析为一个参数占位符 ? 。
而${ } 仅仅为一个纯碎的 string 替换,在动态 SQL 解析阶段将会进行变量替换。
10、获取上一次自动生成的主键值? select last _insert_id() 11、Mybatis如何分页,分页原理? RowBounds对象分页在Sql内直接书写,带有物理分页1.使用mybatis自带的分页(物理分页)
通过RowBounds rb=new RowBounds(offset, limit);来实现
实际上并不是真正的分页,它是将所有的内容查询出来,然后在物理内存中进行截取,这样如果数据量大的话不可取。
2.通过插件进行分页
使用PageHelper进行分页
它的实现原理是将sql语句进行拦截,并在后面添加limit从而达到分页的目的。
12、Mybatis工作原理?Mybatis工作原理图
原理: