96SEO 2026-02-19 22:26 0
使用Servlet就可以实现#xff0c;根据不同的登录用户在页面上动态显示不同内容。

Servlet是JavaEE规范之一#xff0c;其实就是一个接口#xff0c;将来我们需要定义…Servlet
Servlet是JavaWeb最为核心的内容它是Java提供的一门动态web资源开发技术。
使用Servlet就可以实现根据不同的登录用户在页面上动态显示不同内容。
Servlet是JavaEE规范之一其实就是一个接口将来我们需要定义Servlet类实现Servlet接口并由web服务器运行Servlet
介绍完Servlet是什么以后接下来我们就按照快速入门-执行流程-生命周期-体系结构-urlPattern配置-XML配置的学习步骤一步步完成对Servlet的知识学习首选我们来通过一个入门案例来快速把Servlet用起来。
编写一个Servlet类并使用IDEA中Tomcat插件进行部署最终通过浏览器访问所编写的Servlet程序。
dependencygroupIdjavax.servlet/groupIdartifactIdjavax.servlet-api/artifactIdversion3.1.0/version!--此处为什么需要添加该标签?provided指的是在编译和测试过程中有效,最后生成的war包时不会加入因为Tomcat的lib目录中已经有servlet-api这个jar包如果在生成war包的时候生效就会和Tomcat中的jar包冲突导致报错--scopeprovided/scope
/dependency创建:定义一个类实现Servlet接口并重写接口中所有方法并在service方法中输入一句话
}配置:在类上使用WebServlet注解配置该Servlet的访问路径
WebServlet(/demo1)访问:启动Tomcat,浏览器中输入URL地址访问该Servlet
http://localhost:8080/web-demo/demo1器访问后在控制台会打印servlet
至此Servlet的入门案例就已经完成大家可以按照上面的步骤进行练习了。
我们并没有创建ServletDemo1类的对象也没有调用对象中的service方法为什么在控制台就打印了servlet
要想回答上述问题我们就需要对Servlet的执行流程进行一个学习。
浏览器发出http://localhost:8080/web-demo/demo1请求从请求中可以解析出三部分内容分别是localhost:8080、web-demo、demo1
Web服务器根据web-demo可以找到部署在Tomcat服务器上的web-demo项目根据demo1可以找到要访问的是项目中的哪个Servlet类根据WebServlet后面的值进行匹配
Web服务器就会为ServletDemo1这个类创建一个对象然后调用对象中的service方法
ServletDemo1实现了Servlet接口所以类中必然会重写service方法供Tomcat
Web服务器进行调用service方法中有ServletRequest和ServletResponse两个参数ServletRequest封装的是请求数据ServletResponse封装的是响应数据后期我们可以通过这两个参数实现前后端的数据交互
Servlet由web服务器创建Servlet方法由web服务器调用
因为我们自定义的Servlet,必须实现Servlet接口并复写其方法而Servlet接口中有service方法
介绍完Servlet的执行流程后我们知道Servlet是由Tomcat
接下来咱们再来思考一个问题:Tomcat什么时候创建的Servlet对象?
要想回答上述问题我们就需要对Servlet的生命周期进行一个学习。
Servlet运行在Servlet容器(web服务器)中其生命周期由容器来管理分为4个阶段
加载和实例化默认情况下当Servlet第一次被访问时由容器创建Servlet对象
默认情况Servlet会在第一次访问被容器创建但是如果创建Servlet比较耗时的话那么第一个访问的人等待的时间就比较长用户的体验就比较差那么我们能不能把Servlet的创建放到服务器启动的时候来创建具体如何来配置?WebServlet(urlPatterns
loadOnstartup的取值有两类情况1负整数:第一次访问时创建Servlet对象20或正整数:服务器启动时创建Servlet对象数字越小优先级越高初始化在Servlet实例化之后容器将调用Servlet的init()方法初始化这个对象完成一些如加载配置文件、创建连接等初始化的工作。
该方法只调用一次请求处理每次请求Servlet时Servlet容器都会调用Servlet的service()方法对请求进行处理服务终止当需要释放内存或者容器关闭时容器就会调用Servlet实例的destroy()方法完成资源的释放。
在destroy()方法调用之后容器会释放这个Servlet实例该实例随后会被Java的垃圾收集器所回收
javax.servlet.annotation.WebServlet;
{System.out.println(init...);}/***
1.调用时机内存释放或者服务器关闭的时候Servlet对象会被销毁调用*
{System.out.println(destroy...);}public
null;}}注意:如何才能让Servlet中的destroy方法被执行
tomcat7:run启动然后再使用ctrlc关闭tomcat
默认是第一次访问的时候被创建可以使用WebServlet(urlPatterns
Servlet生命周期中涉及到的三个方法这三个方法是什么?什么时候被调用?调用几次?
service方法在Servlet被访问的时候调用每访问1次就调用1次
destroy方法在Servlet对象被销毁的时候调用只执行1次
Servlet中总共有5个方法我们已经介绍过其中的三个剩下的两个方法作用分别是什么
res)销毁方法当Servlet被销毁时调用该方法。
在内存释放或服务器关闭时销毁Servlet
//该方法用来返回Servlet的相关信息没有什么太大的用处一般我们返回一个空字符串即可
getServletConfig()ServletConfig对象在init方法的参数中有而Tomcat
Web服务器在创建Servlet对象的时候会调用init方法必定会传入一个ServletConfig对象我们只需要将服务器传过来的ServletConfig进行返回即可。
具体如何操作?
javax.servlet.annotation.WebServlet;
config;System.out.println(init...);}public
1.调用时机内存释放或者服务器关闭的时候Servlet对象会被销毁调用*
{System.out.println(destroy...);}public
}getServletInfo()和getServletConfig()这两个方法使用的不是很多大家了解下。
通过上面的学习我们知道要想编写一个Servlet就必须要实现Servlet接口重写接口中的5个方法虽然已经能完成要求但是编写起来还是比较麻烦的因为我们更关注的其实只有service方法那有没有更简单方式来创建Servlet呢?
要想解决上面的问题我们需要先对Servlet的体系结构进行下了解:
因为我们将来开发B/S架构的web项目都是针对HTTP协议所以我们自定义Servlet,会通过继承HttpServlet
请求方式处理逻辑System.out.println(get...);}Overrideprotected
请求方式处理逻辑System.out.println(post...);}
}要想发送一个GET请求请求该Servlet只需要通过浏览器发送http://localhost:8080/web-demo/demo4,就能看到doGet方法被执行了要想发送一个POST请求请求该Servlet单单通过浏览器是无法实现的这个时候就需要编写一个form表单来发送请求在webapp下创建一个a.html页面内容如下:
HttpServlet中为什么要根据请求方式的不同调用不同的方法?如何调用?
针对问题一我们需要回顾之前的知识点前端发送GET和POST请求的时候参数的位置不一致GET请求参数在请求行中POST请求参数在请求体中为了能处理不同的请求方式我们得在service方法中进行判断然后写不同的业务处理这样能实现但是每个Servlet类中都将有相似的代码针对这个问题有什么可以优化的策略么?
javax.servlet.annotation.WebServlet;
javax.servlet.http.HttpServlet;
javax.servlet.http.HttpServletRequest;
javax.servlet.http.HttpServletResponse;
java.io.IOException;WebServlet(/demo5)
{//如何调用?//获取请求方式根据不同的请求方式进行不同的业务处理HttpServletRequest
要解决上述问题我们可以对Servlet接口进行继承封装来简化代码开发。
javax.servlet.http.HttpServletRequest;
post方式的处理逻辑doPost(req,res);}}protected
有了MyHttpServlet这个类以后我们再编写Servlet类的时候只需要继承MyHttpServlet重写父类中的doGet和doPost方法就可以用来处理GET和POST请求的业务逻辑。
接下来可以把ServletDemo5代码进行改造
{System.out.println(get...);}Overrideprotected
将来页面发送的是GET请求则会进入到doGet方法中进行执行如果是POST请求则进入到doPost方法。
这样代码在编写的时候就相对来说更加简单快捷。
类似MyHttpServlet这样的类Servlet中已经为我们提供好了就是HttpServlet,翻开源码大家可以搜索service()方法你会发现HttpServlet做的事更多不仅可以处理GET和POST还可以处理其他五种请求方式。
req.getDateHeader(HEADER_IFMODSINCE);if
{resp.setStatus(HttpServletResponse.SC_NOT_MODIFIED);}}}
getLastModified(req);maybeSetLastModified(resp,
(method.equals(METHOD_OPTIONS))
lStrings.getString(http.method_not_implemented);Object[]
errArgs);resp.sendError(HttpServletResponse.SC_NOT_IMPLEMENTED,
Servlet类编写好后要想被访问到就需要配置其访问路径urlPattern
javax.servlet.annotation.WebServlet;/**
}在浏览器上输入http://localhost:8080/web-demo/demo7,http://localhost:8080/web-demo/demo8这两个地址都能访问到ServletDemo7的doGet方法。
访问路径http://localhost:8080/web-demo/user/select目录匹配
javax.servlet.annotation.WebServlet;/***
访问路径http://localhost:8080/web-demo/user/任意思考:1.
访问路径http://localhost:8080/web-demo/user是否能访问到demo9的doGet方法?
访问路径http://localhost:8080/web-demo/user/a/b是否能访问到demo9的doGet方法?
访问路径http://localhost:8080/web-demo/user/select是否能访问到demo9还是demo8的doGet方法?答案是:
能、能、demo8进而我们可以得到的结论是/user/*中的/*代表的是零或多个层级访问匹配。
扩展名匹配
javax.servlet.annotation.WebServlet;/***
访问路径http://localhost:8080/web-demo/任意.do注意:1.
如果路径配置的不是扩展名那么在路径的前面就必须要加/否则会报错2.
如果路径配置的是*.do,那么在*.do的前面不能加/,否则会报错任意匹配
javax.servlet.annotation.WebServlet;/***
访问路径http://localhost:8080/demo-web/任意java
javax.servlet.annotation.WebServlet;/***
}访问路径http://localhost:8080/demo-web/任意注意:/和/*的区别?1.
/,会覆盖掉tomcat中的DefaultServlet,当其他的url-pattern都匹配不上时都会走这个Servlet2.
DefaultServlet是用来处理静态资源如果配置了/会把默认的覆盖掉就会引发请求静态资源的时候没有走默认的而是走了自定义的Servlet类最终导致静态资源不能被访问小结
前面对应Servlet的配置我们都使用的是WebServlet,这个是Servlet从3.0版本后开始支持注解配置3.0版本前只支持XML配置文件的配置方法。
javax.servlet.annotation.WebServlet;public
xmlnshttp://xmlns.jcp.org/xml/ns/javaeexmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsdversion4.0!--
servlet的名称名字任意--servlet-namedemo13/servlet-name!--servlet的类全名--servlet-classcom.itheima.web.ServletDemo13/servlet-class/servlet!--
servlet的名称要和上面的名称一致--servlet-namedemo13/servlet-name!--
servlet的访问路径--url-pattern/demo13/url-pattern/servlet-mapping
/web-app这种配置方式和注解比起来确认麻烦很多所以建议大家使用注解来开发。
但是大家要认识上面这种配置方式因为并不是所有的项目都是基于注解开发的。
感谢大家的阅读文章通过网络资源与自己的学习过程整理出来希望大家多多支持。
才疏学浅难免会有纰漏如果你发现了错误的地方可以提出来我对其加以修改。
作为专业的SEO优化服务提供商,我们致力于通过科学、系统的搜索引擎优化策略,帮助企业在百度、Google等搜索引擎中获得更高的排名和流量。我们的服务涵盖网站结构优化、内容优化、技术SEO和链接建设等多个维度。
| 服务项目 | 基础套餐 | 标准套餐 | 高级定制 |
|---|---|---|---|
| 关键词优化数量 | 10-20个核心词 | 30-50个核心词+长尾词 | 80-150个全方位覆盖 |
| 内容优化 | 基础页面优化 | 全站内容优化+每月5篇原创 | 个性化内容策略+每月15篇原创 |
| 技术SEO | 基本技术检查 | 全面技术优化+移动适配 | 深度技术重构+性能优化 |
| 外链建设 | 每月5-10条 | 每月20-30条高质量外链 | 每月50+条多渠道外链 |
| 数据报告 | 月度基础报告 | 双周详细报告+分析 | 每周深度报告+策略调整 |
| 效果保障 | 3-6个月见效 | 2-4个月见效 | 1-3个月快速见效 |
我们的SEO优化服务遵循科学严谨的流程,确保每一步都基于数据分析和行业最佳实践:
全面检测网站技术问题、内容质量、竞争对手情况,制定个性化优化方案。
基于用户搜索意图和商业目标,制定全面的关键词矩阵和布局策略。
解决网站技术问题,优化网站结构,提升页面速度和移动端体验。
创作高质量原创内容,优化现有页面,建立内容更新机制。
获取高质量外部链接,建立品牌在线影响力,提升网站权威度。
持续监控排名、流量和转化数据,根据效果调整优化策略。
基于我们服务的客户数据统计,平均优化效果如下:
我们坚信,真正的SEO优化不仅仅是追求排名,而是通过提供优质内容、优化用户体验、建立网站权威,最终实现可持续的业务增长。我们的目标是与客户建立长期合作关系,共同成长。
Demand feedback