《Java 面试问题 一 Spring 、SpringMVC 、Mybatis》

  自己理解SSM框架可能问到的面试问题

  

  一、需要知道的SSM基础知识

     1.什么是Spring?

          Spring 是一款轻量级的 IOC (依赖反转) 和  APO (面向切面) 容器框架。(个人理解: 就是一个Bean对象容器,不用我们new 对象了,将对象的创建交给容器系统来管理了)

          常见的配置方式有三种 : 

              1.基于 xml 的配置方式              2.基于注解的配置方式              3.基于Java的配置方式 (虽然这种我没怎么用过吧,但是确实是存在)

        

     2.Spring Bean对象的作用范围

          1 ) .  singleton :这种bean的范围是默认的,不管来了多少请求返回的都是这个对象,单例模式 ,正是这个原因(全局共享一个变量) 可能会造成线程不安全,但是只有 有状态Bean的时候才可能会出现  

              prototype : 原形范围与单例范围相反,为每一个请求都创建一个对象

              request :   在请求bean范围内会每一个来自客户端的网络请求创建一个实例,在请求完成以后,bean会失效并被垃圾回收器回收。

              session :与请求范围类似,确保每个session中有一个bean的实例,在session过期后,bean会随之失效。

               global-session :global-session和Portlet应用相关。当你的应用部署在Portlet容器中工作时,它包含很多portlet。如果你想要声明让所有的portlet共用全局的存储变量的话,那么这全局变量需要存储在global-session中。(这个是直接复制粘贴的,并没有直接理解)

 

    3.Spring 用到的设计模式

         答:   简单工厂模式、工厂模式、代理模式、单例模式、模板模式......(暂时没有理解到的,还有好多)

 

       4.Spring 基于xml 注入bean的几种方法:

        答: 

           1.set方法

           2.构造器方法    (两个参数同类型:可以使用index中)

          3.静态工厂方法

          4.实例工厂方法

    5.使用Spring的优点

          1.可以解耦合

          2.通过使用AOP可以方便的进行事务管理  、权限控制、日志管理

          3.Spring 对主流框架进行了支持如 Struts2  和 Hibernate等

    6.Spring事务管理的两种方式:

          1.编程式事务:在代码中使用编程来完成事务管理 ,硬编码不推荐使用 (这个我还真的没有具体使用过,等使用过在来发表评论)

          2.声明式事务: 在配置文件中进行声明配置,也可以使用注解进行配置   (推荐使用)

              申声明式事务也分为两种:

               1.基于注解的声明式事务

               2.基于xml的声明式事务

 

    7.Spring中的核心类有哪些?各有什么作用

          好吧,我坦言 在Spring中我知道的类没有几个,一个手都能数过来,希望以后能好好的读一下Spring 的底层源码,但是我知道的有以下两个

          BeanFactory : 对象的工厂,里面有对 对象的基本操作,比如说getBean,可以产生一个新的对象。

          ApplicationContext: 继承了BeanFactory 功能比  BeanFactory更多

           ..........

           未完。待续

    8.DI 和 IOC的理解

       

        一、IOC介绍

          IOC是控制反转。

          创建对象实例的控制权从代码控制剥离到IOC容器控制(之前的写法,由程序代码直接操控使用new关键字),实际就是你在xml文件控制,控制权的转移是所谓反转,侧重于原理。 

        二、DI介绍

          DI是依赖注入

          创建对象实例时,为这个对象注入属性值或其它对象实例,侧重于实现。

        三、区别

          1.它们是spring核心思想的不同方面的描述。

          2.依赖注入和控制反转是对同一件事情的不同描述,从某个方面讲,就是它们描述的角度不同。

              依赖注入是从应用程序的角度在描述,可以把依赖注入描述完整点:应用程序依赖容器创建并注入它所需要的外部资源;

                   而控制反转是从容器的角度在描述,描述完整点:容器控制应用程序,由容器反向的向应用程序注入应用程序所需要的外部资源。

 

     9.什么是SpringMVC:

          SpringMVC是一款基于Java实现的MCV设计模式的一款轻量级web框架,他实现了web内容的解耦合。

 

       10.SpringMVC处理用户请求的流程:

            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响应用户

     11.SpringMVC 如何解决中文POST 和 GET请求乱码问题

            1.get请求 可以使用手动转换    String name = new String(xx.getBytes(“iso-8859-1”),”utf-8”);

                 如果不起作用的话可以修改  server.xml 和工程的编码都为 utf-8

            2.post 请求中文乱码问题解决方式

                在web.xml 文件中配置Spring中的  CharacterEncoding Filter

 

     12.SpringMVC如何响应JSON数据给Ajax使用

          1.使用Jaskon jar包

          2.配置ResponseBody  

          3.在配置文件中配置   

 

       13.什么是Mybatis?

            1. mybatis 是一款半ORM框架(他内部封装了JDBC的操作 是开发者专注于sql的编写,并不用关心驱动的加载,连接对象的创建、创建statement对象等复杂的操作过程)灵活性高。

            2.mybatis可以使用xml 或者注解来进行对Entity对象于数据库表中的字段进行对应,避免了JDBC返回结果集的设置

            3.通过xml 文件或注解的方式将要执行的各种 statement 配置起来,并通过java对象和 statement中sql的动态参数进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果映射为java对象并返回。(从执行sql到返回result的过程)。                        (这个是我抄的。。。。。)

 

      14.Mybatis的优点

            1.可以灵活的编写sql语句

            2.对各种数据库有很好的兼容

            3.与JDBC相比 减少了50%的代码,减少了大量的冗余代码,不用手动 创建和关闭连接  

            4.能够与Spring进行很好的集成

      15.Mybatis的缺点

             1.如果涉及的业务逻辑比较负责,涉及到多表关联,对程序开发人员的sql语句功底掌握要求较高

              2. 可移植性差   sql语句与具体使用的数据库有很大关系,如果更换数据库,sql语句可能需要重新编写。

      16.  ${} 和 #{}的区别

              # 是预编译处理

              $ 是字符串替换

            Mybatis  在处理 #{}  会将sql 中的#{} 替换成 ? 并调用  PreparedStatement的set方法来设置值

            Mybatis 在处理${}   会直接将sql 中的${} 直接替换成字符串  ,存在sql 注入问题

      

      17. 当实体类中的属性和表中的字段名称不一致该怎么解决?

            解决方案1: 在查询的sql 语句中定义字段的别名,让别名和类属性的名称一致

              

             

             

            解决方案2:   通过来映射字段名和实体类属性名的一一对应的关系。

 

              

           
 
            
              
                
 
                
                
                
            

  

    18.通常一个Xml映射文件,都会写一个Dao接口与之对应,请问,这个Dao接口的工作原理是什么?

      Dao接口里的方法,参数不同时,方法能重载吗?

          Dao接口即Mapper接口。接口的全限名,就是映射文件中的namespace的值;接口的方法名,就是映射文件中Mapper的Statement的id值;接口方法内的参数,就是传递给sql的参数。

Mapper接口是没有实现类的,当调用接口方法时,接口全限名+方法名拼接字符串作为key值,可唯一定位一个MapperStatement。在Mybatis中,每一个