Java面试题自用六

Java面试题自用六

1.forward(转发)与redirect(重定向)的区别

1.forward

request.getRequestDispatcher(“new.jsp”).forward(request, response); //转发到new.jsp

2.redirect

response.sendRedirect(“new.jsp”); //重定向到new.jsp

很明显一个是用request对象调用,一个是用response对象调用,那么,这两者有什么区别呢?

一、数据共享方面

forward:转发页面和转发到的页面可以共享request里面的数据
redirect:不能共享数据

二、地址栏显示方面

forward是服务器请求资源,服务器直接访问目标地址的URL,把那个URL的响应内容读取过来,然后把这些内容再发给浏览器.浏览器根本不知道服务器发送的内容从哪里来的,所以它的地址栏还是原来的地址.
redirect是服务端根据逻辑,发送一个状态码,告诉浏览器重新去请求那个地址.所以地址栏显示的是新的URL.

三、本质区别

转发是服务器行为,重定向是客户端行为。为什么这样说呢,这就要看两个动作的工作流程:

转发过程:客户浏览器发送http请求—>web服务器接受此请求—>调用内部的一个方法在容器内部完成请求处理和转发动作—>将目标资源 发送给客户;在这里,转发的路径必须是同一个web容器下的url,其不能转向到其他的web路径上去,中间传递的是自己的容器内的request。在客 户浏览器路径栏显示的仍然是其第一次访问的路径,也就是说客户是感觉不到服务器做了转发的。转发行为是浏览器只做了一次访问请求。

**重定向过程:**客户浏览器发送http请求—>web服务器接受后发送302状态码响应及对应新的location给客户浏览器—>客户浏览器发现 是302响应,则自动再发送一个新的http请求,请求url是新的location地址—>服务器根据此请求寻找资源并发送给客户。在这里 location可以重定向到任意URL,既然是浏览器重新发出了请求,则就没有什么request传递的概念了。在客户浏览器路径栏显示的是其重定向的 路径,客户可以观察到地址的变化的。重定向行为是浏览器做了至少两次的访问请求的。

**重定向,其实是两次request:**第一次,客户端request A,服务器响应,并response回来,告诉浏览器,你应该去B。这个时候IE可以看到地址变了,而且历史的回退按钮也亮了。重定向可以访问自己web应用以外的资源。在重定向的过程中,传输的信息会被丢失。

2.数据库的三范式是什么?

  • 第一范式:强调的是列的原子性,即数据库表的每一列都是不可分割的原子数据项。
  • 第二范式:要求实体的属性完全依赖于主关键字。所谓完全依赖是指不能存在仅依赖主关键字一部分的属性。
  • 第三范式:任何非主属性不依赖于其它非主属性。

3.ApplicationContext通常的实现是什么?

FileSystemXmlApplicationContext :此容器从⼀个XML⽂件中加载beans的定义,XMLBean 配置⽂件的全路径名必须提供给它的构造函数。
ClassPathXmlApplicationContext:此容器也从⼀个XML⽂件中加载beans的定义,这⾥,你需要正确设置classpath因为这个容器将在classpath⾥找bean配置。
WebXmlApplicationContext:此容器加载⼀个XML⽂件,此⽂件定义了⼀个WEB应⽤的所有bean。

4.BeanFactory和ApplicationContext有什么区别?

BeanFactory 可以理解为含有bean集合的⼯⼚类。BeanFactory 包含了种bean的定义,
以便在接收到客户端请求时将对应的bean实例化。
BeanFactory还能在实例化对象的时⽣成协作类之间的关系。此举将bean⾃身与bean客户
端的配置中解放出来。BeanFactory还包含了bean⽣命周期的控制,调⽤客户端的初始化
⽅法(initialization methods)和销毁⽅法(destruction methods)。
从表⾯上看,application context如同bean factory⼀样具有bean定义、bean关联关系
的设置,根据请求分发bean的功能。但application context在此基础上还提供了其他的功
能。

  1. 提供了⽀持国际化的⽂本消息
  2. 统⼀的资源⽂件读取⽅式
  3. 已在监听器中注册的bean的事件 以下是三种较常⻅的 ApplicationContext 实现⽅式:
    a. ClassPathXmlApplicationContext:从classpath的XML配置⽂件中读取上下⽂,并⽣成上下⽂定义。应⽤程序上下⽂从程序环境变量中取得。
    ApplicationContext context = new ClassPathXmlApplicationContext(“bean.xml”);
    b. FileSystemXmlApplicationContext :由⽂件系统中的XML配置⽂件读取上下⽂。
    ApplicationContext context = new FileSystemXmlApplicationContext(“bean.xml”);
    c. XmlWebApplicationContext:由Web应⽤的XML⽂件读取上下⽂。

5.Spring有⼏种配置⽅式?

将Spring配置到应⽤开发中有以下三种⽅式:

  1. 基于XML的配置
  2. 基于注解的配置
  3. 基于Java的配置

6.@Component, @Controller, @Repository, @Service 有何区别?

@Component:这将 java 类标记为 bean。它是任何 Spring 管理组件的通用构造型。spring 的组件扫描机制现在可以将其拾取并将其拉入应用程序环境中。

@Controller:这将一个类标记为 Spring Web MVC 控制器。标有它的 Bean 会自动导入到 IoC 容器中。

@Service:此注解是组件注解的特化。它不会对 @Component 注解提供任何其他行为。您可以在服务层类中使用 @Service 而不是 @Component,因为它以更好的方式指定了意图。

@Repository:这个注解是具有类似用途和功能的 @Component 注解的特化。它为 DAO 提供了额外的好处。它将 DAO 导入 IoC 容器,并使未经检查的异常有资格转换为 Spring DataAccessException。

7.@Autowired 注解有什么作用,@Autowired和@Resource之间的区别?

@Autowired默认是按照类型装配注入的,默认情况下它要求依赖对象必须存在(可以设置它required属性为false)。@Autowired 注解提供了更细粒度的控制,包括在何处以及如何完成自动装配。它的用法和@Required一样,修饰setter方法、构造器、属性或者具有任意名称和/或多个参数的PN方法。

@Autowired可用于:构造函数、成员变量、Setter方法

@Autowired和@Resource之间的区别

  • @Autowired默认是按照类型装配注入的,默认情况下它要求依赖对象必须存在(可以设置它required属性为false)。
  • @Resource默认是按照名称来装配注入的,只有当找不到与名称匹配的bean才会按照类型来装配注入。

8.SpringBoot和SpringCloud的区别?

SpringBoot专注于快速方便的开发单个个体微服务。

SpringCloud是关注全局的微服务协调整理治理框架,它将SpringBoot开发的一个个单体微服务整合并管理起来,

为各个微服务之间提供,配置管理、服务发现、断路器、路由、微代理、事件总线、全局锁、决策竞选、分布式会话等等集成服务

SpringBoot可以离开SpringCloud独立使用开发项目, 但是SpringCloud离不开SpringBoot ,属于依赖的关系

SpringBoot专注于快速、方便的开发单个微服务个体,SpringCloud关注全局的服务治理框架。

以上内容来源于自己学习总结以及网络收集,如有问题欢迎指出

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值