Java SSM 框架常见面试题
你的导师 架构师日刊 昨天
---------------------------
1 Spring面试题
三种实现方式均有代码:
作用:Ioc解决对象之间的依赖问题,把所有Bean的依赖关系通过配置文件或注解关联起来,降低了耦合度。
1) 构造器注入:通过构造方法初始化
2) setter方法注入:通过setter方法初始化
3) 接口注入
工厂模式:每个Bean的创建通过方法
单例模式:默认的每个Bean的作用域都是单例
代理模式:关于Aop的实现通过代理模式
IOC:通过反射机制生成对象注入
AOP:动态代理
2 SpringMVC面试题
默认是单例模式。问题:单例模式,在多线程访问时有线程安全问题
解决方法:不要用同步,在控制器里面不能写成员变量。
为什么设计成单例模式?
①性能 (不用每次请求都创建对象)
②不需要多例(不要在控制器类中定义成员变量)
@Controller:该注解表明该类扮演控制器的角色
作用:用来映射一个URL到一个类或者一个特定的处理方法上
这个问题有点垃圾,没价值。
方法:直接在方法中声明这个对象,SpringMvc就自动把属性赋值到这个对象里面
String,ModelAndView,void, List,Set 等
一般String,Ajax请求,返回一个List集合
转发:return "forward: hello "
重定向 return "redirect:hello"
通过JackSon框架把java里面对象直接转换成js可识别的json对象。具体步骤如下:
1、页面引入
1)页面引入js方法:
2) ajax方法:$.ajax({});
2、springmvc框架的配置
1)需要添加三个jar jackson-annotations-2.4.0.jar、jackson-core-2.4.2.jar、jackson-databind-2.4.2.jar
3、controller的要素
1)对方法添加@ResponseBody注解
入口不同:
Struts2:filter过滤器
SpringMvc:一个Servlet即前端控制器
开发方式不同:
Struts2:基于类开发,传递参数通过类的属性,只能设置为多例
SpringMvc:基于方法开发(一个url对应一个方法),请求参数传递到方法形参,可以为单例也可以为多例(建议单例)
请求方式不同:
Struts2:值栈村塾请求和响应的数据,通过OGNL存取数据
SpringMvc:通过参数解析器将request请求内容解析,给方法形参赋值,将数据和视图封装成ModelAndView对象,最后又将ModelAndView中的模型数据通过request域传输到页面,jsp视图解析器默认使用的是jstl。
任何连接池都要实现DataSource接口,其实都是对底层jdbc的封装。
${} 不是el表达式,而是spring内部自定义
1、Dhcp的实现:
<bean id="dbcp" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="${jdbc.driver}">property>
<property name="url" value="${jdbc.url}">property>
<property name="username" value="${jdbc.username}">property>
<property name="password" value="${jdbc.password}">property>
bean>
2、c3p0的实现:
<bean id="c3p0" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="${jdbc.driver}">property>
<property name="jdbcUrl" value="${jdbc.url}">property>
<property name="user" value="${jdbc.username}">property>
<property name="password" value="${jdbc.password}">property>
bean>
3、spring对jdbc的实现:
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"
destroy-method="close">
<property name="driverClassName" value="${jdbc.driver}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
<property name="maxActive" value="10" />
<property name="maxIdle" value="5" />
bean>
3 Mybatis面试题
Ibatis:2010年,apache的Ibatis框架停止更新,并移交给了google团队,同时更名为MyBatis。从2010年后Ibatis在没更新过,彻底变成了一个孤儿框架。一个没人维护的框架注定被mybatis拍在沙滩上。
Mybatis:Ibatis的升级版本。
Mybatis实现了DAO接口与xml映射文件的绑定,自动为我们生成接口的具体实现,使用起来变得更加省事和方便。
SqlSession
映射键值对即可:column:数据库中表的列名;property:实体Bean中的属性名
property:属性名select:要连接的查询column:共同列javaType:集合中元素的类型
property:属性名 column:共同列 ofType:集合中元素的类型 select:要连接的查询
${}:简单字符串替换,把${}直接替换成变量的值,不做任何转换,这种是取值以后再去编译SQL语句。
#{}:预编译处理,sql中的#{}替换成?,补全预编译语句,有效的防止Sql语句注入,这种取值是编译好SQL语句再取值。
总结:一般用#{}来进行列的代替
#{}:占位符,如果传入的是字符串,预编译时会自动带上单引号
${}:连接符,如果传入的是基础数据类型,也就是string,long,double,int,boolean,float等 大括号只能写value,即${value};
如果传入的是pojo或者map类型, 大括号只能写属性名或key名,即${username};
能使用#{}的时候尽量使用#{},不使用${};${}用的很少,也就模糊查询
#{}相当于jdbc中的preparedstatement(预编译),${}是直接使用里面的值进行拼接,有可能会有SQL注入问题
RowBounds对象分页
在Sql内直接书写,带有物理分页
原理:
参考文献:https://blog.csdn.net/qq_39031310