博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Servlet学习笔记(1)--第一个servlet&&三种状态对象(cookie,session,application)&&Servlet的生命周期...
阅读量:6395 次
发布时间:2019-06-23

本文共 6807 字,大约阅读时间需要 22 分钟。

servlet的404错误困扰了两天,各种方法都试过了,翻书逛论坛终于把问题解决了,写此博客来纪念自己的第一个servlet经历。

下面我会将自己的编写第一个servlet的详细过程提供给初学者,大神们可以自动过滤掉。下面的步骤有这样的前提:你的eclipse嵌入了TomCat插件(我们会在Eclipse上操作servlet)或者本地主机已经有安装好某一个版本的TomCat,我这里用的是Tomcat7.0.69.

第一步:创建Dynamic Web Project

Eclipse下->new->other->web->Dynamic Web Project,名称我们就叫TestServlet2

TargetRuntime这个选项,如果你是第一次使用Tomcat的话应该还没有配置,选择右边的New Runtime会出现下面的页面:

我选择的是v7.0,因为我电脑上装的就是v7.0.69;

Configuration右面的选项Modify:我们暂时只需要Dynamic和Java两项就可以,把那个JavaScript前面的勾去掉,点击Ok;

点击next:

src是我们源代码的目录位置,下面的Default output folder是我们源代码编译之后的.class文件的输出位置,我们这里改成WEB-INF/classes(为了与我们把应用发布到TomCat的webapps下的目录一致,方便理解,此时我们的build目录就没啥用了,等下它自动生成的时候就可以删除了);

继续点击next:

直接默认就可以了,Context root是我们web应用的主目录,Context directory是我们存放JSP文件其他文件的,里面包括两个文件夹META-INF和WEB-INF,最后勾选自动配置web.xml文件;

现在的项目目录如下图所示:

第二步:写我们的servlet

在src目录下新建一个class,类名就叫做HelloWorldServlet,添加一个包:com.ysw.servlet

在HelloWorldServlet中添加如下代码:我们这里用extends HttpServlet的方式来编写,其他两种方式大家可以自己Google一下;

1 package com.ysw.servlet; 2  3 import java.io.IOException; 4  5 import javax.servlet.ServletException; 6 import javax.servlet.http.HttpServlet; 7 import javax.servlet.http.HttpServletRequest; 8 import javax.servlet.http.HttpServletResponse; 9 10 public class HelloWorldServlet extends HttpServlet {11 12     private static final long serialVersionUID = 1L;13 14     @Override15     protected void doGet(HttpServletRequest request,16             HttpServletResponse response) throws ServletException, IOException {17         System.out.println("doGet");18     }19 }

实现的简单功能是在我们Eclipse的控制台打印"doGet"字符串;

第三步:配置文件web.xml

1 
6 7
8
This is the description of my J2EE component
9
This is the display name of my J2EE component
10
HW
11
com.ysw.servlet.HelloWorldServlet2
12
13
14
HW
15
/abc
16
17
18
20
19
20

在我们的WEB-INF目录下有一个web.xml文件,我们在其中添加如下内容:每一个标签代表啥意思大家自己查一下,学习的过程是痛并快乐着;

我还是说一下吧:<servlet-name>是给我们的servlet起一个名字,可以是任意的;<servlet-class>指向我们要注册的servlet的类地址,这里一定要注意:如果你的程序使用了包,比如我的程序中的包名是com.ysw.servlet

<servlet-mapping>中的servlet-name与我们上面定义的<servlet>中的那个<servelt-name>一定要一致;<url-pattern>意思是我们在浏览器中输入/abc这种形式就能访问到Tomcat上相应的资源

第四步:修改Project下的.class文件

在我的电脑上是这样的:

编辑.classpath文件,将<classpathentry kind="output" path="build/classes"/>这一项中的path改成我们前面已经说过的WEB-INF/classes目录,即:<classpathentry kind="output" path="WEB-INF/classes"/>保存退出;

【重要的一步】:右键工程(TestServlet2)->Build Project,eclipse一般默认都是自动编译代码,只要你的代码修改后保存,eclipse是会自动编译成class文件的。但如果你修改过配置,eclipse不是自动编译方式,那么就要点击这个build project选项手动把代码编译成class文件了。

第五步:在Tomcat上运行我们的servlet

点击以后出现下面的界面:选择我们先前配置的相应版本的Tomcat7.0.69,你的机器因人而异

点击->next,会让我们选择要运行的servlet,将要运行的servley移动到右面区域,点击->finashed这是就可以从控制台开到Tomcat的启动,

你看到的是这样的情况:

【没有消息就是最好的消息】:最下面切换到console这一视图,刷新一下我们上图的那个浏览器,我们可以看到:

可以看到我们的打印输出信息;

第六步:将我们的web应用部署到Tomcat服务器

在Tomcat的webapps目录下新建一个名称为myWebSite的文件夹,这个文件夹就是我们web应用的根目录。在myWebSite内新建一个名称叫做WEB-INF(这个名称是固定的,不能用其他名称),然后在WEB-INF文件夹内新建一个名称为classes的文件夹,用于存放我们编译好的.class文件,在WEB-INF文件夹内还有一个文件,就是我们前面提到的web.xml文件,直接放在这个位置就可以了.

在class文件夹下放我们编译好的class文件,其实只要把我们在的工程TestServlet2下的WEB-INF下的class文件夹拷贝过来就行(这个时候我们在前面的操作:<classpathentry kind="output" path="WEB-INF/classes"/>),

在这里就方便我们的应用发布了,因为我程序中用到了包com.ysw.servlet,因此class文件下也包括了各级目录;

接下来就是要用浏览器访问我们的servlet:首先要关闭掉Eclipse中我们之前一直运行的TomCat服务,否则我们在cmd下无法启动TomCat;

启动服务以后可以清楚的看到我们的应用得到了配置和部署:

在浏览器下我们输入:

可以看到:doGet得以输出,至此我的第一个Servlet完成!

cookie,session,application的区别:这部分转载自:

Cookie:   ①存在于客户端(可被阻止)  ②只能是文本文档   ③如果设置了期限值,则写入客户端的文件;   如果没有,它只对本窗口或其子窗口有效,其它窗口不能访问该Cookie   ④在Servlet/JSP中设置的Cookie可以被同路径下或其子路径的Servlet/JSP访问,父路径不可以   ○注:这里的路径是指URL,而不是Web文件的目录 Session:   ①存在于服务器端  ②每个Session对应一个窗口,用SessionID标识,这个Session为该窗口及其子窗口共享   ③有两种实现方式:a.使用Cookie(在Cookie可用时)b.URL重写(在Cookie被禁用时)   ④没有访问路径的问题。同一个WebApplication下的Servlet/JSP设置的Session可以被互相访问   前提是:同一个浏览器窗口或其子窗口 Application:  与一个Web应用程序相对应,该应用程序下所有的Servlet/JSP共用该Application中的信息(ServletContext)1、session保存在服务器,客户端不知道其中的信息;cookie保存在客户端,服务器能够知道其中的信息。      2、session中保存的是对象,cookie中保存的是字符串。      3、session不能区分路径,同一个用户在访问一个网站期间,所有的session在任何一个地方都可以访问到。而cookie中如果设置了路径参数,那么同一个网站中不同路径下的cookie互相是访问不到的。      4、session需要借助cookie才能正常工作。如果客户端完全禁止cookie,session将失效。 但是如果服务器端启用了url编码,也就是用  URLEncoder.encode()把所有的url编码了,则会在url后面出现如下类似的东西  index.jsp:jsessionid=fdsaffjdlks;jaf;lkdjsf  服务器通过这个进行session的判断  5 session在用户会话结束后就会关闭了,但cookie因为保存在客户端,可以长期保存  Cookie存储的信息是放到客户端的,用户在访问服务器端页面时,必然在客户端和服务器端之间频繁交换信息,影响了程序的性能。而Session由于存储在服务器内存中,因此不存在这个问题。不过,Session存储的信息是临时的,用户一旦关闭浏览器,状态即失去。而Cookie则相反。COOKIE 是本地文件,是 40 大盗在阿里巴巴家做的记号,或者是送牛奶的人在你家门口钉的箱子。  Application状态为应用程序提供了一个全局的状态。所有客户都可以使用该状态。从设计的角度来说,我们通常用Application来存储一些标准的数据。同时,我们在使用它时要注意避免性能的降低,存储的数据尽可能提供给客户只读的功能。 APPLICATION 是公共浴池。在这里能看见所有人,包括 ppmm 哦:)。  Session和客户端的Cookie是有关的,当客户关掉Cookie时,Session就失效了,SESSION 是服务器端内存,是你洗澡时浴池发给你的钥匙。自己专用,可以开自己的好多箱子。Application:application是应用级别的,同一个应用中的所有用户将共享此对象。因此,我们利用application对象来存储一些坏境信息。Request:      Request也可以像Session那样使用,但是它第二次请求服务器页面时就失去存储功能了     request的范围只在一jsp页发出请求到另一页之间,随后这个属性失效;     session范围是用户和服务器连接的那段时间,用户与服务器断开属性就失效;     application作用范围最大,慎用,在服务器一开始执行服务到服务器关闭为止。可能造成服务器负载过重。

Servlet的生命周期

  * API中的生命周期:一个servlet只有一个对象(实例)
  * 1.加载(classLoader)将类加载进来
  * 2.实例化,new一个对象
  * 3.初始化:调用init(ServletConfig)方法
  * 4.处理请求:service doGet  doPost(http协议)
  * 5.退出服务:destory()
  * init():只执行一次
  * destory():
  * doGet():
  * service():

验证servlet的生命周期的代码:

1 package com.ysw.servlet; 2  3 import java.io.IOException; 4  5 import javax.servlet.ServletConfig; 6 import javax.servlet.ServletException; 7 import javax.servlet.http.HttpServlet; 8 import javax.servlet.http.HttpServletRequest; 9 import javax.servlet.http.HttpServletResponse;10 11 /**12  * 13  * @author Administrator14  *15  */16 public class TestLifeCycleServlet extends HttpServlet {17     18     /**19      * API中的生命周期:一个servlet只有一个对象(实例)20      * 1.加载(classLoader)将类加载进来21      * 2.实例化,new一个对象22      * 3.初始化:调用init(ServletConfig)方法23      * 4.处理请求:service doGet  doPost(http协议)24      * 5.退出服务:destory()25      * init():只执行一次26      * destory():27      * doGet():28      * service():29      */30     private static final long serialVersionUID = 1L;31     @Override32     public void destroy() {33         34         System.out.println("destory");35     }36 37 38     @Override39     protected void doGet(HttpServletRequest request, HttpServletResponse response)40             throws ServletException, IOException {41         42         System.out.println("doGet");43     }44 45     @Override46     public void init(ServletConfig config) throws ServletException {47         48         System.out.println("init");49     }50 51 52     public TestLifeCycleServlet() {53         System.out.println("constructor!");54     }55     56 57 }

 

你可能感兴趣的文章
Win10 安装msi 提示2502、2503的错误代码 -- 命令提示符(管理员) -- msiexec /package...
查看>>
组策略脚本的趣味应用
查看>>
corosync+pacemaker高可用集群
查看>>
景安河南机房电力事故,部分主机和云服务器停机
查看>>
1024x600 7" LVDS LCD with Capacitive Touch for pcD
查看>>
解决ubuntu系统安装完后启动项里没有ubuntu的问题
查看>>
Objective-C中new与alloc/init的区别
查看>>
手动编译Mysql5.6.10 手动编译php 支持fastcgi
查看>>
MySQL主主
查看>>
linux的权限管理以及特殊权限SUID,SGID,Sticky
查看>>
大数据测试之初识Hadoop2
查看>>
linux安装nginx
查看>>
ant 之传参数
查看>>
翻转单词顺序与左旋转字符串
查看>>
在Zf2中实现Controller按照URL自动注册
查看>>
批处理的变量引用
查看>>
oracle ORACLE_SID使用上的意义
查看>>
RHEL5下安装Xen
查看>>
2011百度之星初赛B圆环
查看>>
canvas绘制时钟
查看>>