百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

Spring 中的Servlet与Spring MVC 有什么区别?

yuyutoo 2024-11-05 13:27 4 浏览 0 评论

ServletSpring MVC都是在Java Web开发中用于处理Web请求的技术,其中Servlet是Java EE规范的一部分,而Spring MVC是Spring Framework的一部分,属于Spring生态系统的一部分。

接下来,我们就来详细的介绍一下二者之间的区别,并且结合底层原理对其进行说明。

Servlet是什么?

Servlet 是 Java EE(现在叫 Jakarta EE)中最核心的组件之一,它是一个接口,主要用于处理HTTP请求。通过实现 javax.servlet.Servlet 接口,来处理客户端发送的请求并生成响应。

其工作流程如下。

  • 第一步、 客户端一般情况下这个客户端通常是指浏览器,发起一个HTTP请求,Servlet会接收到该请求。
  • 第二步、当请求到达Servlet容器(例如Tomcat)之后,Servlet容器会解析请求的URL,并根据映射规则找到相应的Servlet。
  • 第三步、如果Servlet还没有被加载,容器会先实例化它。每个请求会触发Servlet的 service() 方法,该方法会根据HTTP请求类型(GET、POST等)调用相应的doGet()或doPost()等方法。
  • 第四步、Servlet处理完请求后,会将生成的响应数据(通常是HTML或JSON等)返回给客户端。
  • 第五步、当服务器关闭或Servlet不再需要时,容器会调用destroy()方法来销毁Servlet实例。

这也对应了之前的分享中,我们介绍的关于过滤器的操作内容,如下所示。

@WebServlet("/hello")
public class HelloServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {
        resp.setContentType("text/html");
        PrintWriter out = resp.getWriter();
        out.println("<h1>Hello, Servlet!</h1>");
    }
}

Servlet要求开发者可以手动处理HTTP请求的各个方面,包括从HttpServletRequest中获取参数,来生成HttpServletResponse响应,以及处理HTTP方法(如GET、POST等)。当然也可以通过转发请求给JSP引擎来渲染动态HTML页面。在默认情况下,Servlet是单实例的,也就是说每个Servlet实例可以处理多个请求,因此需要开发者保证线程安全。

Spring MVC是什么?

Spring MVC是Spring Framework框架提供的一个基于Servlet实现的Web框架,它遵循MVC(Model-View-Controller)设计模式,其设计的目的就是为了简化Web应用的开发。并且Spring MVC是建立在Servlet API之上,与Servlet的不同就是它提供了更高层次的抽象,并对复杂的Web请求处理提供了更强大的支持。

Spring MVC的工作流程包括多个组件,它通过DispatcherServlet作为前端控制器来协调请求处理,其处理流程如下所示。

  • 第一步、和Servlet一样,客户端(浏览器)发送HTTP请求。
  • 第二步、请求首先到达Spring MVC的核心组件DispatcherServlet其本质上也是一个Servlet。
  • 第三步、这个时候DispatcherServlet会使用HandlerMapping来根据URL找到对应的处理器,这个处理器通常是一个控制器Controller。
  • 第四步、DispatcherServlet会调用映射到的控制器中的方法。而控制器方法通常会返回一个 ModelAndView对象这个对象包含视图名和模型数据,用来进行View层的数据渲染展示。
  • 第五步、DispatcherServlet通过ViewResolver来将返回的视图名解析为具体的视图,例如JSP或Thymeleaf模板引擎。
  • 第六步、视图负责渲染最终的HTML或其他格式的响应内容,最后响应返回给客户端。

如下所示,是一个简单的SpringMVC的示例。

@Controller
public class HelloController {

    @GetMapping("/hello")
    public String sayHello(Model model) {
        model.addAttribute("message", "Hello, Spring MVC!");
        return "hello";  // 返回视图名 "hello"
    }
}

Spring MVC主要依靠注解来定义控制器和映射规则,简化了开发。例如我们比较常见的注解有@Controller, @RequestMapping, @GetMapping, @PostMapping等,Spring MVC会自动将HTTP请求中的参数绑定到控制器方法的参数中,不需要手动从 HttpServletRequest 获取。提供了众多拦截器(interceptors)、过滤器(filters)等机制,可以方便地进行功能扩展。

通过内置的视图解析机制,可以轻松集成JSP、Thymeleaf等视图技术。支持对表单数据的自动绑定、表单验证和错误处理。

底层差异详解

控制器的实现方式

  • Servlet直接实现或继承HttpServlet类来实现的具体操作,我们需要通过重写doGet()、doPost()等方法来处理HTTP请求操作。
  • Spring MVC控制器不需要继承特定类,它通常使用@Controller注解来标记控制类类,然后通过使用@RequestMapping或其他映射注解来定义URL的映射关系。这种方式避免了和具体的Servlet API绑定,使得Spring MVC的使用更加的灵活。

请求处理模型

  • Servlet是单个类对应单个URL映射,处理过程较为手动。需要开发者去处理大量的处理请求参数、构建响应。
  • Spring MVC采用了DispatcherServlet作为中央控制器,将所有的请求经过它来进行处理,然后通过各种策略模式的组件,例如HandlerMapping, HandlerAdapter, ViewResolver等进行分发和处理。这样对于开发者来讲,只需要专注于业务逻辑。而底层的许多重复工作,例如请求参数的处理、视图解析等则是由Spring框架自动完成。

对象和数据管理

  • Servlet处理请求的生命周期较短,主要通过HttpServletRequest和HttpServletResponse传递请求和响应的数据。Servlet则本身只专注于请求和响应的交互,对于状态的管理则需要通过会话Session或者通过上下文Context机制来实现。
  • Spring MVC中的数据传递更加高级,例如通过Model或ModelAndView来传递数据到视图。Spring MVC还整合了@ModelAttribute等注解来处理表单提交的数据绑定和数据校验,减少了手动从请求中获取参数的工作。

扩展性和模块化

  • Servlet本身比较底层,虽然灵活,但很多功能需要手动实现,比如会话管理、跨站请求伪造(CSRF)防护等,开发者必须依赖外部库或者自己实现。
  • Spring MVC提供了大量现成的组件,诸如数据绑定、校验、异常处理、国际化、模板引擎集成等。开发者可以通过扩展HandlerInterceptor、 ControllerAdvice 等类进行扩展,也可以利用Spring生态的众多功能(如Spring Security、Spring Data等)来增强Web应用。

依赖注入和AOP

  • Servlet本身不支持依赖注入,也没有AOP能力。需要结合Java EE中的CDI(Context and Dependency Injection)或手动管理依赖。
  • Spring MVC完全依赖Spring的核心功能即IOC容器和AOP,控制器类的依赖可以通过Spring的自动注入例如 @Autowired来管理,极大简化了组件之间的依赖管理。AOP(Aspect-Oriented Programming)也可以用于控制器中,以处理日志、事务等横切关注点。

总结

Servlet是Java Web开发的底层技术,它是Java EE的一部分,要求开发者手动处理请求、响应、参数等内容。Servlet的API较为原始,虽然功能强大,但并没有提供高级的Web框架功能。Spring MVC是基于Servlet的一个Web框架,它简化了Web开发,通过 DispatcherServlet 提供了更加模块化、可扩展的方式来处理Web请求。Spring MVC 依赖Spring框架的依赖注入和其他组件,极大提升了开发效率,并且集成了大量Web开发中常用的功能。

两者的区别可以类比于“手工打造”与“利用框架搭建”,Spring MVC在Servlet的基础上进行了高度封装,简化了开发流程并增强了扩展性。

相关推荐

史上最全的浏览器兼容性问题和解决方案

微信ID:WEB_wysj(点击关注)◎◎◎◎◎◎◎◎◎一┳═┻︻▄(页底留言开放,欢迎来吐槽)●●●...

平面设计基础知识_平面设计基础知识实验收获与总结
平面设计基础知识_平面设计基础知识实验收获与总结

CSS构造颜色,背景与图像1.使用span更好的控制文本中局部区域的文本:文本;2.使用display属性提供区块转变:display:inline(是内联的...

2025-02-21 16:01 yuyutoo

写作排版简单三步就行-工具篇_作文排版模板

和我们工作中日常word排版内部交流不同,这篇教程介绍的写作排版主要是用于“微信公众号、头条号”网络展示。写作展现的是我的思考,排版是让写作在网格上更好地展现。在写作上花费时间是有累积复利优势的,在排...

写一个2048的游戏_2048小游戏功能实现

1.创建HTML文件1.打开一个文本编辑器,例如Notepad++、SublimeText、VisualStudioCode等。2.将以下HTML代码复制并粘贴到文本编辑器中:html...

今天你穿“短袖”了吗?青岛最高23℃!接下来几天气温更刺激……

  最近的天气暖和得让很多小伙伴们喊“热”!!!  昨天的气温到底升得有多高呢?你家有没有榜上有名?...

CSS不规则卡片,纯CSS制作优惠券样式,CSS实现锯齿样式

之前也有写过CSS优惠券样式《CSS3径向渐变实现优惠券波浪造型》,这次再来温习一遍,并且将更为详细的讲解,从布局到具体样式说明,最后定义CSS变量,自定义主题颜色。布局...

柠檬科技肖勃飞:大数据风控助力信用社会建设

...

你的自我界限够强大吗?_你的自我界限够强大吗英文

我的结果:A、该设立新的界限...

行内元素与块级元素,以及区别_行内元素和块级元素有什么区别?

行内元素与块级元素首先,CSS规范规定,每个元素都有display属性,确定该元素的类型,每个元素都有默认的display值,分别为块级(block)、行内(inline)。块级元素:(以下列举比较常...

让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华
让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华

去年的两会期间,习近平总书记在参加人大会议四川代表团审议时,对治蜀兴川提出了明确要求,指明了前行方向,并带来了“祝四川人民的生活越来越安逸”的美好祝福。又是一年...

2025-02-21 16:00 yuyutoo

今年国家综合性消防救援队伍计划招录消防员15000名

记者24日从应急管理部获悉,国家综合性消防救援队伍2023年消防员招录工作已正式启动。今年共计划招录消防员15000名,其中高校应届毕业生5000名、退役士兵5000名、社会青年5000名。本次招录的...

一起盘点最新 Chrome v133 的5大主流特性 ?

1.CSS的高级attr()方法CSSattr()函数是CSSLevel5中用于检索DOM元素的属性值并将其用于CSS属性值,类似于var()函数替换自定义属性值的方式。...

竞走团体世锦赛5月太仓举行 世界冠军杨家玉担任形象大使

style="text-align:center;"data-mce-style="text-align:...

学物理能做什么?_学物理能做什么 卢昌海

作者:曹则贤中国科学院物理研究所原标题:《物理学:ASourceofPowerforMan》在2006年中央电视台《对话》栏目的某期节目中,主持人问过我一个的问题:“学物理的人,如果日后不...

你不知道的关于这只眯眼兔的6个小秘密
你不知道的关于这只眯眼兔的6个小秘密

在你们忙着给熊本君做表情包的时候,要知道,最先在网络上引起轰动的可是这只脸上只有两条缝的兔子——兔斯基。今年,它更是迎来了自己的10岁生日。①关于德艺双馨“老艺...

2025-02-21 16:00 yuyutoo

取消回复欢迎 发表评论: