news 2026/4/18 3:43:41

Servlet入门保姆级教程:从0到1搞定Tomcat与Web开发

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Servlet入门保姆级教程:从0到1搞定Tomcat与Web开发

作为Java后端新手,刚接触Servlet是不是总被一堆“高大上”的概念绕晕?Tomcat是啥?CS/BS架构有啥区别?HTTP协议到底在聊啥?别急!这篇文章用最接地气的话+实战案例,带你轻松拿捏Servlet入门核心知识点,看完就能手写第一个Servlet程序✅

一、Web开发先搞懂这些基础概念 📚

在写代码之前,咱们先把“地基”打牢,这些概念看似抽象,实则都是日常上网能接触到的东西~

1. 软件的两大核心架构:CS vs BS

咱们每天用的软件,本质上就分两种“沟通模式”:

  • CS架构(Client-Server):客户端-服务器

✨ 通俗说:就是要先装APP才能用的软件,比如QQ、微信、玩的《命运2》都属于这类。

❌ 缺点:得安装、对手机/电脑配置有要求、每次更新还得手动点升级,麻烦!

  • BS架构(Browser-Server):浏览器-服务器

✨ 通俗说:不用装任何东西,打开浏览器就能用,比如CSDN、百度、淘宝网页版。

✅ 优点:零安装、低配电脑也能跑、服务器端更新后咱们直接用,完全无感!

2. Tomcat:Web开发的“小管家” 💻

写Java Web程序,绕不开Tomcat,咱们先把它摸透:

(1)为啥非要用Tomcat?

浏览器自己没法直接和MySQL数据库打交道,得靠“中间人”——Tomcat(里面跑Servlet),流程是:

浏览器 → Tomcat(Servlet) → JDBC → MySQL

就像你点外卖,没法直接找厨师,得靠外卖小哥(Tomcat)传需求~

(2)Tomcat是啥?

Apache和Sun(Java亲爹)联手开发的轻量级Web应用服务器,免费、小巧、够用,新手入门首选!

(3)Tomcat安装:解压即走

官网下载:https://tomcat.apache.org/

下载后解压到任意目录(别带中文路径!),就算安装完成,主打一个简单粗暴~

(4)Tomcat目录结构:每个文件夹都有使命

目录名

作用

bin

启动/关闭脚本(startup.bat、shutdown.bat)

conf

配置文件(比如改端口、设置账号密码)

lib

Tomcat依赖的jar包,别乱删!

logs

运行日志,程序报错先看这里

webapps

发布WAR包的地方,把写好的Web程序仍这就能运行

work

Tomcat编译JSP的临时文件,删了也没事,重启会重新生成

(5)启动&关闭:双击搞定
  • 启动:双击bin/startup.bat,弹出黑窗口不闪退就成功(闪退大概率是没配JAVA_HOME);

  • 关闭:双击bin/shutdown.bat,或者直接关黑窗口(不推荐,容易丢数据)。

3. WAR包:Web应用的“打包快递” 📦

写好的Web程序要部署到Tomcat,得打成WAR包,它的核心结构长这样:

4. HTTP协议:浏览器和服务器的“聊天规则” 🗣️

浏览器和服务器沟通,得按固定规则来,这个规则就是HTTP协议,分“请求”和“响应”两部分:

(1)浏览器给服务器发请求(Request)
  • 请求行:核心指令,比如GET /order HTTP/1.1(意思:用GET方式要/order这个资源,用HTTP1.1协议);

  • 请求头:额外说明,比如Accept: application/json(告诉服务器:我只接受JSON格式的数据);

  • 请求体:业务数据,比如name=zs&pwd=111(登录时传的账号密码)。

(2)服务器给浏览器回响应(Response)
  • 响应头:额外说明,比如Status: 200 OK(告诉浏览器:请求成功了);

  • 响应体:具体内容,比如网页的HTML代码、JSON数据(咱们看到的页面内容都在这)。

二、Servlet入门:手写第一个HelloServlet 👨💻

讲完概念,直接上手写代码!Servlet本质是运行在Tomcat上的Java程序,咱们一步步来~

1. Servlet是啥?

Servlet = Server + Applet(服务器小程序),是Java写的、跑在Tomcat上的程序。

Tomcat和Servlet有个“契约”:所有Servlet都必须直接/间接实现Servlet接口,不然Tomcat不认!

2. 第一步:创建Web工程

以IDEA为例,操作超简单:

  1. 右键项目 → 选择add Framework support...

  2. 勾选Web Application→ 点击ok

  3. 把生成的web目录拖到main目录下,改名为webapp(规范!);

  4. 打开pom.xml,设置打包方式为war

<packaging>war</packaging>

3. 第二步:写第一个Servlet程序

(1)引入Servlet依赖

pom.xml里加Servlet API依赖(Tomcat本身带,但开发时要引入):

(2)编写HelloServlet类

创建com.hg.servlet包,写实现Servlet接口的类:

(3)配置web.xml(关键!)

webapp/WEB-INF下找到web.xml,配置Servlet映射(告诉Tomcat:哪个URL对应哪个Servlet):

4. 运行测试

  1. 启动Tomcat,把项目部署上去;

  2. 打开浏览器,访问http://localhost:8080/你的项目名/hello

  3. 看到页面显示🎉 恭喜!第一个Servlet跑起来了!,就成功啦!

✨ 新手避坑小贴士

  1. 启动Tomcat闪退:检查是否配置了JAVA_HOME环境变量;

  2. 访问404:检查web.xml里的url-pattern和类路径是否写错;

  3. 中文乱码:一定要在service方法里加response.setContentType("text/html;charset=utf-8")

总结

  1. Web开发核心架构分CS(需安装)和BS(浏览器访问),Servlet属于BS架构的后端核心;

  2. Tomcat是轻量级Web服务器,核心目录要记清,启动关闭双击bat即可;

  3. 写Servlet的核心步骤:建Web工程→引依赖→写Servlet类→配置web.xml,关键是web.xmlurl-patternServlet类的映射。

跟着这篇教程走,新手也能快速搞定Servlet入门~如果有问题,评论区见👇

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/10 15:40:23

C++ 17 详细特性解析(4)

std::variant std::variant 是 C17 标准库中加入的一个类模板&#xff0c;它代表一个类型安全的联合体&#xff08;union&#xff09;。它可以持有其模板参数列表中指定的任何一种类型的值。我们也不叫他联合体了&#xff0c;常说的便是“变体” &#x1f517; 参考&#xff…

作者头像 李华
网站建设 2026/4/18 2:02:42

基于Springboot+Vue的乡镇卫生所医用物资进销存系统源码文档部署文档代码讲解等

课题介绍 本课题旨在设计并实现一套基于SpringBootVue的乡镇卫生所医用物资进销存系统&#xff0c;解决当前乡镇卫生所医用物资采购无序、库存管控混乱、出入库登记繁琐、物资过期预警不足等问题&#xff0c;适配乡镇卫生所医用物资精细化管理的核心需求。系统采用前后端分离架…

作者头像 李华
网站建设 2026/4/18 2:05:34

MAVLink 通信协议 C++ 开发实战:从环境搭建到飞控通信全解析

前言 MAVLink&#xff08;Micro Air Vehicle Link&#xff09;是一款轻量级、低带宽、高可靠性的微小型无人机通信协议&#xff0c;由 PX4 团队主导设计&#xff0c;广泛应用于无人机、无人车、机器人等嵌入式系统的跨设备通信场景。其核心优势在于专为资源受限的硬件&#xf…

作者头像 李华
网站建设 2026/4/18 1:59:18

告别传统RAG的痛点!Agent Skills让知识库检索更智能(本地知识库搭建新思路:用Agent Skills实现渐进式检索)

文章目录 📖 介绍 📖 🏡 演示环境 🏡 📒 Agent Skills在知识库检索中的实践探索 📒 📝 传统RAG的局限性 📝 Agent Skills的核心设计理念 🎯 分层索引导航 🎯 先学习,再处理 🎯 渐进式检索 📝 实际应用场景对比 场景一:查询AI行业趋势 场景二:分析电…

作者头像 李华
网站建设 2026/4/18 1:57:22

基于multisim的波形发生与变换电路设计

设计正弦波振荡电路&#xff0c;要求产生1KHz的正弦波&#xff0c;并将1KHz的正弦波转换成1kHz的方波和三角波。 仿真图&#xff1a; 仿真演示与文件下载&#xff1a;基于multisim的波形发生与变换电路设计演示视频_哔哩哔哩_bilibili

作者头像 李华
网站建设 2026/4/18 1:59:41

淘宝评论数据采集 API 全解析【淘宝评论API】

一、官方 API 方案 1.1 核心接口概览 淘宝开放平台 (TOP) 提供的官方评论数据接口主要有以下 3 个&#xff0c;权限申请门槛较高&#xff0c;仅对企业 / 店铺商家开放&#xff0c;个人开发者无法申请&#xff1a; 接口名称功能描述适用场景taobao.item.review.get获取淘宝商…

作者头像 李华