Java Web学习笔记-Servle生命周期
Servlet会在服务器启动或第一次请求该Servlet的时候开始生命周期,在服务器停止的时候结束生命周期.
无论请求多少次Servlet,最多只有一个Servlet实例.多个客户端并发请求Servlet时,服务器会启动多个线程分别执行该Servlet的service()方法.
package com.helloxr.servlet; import java.io.IOException;
import java.io.PrintWriter; import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; public class LifeCycleServlet extends HttpServlet { /**
*
*/
private static final long serialVersionUID = 9898777879L;
public static double startPoint = 0; /**
* Constructor of the object.
*/
public LifeCycleServlet() {
super();
} /**
* Destruction of the servlet. <br>
*/
public void destroy() {
this.log("执行 destroy方法 ...");
startPoint = 0;
} /**
* The doGet method of the servlet. <br>
*
* This method is called when a form has its tag value method equals to get.
*
* @param request the request send by the client to the server
* @param response the response send by the server to the client
* @throws ServletException if an error occurred
* @throws IOException if an error occurred
*/
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { this.log("执行 doGet() 方法 ...");
response.setCharacterEncoding("UTF-8");
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">");
out.println("<HTML>");
out.println(" <HEAD><TITLE>个人所得税计算</TITLE></HEAD>");
out.println("<link rel='stylesheet' type='text/css' href='../css/style.css'>");
out.println(" <BODY>");
out.println("<div align='center'><br/><fieldset style='width:90%'><legend>个税计算器</legend><br/>");
out.println("<form method='post'>"); out.println("<div style='line'>");
out.println(" <div class='leftDiv'>您的工资为</div><div align='left' class='rightDiv'><input type='text' name='income'>单位:元<div>");
out.println("</div><br/>"); out.println("<div style='line'");
out.println(" <div class='leftDiv'></div><div align='left' class='rightDiv'><input type='submit' value=' 计算个税 ' class=button></div>");
out.println("</div>");
out.println("</form>");
out.println(" </BODY>");
out.println("</HTML>");
out.flush();
out.close();
} /**
* The doPost method of the servlet. <br>
*
* This method is called when a form has its tag value method equals to post.
*
* @param request the request send by the client to the server
* @param response the response send by the server to the client
* @throws ServletException if an error occurred
* @throws IOException if an error occurred
*/
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { this.log("执行 doPost() 方法 ...");
response.setCharacterEncoding("UTF-8");
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.println("<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">");
out.println("<HTML>");
out.println(" <HEAD><TITLE>个人所得税计算</TITLE></HEAD>");
out.println("<link rel='stylesheet' type='text/css' href='../css/style.css'>");
out.println(" <BODY>");
out.println("<div align='center'><br/>");
out.println("<fieldset style='width:90%'><legend>个税计算器</legend><br/>"); try{
double income = new Double(request.getParameter("income")); double charge = income - startPoint;
double tax = 0; if(charge <= 0) {tax = 0;}
if(charge > 0 && charge <= 500) {tax = charge * 0.05;}
if(charge > 500 && charge <= 2000) {tax = charge * 0.1 - 25;}
if(charge > 2000 && charge <= 5000) {tax = charge * 0.15 - 125;}
if(charge > 5000 && charge <= 20000) {tax = charge * 0.2 - 375;}
if(charge > 20000 && charge <= 40000) {tax = charge * 0.25 - 1375;}
if(charge > 40000 && charge <= 60000) {tax = charge * 0.30 - 3375;}
if(charge > 60000 && charge <= 80000) {tax = charge * 0.35 - 6375;}
if(charge > 80000 && charge <= 100000) {tax = charge * 0.4 - 10375;}
if(charge > 100000) {tax = charge * 0.45 - 15375;} out.println("<div style='line'>");
out.println(" <div class='leftDiv'>您的工资为</div><div class='rightDiv'>" + income + " 元</div>");
out.println("</div>");
out.println("<div style='line'>");
out.println(" <div class='leftDiv'>您应纳税</div><div class='rightDiv'>" + tax + "元</div> ");
out.println("</div><br/>");
out.println("<input type='button' onclick='history.go(-1);' value='纳税光荣 逃税可耻 返回' class=button>"); }catch(Exception e){
out.println("请输入数值类型数据.<input type='button' onclick='history.go(-1);' value='返回' class=button>");
}
out.println(" </BODY>");
out.println("</HTML>");
out.flush();
out.close();
} /**
* Initialization of the servlet. <br>
*
* @throws ServletException if an error occurs
*/
@Override
public void init() throws ServletException {
this.log("执行 init() 方法 ...");
ServletConfig config = this.getServletConfig();
startPoint = Double.parseDouble(config.getInitParameter("startPoint"));
}
@Override
protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException,IOException{
this.log("执行 service() 方法 ...");
super.service(request, response);
} }
web.xml的配置如下:
<servlet>
<servlet-name>LifeCycleServlet</servlet-name>
<servlet-class>com.helloxr.servlet.LifeCycleServlet</servlet-class>
<init-param>
<param-name>startPoint</param-name>
<param-value>1600</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>LifeCycleServlet</servlet-name>
<url-pattern>/servlet/LifeCycleServlet</url-pattern>
</servlet-mapping>
Tomcat控制台的部分输出:
一月 07, 2017 10:28:35 下午 org.apache.catalina.core.ApplicationContext log
信息: LifeCycleServlet: 执行 init() 方法 ...
一月 07, 2017 10:28:35 下午 org.apache.catalina.core.ApplicationContext log
信息: LifeCycleServlet: 执行 service() 方法 ...
一月 07, 2017 10:28:35 下午 org.apache.catalina.core.ApplicationContext log
信息: LifeCycleServlet: 执行 doGet() 方法 ...
一月 07, 2017 10:29:03 下午 org.apache.catalina.core.ApplicationContext log
信息: LifeCycleServlet: 执行 service() 方法 ...
一月 07, 2017 10:29:03 下午 org.apache.catalina.core.ApplicationContext log
信息: LifeCycleServlet: 执行 doPost() 方法 ...
一月 07, 2017 10:29:22 下午 org.apache.catalina.core.StandardServer await
信息: A valid shutdown command was received via the shutdown port. Stopping the Server instance.
一月 07, 2017 10:29:22 下午 org.apache.coyote.AbstractProtocol pause
信息: Pausing ProtocolHandler ["http-apr-8080"]
一月 07, 2017 10:29:22 下午 org.apache.coyote.AbstractProtocol pause
信息: Pausing ProtocolHandler ["ajp-apr-8009"]
一月 07, 2017 10:29:22 下午 org.apache.catalina.core.StandardService stopInternal
信息: Stopping service Catalina
一月 07, 2017 10:29:22 下午 org.apache.catalina.core.ApplicationContext log
信息: SessionListener: contextDestroyed()
一月 07, 2017 10:29:22 下午 org.apache.catalina.core.ApplicationContext log
信息: ContextListener: contextDestroyed()
一月 07, 2017 10:29:22 下午 org.apache.catalina.core.ApplicationContext log
信息: LifeCycleServlet: 执行 destroy方法 ...
一月 07, 2017 10:29:22 下午 org.apache.coyote.AbstractProtocol stop
信息: Stopping ProtocolHandler ["http-apr-8080"]
一月 07, 2017 10:29:23 下午 org.apache.coyote.AbstractProtocol stop
信息: Stopping ProtocolHandler ["ajp-apr-8009"]
一月 07, 2017 10:29:23 下午 org.apache.coyote.AbstractProtocol destroy
信息: Destroying ProtocolHandler ["http-apr-8080"]
一月 07, 2017 10:29:23 下午 org.apache.coyote.AbstractProtocol destroy
信息: Destroying ProtocolHandler ["ajp-apr-8009"]
LifeCycleServlet运行效果:
Java Web学习笔记-Servle生命周期的更多相关文章
- [原创]java WEB学习笔记95:Hibernate 目录
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...
- Java Web学习笔记之---JSP
Java Web学习笔记之---JSP (一)JSP常用语法 (1)HTML注释 <!--所要注释的内容 --> 在客户端显示一个注释. (2)隐藏注释 <%--所要注释的内容--% ...
- [原创]java WEB学习笔记75:Struts2 学习之路-- 总结 和 目录
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...
- [原创]java WEB学习笔记66:Struts2 学习之路--Struts的CRUD操作( 查看 / 删除/ 添加) 使用 paramsPrepareParamsStack 重构代码 ,PrepareInterceptor拦截器,paramsPrepareParamsStack 拦截器栈
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...
- java web 学习笔记 编码问题总结
java web 学习笔记 编码问题总结 1.非form表单中提交的中文参数---------------------------传递给Servlet服务器时,默认以iso-8859-1解码 ...
- Java Web 学习笔记 1
Java Web 学习笔记 1 一.Web开发基础 1-1 Java Web 应用开发概述 1.1.1 C/S C/S(Client/Server)服务器通常采用高性能的PC机或工作站,并采用大型数据 ...
- [原创]java WEB学习笔记11:HttpServlet(HttpServletRequest HttpServletRsponse) 以及关于 Servlet 小结
本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...
- Java Web学习笔记之---EL和JSTL
Java Web学习笔记之---EL和JSTL (一)EL (1)EL作用 Expression Language(表达式语言),目的是代替JSP页面中复杂的代码 (2)EL表达式 ${变量名} ( ...
- JAVA Web学习笔记
JAVA Web学习笔记 1.JSP (java服务器页面) 锁定 本词条由“科普中国”百科科学词条编写与应用工作项目 审核 . JSP全名为Java Server Pages,中文名叫java服务器 ...
随机推荐
- oracle job有定时执行的功能,可以在指定的时间点或每天的某个时间点自行执行任务。
来源于:http://www.cnblogs.com/wangfg/p/5110831.html 一.查询系统中的job,可以查询视图 --相关视图 select * from dba_jobs; s ...
- Gson解析json数据
1.解析单个对象 JSON字符串如下 [ { "formatDate":"2015-10-28", "date":"2015\u5 ...
- 转载--web前端35个jQuery小技巧!
1. 禁止右键点击$(document).ready(function(){ $(document).bind("contextmenu",function(e){ ...
- Java 测试代码模板
package com.robert.service; import org.apache.commons.logging.Log; import org.apache.commons.logging ...
- 【ASP.NET Identity系列教程(三)】Identity高级技术
注:本文是[ASP.NET Identity系列教程]的第三篇.本系列教程详细.完整.深入地介绍了微软的ASP.NET Identity技术,描述了如何运用ASP.NET Identity实现应用程序 ...
- js-回车事件控制
1.文本框回车时间 < script type = "text/javascript" language = "javascript" > fun ...
- Thinking in java学习笔记之初始化
1.基本数据类型:类的每个基本数据类型保证有一个初值(char为0输出则是空白) 2.构造器: 3.静态初始化顺序示例及总结 4.非静态初始化顺序 4.数组
- BZOJ 1142: [POI2009]Tab
1142: [POI2009]Tab Time Limit: 40 Sec Memory Limit: 162 MBSubmit: 213 Solved: 80[Submit][Status][D ...
- 【BZOJ-2599】Race 点分治
2599: [IOI2011]Race Time Limit: 70 Sec Memory Limit: 128 MBSubmit: 2590 Solved: 769[Submit][Status ...
- javaScript与MVC
MVC,就是Module,View,Controller分离,使业务逻辑更加清晰,但是现在公司的项目中很多地方那个不是这样的,很多业务逻辑放在了javascript中实现,这样做的优点就是对于技术要求 ...