自己理解SSM框架可能问到的面试问题
Spring 是一款轻量级的 IOC (依赖反转) 和 APO (面向切面) 容器框架。(个人理解: 就是一个Bean对象容器,不用我们new 对象了,将对象的创建交给容器系统来管理了)
常见的配置方式有三种 :
1.基于 xml 的配置方式 2.基于注解的配置方式 3.基于Java的配置方式 (虽然这种我没怎么用过吧,但是确实是存在)
1 ) . singleton :这种bean的范围是默认的,不管来了多少请求返回的都是这个对象,单例模式 ,正是这个原因(全局共享一个变量) 可能会造成线程不安全,但是只有 有状态Bean的时候才可能会出现
prototype : 原形范围与单例范围相反,为每一个请求都创建一个对象
request : 在请求bean范围内会每一个来自客户端的网络请求创建一个实例,在请求完成以后,bean会失效并被垃圾回收器回收。
session :与请求范围类似,确保每个session中有一个bean的实例,在session过期后,bean会随之失效。
global-session :global-session和Portlet应用相关。当你的应用部署在Portlet容器中工作时,它包含很多portlet。如果你想要声明让所有的portlet共用全局的存储变量的话,那么这全局变量需要存储在global-session中。(这个是直接复制粘贴的,并没有直接理解)
答: 简单工厂模式、工厂模式、代理模式、单例模式、模板模式......(暂时没有理解到的,还有好多)
答:
1.set方法
2.构造器方法 (两个参数同类型:可以使用index中)
3.静态工厂方法
4.实例工厂方法
1.可以解耦合
2.通过使用AOP可以方便的进行事务管理 、权限控制、日志管理
3.Spring 对主流框架进行了支持如 Struts2 和 Hibernate等
1.编程式事务:在代码中使用编程来完成事务管理 ,硬编码不推荐使用 (这个我还真的没有具体使用过,等使用过在来发表评论)
2.声明式事务: 在配置文件中进行声明配置,也可以使用注解进行配置 (推荐使用)
申声明式事务也分为两种:
1.基于注解的声明式事务
2.基于xml的声明式事务
好吧,我坦言 在Spring中我知道的类没有几个,一个手都能数过来,希望以后能好好的读一下Spring 的底层源码,但是我知道的有以下两个
BeanFactory : 对象的工厂,里面有对 对象的基本操作,比如说getBean,可以产生一个新的对象。
ApplicationContext: 继承了BeanFactory 功能比 BeanFactory更多
..........
未完。待续
一、IOC介绍
IOC是控制反转。
创建对象实例的控制权从代码控制剥离到IOC容器控制(之前的写法,由程序代码直接操控使用new关键字),实际就是你在xml文件控制,控制权的转移是所谓反转,侧重于原理。
二、DI介绍
DI是依赖注入
创建对象实例时,为这个对象注入属性值或其它对象实例,侧重于实现。
三、区别
1.它们是spring核心思想的不同方面的描述。
2.依赖注入和控制反转是对同一件事情的不同描述,从某个方面讲,就是它们描述的角度不同。
依赖注入是从应用程序的角度在描述,可以把依赖注入描述完整点:应用程序依赖容器创建并注入它所需要的外部资源;
而控制反转是从容器的角度在描述,描述完整点:容器控制应用程序,由容器反向的向应用程序注入应用程序所需要的外部资源。
SpringMVC是一款基于Java实现的MCV设计模式的一款轻量级web框架,他实现了web内容的解耦合。
1.用户发送请求至前端控制器DispatcherServlet
2.DispatcherServlet收到请求调用HandlerMapping处理器映射器。
3.处理器映射器根据请求url找到具体的处理器,生成处理器对象及处理器拦截器(如果有则生成)一并返回给DispatcherServlet。
4.DispatcherServlet通过HandlerAdapter处理器适配器调用处理器
5.执行处理器(Controller,也叫后端控制器)。
6.Controller执行完成返回ModelAndView
7.HandlerAdapter将controller执行结果ModelAndView返回给DispatcherServlet
8.DispatcherServlet将ModelAndView传给ViewReslover视图解析器
9.ViewReslover解析后返回具体View
10.DispatcherServlet对View进行渲染视图(即将模型数据填充至视图中)。
11.DispatcherServlet响应用户
1.get请求 可以使用手动转换 String name = new String(xx.getBytes(“iso-8859-1”),”utf-8”);
如果不起作用的话可以修改 server.xml 和工程的编码都为 utf-8
2.post 请求中文乱码问题解决方式
在web.xml 文件中配置Spring中的 CharacterEncoding Filter
1.使用Jaskon jar包
2.配置ResponseBody
3.在配置文件中配置 <mvc:annotation-driven />
1. mybatis 是一款半ORM框架(他内部封装了JDBC的操作 是开发者专注于sql的编写,并不用关心驱动的加载,连接对象的创建、创建statement对象等复杂的操作过程)灵活性高。
2.mybatis可以使用xml 或者注解来进行对Entity对象于数据库表中的字段进行对应,避免了JDBC返回结果集的设置
3.通过xml 文件或注解的方式将要执行的各种 statement 配置起来,并通过java对象和 statement中sql的动态参数进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果映射为java对象并返回。(从执行sql到返回result的过程)。 (这个是我抄的。。。。。)
1.可以灵活的编写sql语句
2.对各种数据库有很好的兼容
3.与JDBC相比 减少了50%的代码,减少了大量的冗余代码,不用手动 创建和关闭连接
4.能够与Spring进行很好的集成
1.如果涉及的业务逻辑比较负责,涉及到多表关联,对程序开发人员的sql语句功底掌握要求较高
2. 可移植性差 sql语句与具体使用的数据库有很大关系,如果更换数据库,sql语句可能需要重新编写。
# 是预编译处理
$ 是字符串替换
Mybatis 在处理 #{} 会将sql 中的#{} 替换成 ? 并调用 PreparedStatement的set方法来设置值
Mybatis 在处理{} 会直接将sql 中的{} 直接替换成字符串 ,存在sql 注入问题
解决方案1: 在查询的sql 语句中定义字段的别名,让别名和类属性的名称一致
<select id=”selectorder” parametertype=”int” resultetype=”me.gacl.domain.order”>
select order_id id, order_no orderno ,order_price price form orders where order_id=#{id};
</select>
解决方案2: 通过<resultMap>来映射字段名和实体类属性名的一一对应的关系。
<select id="getOrder" parameterType="int" resultMap="orderresultmap">
select * from orders where order_id=#{id}
</select>
<resultMap type=”me.gacl.domain.order” id=”orderresultmap”>
<!–用id属性来映射主键字段–>
<id property=”id” column=”order_id”>
<!–用result属性来映射非主键字段,property为实体类属性名,column为数据表中的属性–>
<result property = “orderno” column =”order_no”/>
<result property=”price” column=”order_price” />
</reslutMap>
Dao接口即Mapper接口。接口的全限名,就是映射文件中的namespace的值;接口的方法名,就是映射文件中Mapper的Statement的id值;接口方法内的参数,就是传递给sql的参数。
Mapper接口是没有实现类的,当调用接口方法时,接口全限名+方法名拼接字符串作为key值,可唯一定位一个MapperStatement。在Mybatis中,每一个<select>、<insert>、<update>、<delete>标签,都会被解析为一个MapperStatement对象。
举例:com.mybatis3.mappers.StudentDao.findStudentById,可以唯一找到namespace为com.mybatis3.mappers.StudentDao下面 id 为 findStudentById 的 MapperStatement。
Mapper接口里的方法,是不能重载的,因为是使用 全限名+方法名 的保存和寻找策略。Mapper 接口的工作原理是JDK动态代理,Mybatis运行时会使用JDK动态代理为Mapper接口生成代理对象proxy,代理对象会拦截接口方法,转而执行MapperStatement所代表的sql,然后将sql执行结果返回。
————————————————————————还有好多知识,但是日后在补充————————————————————————————————