一、定义Servlet:

public class HelloServlet extends HttpServlet {

@Override  protected void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

System.out.println("get method invoke");

PrintWriter out=response.getWriter();

out.print("hello, HTTP GET method!");

}

@Override  protected void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

System.out.println("post method invoke");

PrintWriter out=response.getWriter();

out.print("hello, HTTP POST method!");

}

}

 二、发布Servlet:


方法一:注解方式

@WebServlet(name = "HelloServlet", urlPatterns = {"/hello","/greeting"})

@WebServlet注解属性:



  方法二:web.xml配置方式  


<servlet>


<description>This is a hello greeting servlet</description>


<display-name>Hello Servlet</display-name>


   <servlet-name>HelloServlet</servlet-name>


</servlet>


<servlet-mapping>


   <servlet-name>HelloServlet</servlet-name>


   <url-pattern>/greeting</url-pattern>


   <url-pattern>/hello</url-pattern>


</servlet-mapping>


web.xml配置标签:  


<!--指示服务器在收到引用一个目录名而不是文件名的URL时,使用哪个文件-->
<welcome-file-list>
<!--用于指定欢迎页面的路径-->
<welcome-file></welcome-file>
</welcome-file-list>

<!--服务器一般为servlet提供一个缺省的URL:http://host/webAppPrefix/servlet/ServletName。 但是,常常会更改这个URL,以便servlet可以访问初始化参数或更容易地处理相对URL。在更改缺省URL时,使用servlet-mapping元素-->
<servlet-mapping>
<!--用于指定上文配置的servlet的名称-->
<servlet-name></servlet-name>
<!--描述用于解析URL的模式-->
<url-pattern></url-pattern>
</servlet-mapping>

<!--如果某个会话在一定时间内未被访问,服务器可以抛弃它以节省内存。可通过使用HttpSession的setMaxInactiveInterval方法明确设置单个会话对象的超时值,或者可利用session-config元素制定缺省超时值-->
<session-config>
<!--用于session的超时时间-->
<session-timeout></session-timeout>
</session-config>

<!--在向servlet或JSP页面制定初始化参数或定制URL时,必须首先命名servlet或JSP页面。Servlet元素就是用来完成此项任务的-->
<servlet>
<!--声明描述信息-->
<description></description>
<!--用于定义Web应用的名称-->
<display-name></display-name>
<!--指定应用的大图标和小图标-->
<icon></icon>
<!--用于指定servlet的一些初始化参数-->
<init-param></init-param>
<!--用于指定一个jsp页面来对该servlet进行初始化-->
<jsp-file></jsp-file>
<!--用于指定应用启动时加载的优先级-->
<load-on-startup></load-on-startup>
<!--该元素指定了该web应用程序运行时所需用的运行身份-->
<run-as></run-as>
<!--该元素将 <security-role> 定义的安全角色名链接到使用Servlet逻辑进行硬编码的备用角色名。使用此附加提取层,可以在部署时配置Servlet,且不必更改Servlet 代码-->
<security-role-ref></security-role-ref>
<!--用于指定当前servlet对应的类的路径-->
<servlet-class></servlet-class>
<!--用于对当前servlet取一个名称,以便在后面的映射时使用-->
<servlet-name></servlet-name>
</servlet>

<!--该元素声明一个对Web服务的引用-->
<service-ref>
<!--声明描述信息-->
<description></description>
<!--用于定义Web应用的名称-->
<display-name></display-name>
<!--元素为端口组件声明处理器。它包含一个必需的handler-name和handlerclass和可选的init-param,soap-header,soap-role和port-name元素。handler-name元素定义了处理器的名称(在web.xml中是唯一的)。handler-class定义了处理器所实现类的完全限定名-->
<handler></handler>
<!--指定应用的大图标和小图标-->
<icon></icon>
<!--该元素包含将WSDL定义映射到服务终端接口和服务接口的那个文件的位置-->
<jaxrpc-mapping-file></jaxrpc-mapping-file>
<!--该元素声明了一个在容器中解析服务终端接口到一个WSDL端口的客户端依赖关系。它使用一个特别的端口组件选择性地关联服务终端接口-->
<port-component-ref></port-component-ref>
<!--该元素指定Web应用所依赖的JAX-RPC完全限定接口名-->
<service-interface></service-interface>
<!--该元素与其两个子元素(namespaceURI和localpart)声明了正在引用的WSDL服务元素。如果不指定wsdl-file元素或者WSDL文件只包含一个服务-->
<service-qname></service-qname>
<!--该元素定义的Web服务(与java:comp/env上下文对应的)-->
<service-ref-name></service-ref-name>
<!--该元素包含Web服务描述语言文件的位置(相对于Web应用程序的根目录)。这个文件必须放在WEB-INF/wsdl目录中-->
<wsdl-file></wsdl-file>
</service-ref>

<!--给出安全角色的一个列表,这些角色将出现在servlet元素内的security-role-ref元素的role-name子元素中。分别地声明角色可使高级IDE处理安全信息更为容易-->
<security-role>
<!--声明描述信息-->
<description></description>
<!--用于定义那些安全角色可以访问在此安全约束中定义的资源-->
<role-name></role-name>
</security-role>

<!--制定应该保护的URL。它与login-config元素联合使用-->
<security-constraint>
<!--用于定义那些组或委托人可以访问此安全约束内定义的web资源集合-->
<auth-constraint></auth-constraint>
<!--用于定义Web应用的名称-->
<display-name></display-name>
<!--用于定义客户端如何与服务器进行通信-->
<user-data-constraint></user-data-constraint>
<!--用于定义用此安全约束的web应用程序的区域-->
<web-resource-collection></web-resource-collection>
</security-constraint>

<!--声明一个资源工厂使用的外部资源-->
<resource-ref>
<!--声明描述信息-->
<description></description>
<!--用于指定资源由Application或Container来许可-->
<res-auth></res-auth>
<!--用于指定资源名称 -->
<res-ref-name></res-ref-name>
<!--用于指定资源是否可以共享.默认值为 Shareable -->
<res-sharing-scope></res-sharing-scope>
<!--用于指定资源种类-->
<res-type></res-type>
</resource-ref>

<!--声明与资源相关的一个管理对象-->
<resource-env-ref>
<!--声明描述信息-->
<description></description>
<!--指定资源环境引用的名称,其它值为web应用程序代码中使用的环境条目名称。名称是相对于java:comp/env上下文的JNDI名称,该名称在web应用程序中必须唯一-->
<resource-env-ref-name></resource-env-ref-name>
<!--指定资源环境引用的类型,它是java语言的类或者接口的完全限定名称-->
<resource-env-ref-type></resource-env-ref-type>
</resource-env-ref>

<!--如果Web应用具有想到特殊的文件,希望能保证给他们分配特定的MIME类型,则mime-mapping元素提供这种保证-->
<mime-mapping>
<!--用于指定其扩展名名称-->
<extension></extension>
<!--用于指定MIME的格式-->
<mime-type></mime-type>
</mime-mapping>

<!--用于指出将引用与web.xml中声明资源相关联的信息地址-->
<message-destination-ref>
<!--声明描述信息-->
<description></description>
<!--用来连接对一个目标消息的引用。它的值必须通过web.xml文件或者在同一个J2EE应用单元的部署描述文件中message-destination元素的message-destination-name子元素来声明-->
<message-destination-link></message-destination-link>
<!--定义一个信息地址引用的JNDI名(相对于java:comp/env上下文)。在web.xml中,这个名称必须唯一-->
<message-destination-ref-name></message-destination-ref-name>
<!--素声明了目标的类型,可以是javax.jms.Queue或javax.jms.Topic-->
<message-destination-type></message-destination-type>
<!--说明引用所指定的目标信息的使用情况。它的值指出是使用目标信息中的消息,还是产生目标信息,亦或两者兼有(有效值为Consumes,Produces或ConsumesProduces)-->
<message-destination-usage></message-destination-usage>
</message-destination-ref>

<!--元素指定了一个逻辑目标消息,后者映射到服务器特有部署描述文件中的物理目标信息-->
<message-destination>
<!--声明描述信息-->
<description></description>
<!--用于定义Web应用的名称-->
<display-name></display-name>
<!--指定应用的大图标和小图标-->
<icon></icon>
<!--为一个目标信息指定一个唯一的名称(仅限于web.xml中)-->
<message-destination-name></message-destination-name>
</message-destination>

<!--指定服务器应该怎样给试图访问受保护页面的用户授权。它与sercurity-constraint元素联合使用-->
<login-config>
<!--指定对用户身份验证的方法。可能值:
BASIC:使用浏览器进行身份验证(默认),
FORM:使用用户编写的HTML表单-->
<auth-method></auth-method>
<!--指定必需相对于文档根目录的web资源的URI,用于对用户进行身份验证。这个可以是HTML页面、JSP或者HTTP Servlet,且必须返回-->
<form-login-config></form-login-config>
<!--用于对用户凭据进行身份验证时所引用的领域名称-->
<realm-name></realm-name>
</login-config>

<!--该元素用来设置各种Locale和字符集编码之间的映射关系的集合-->
<locale-encoding-mapping-list>
<!--该元素用来设置各种Locale和字符集编码之间的映射关系-->
<locale-encoding-mapping>
<!--该元素用来指定其Locale的名称,如:zh-CN-->
<locale></locale>
<!--该元素用来指定其编码方式-->
<encoding></encoding>
</locale-encoding-mapping>
</locale-encoding-mapping-list>

<!--servlet API的版本2.3增加了对事件监听程序的支持,事件监听程序在建立、修改和删除会话或servlet环境时得到通知。Listener元素指出事件监听程序类-->
<listener>
<!--声明描述信息-->
<description></description>
<!--用于定义Web应用的名称-->
<display-name></display-name>
<!--指定应用的大图标和小图标-->
<icon></icon>
<!--用于指定监听器的类(完整路径)-->
<listener-class></listener-class>
</listener>

<!--该元素主要用来设定JSP的相关配置-->
<jsp-config>
<!--定义了一组JSP的特性。这些特性实际上对应JSP的page directive定义的特性-->
<jsp-property-group>
<!--声明描述信息-->
<description></description>
<!--用于定义Web应用的名称-->
<display-name></display-name>
<!--若为true,表示不支持EL语法-->
<el-ignored></el-ignored>
<!--指定应用的大图标和小图标-->
<icon></icon>
<!--设置JSP网页的结尾,扩展名为.jspf -->
<include-coda></include-coda>
<!--设置JSP网页的抬头,扩展名为.jspf -->
<include-prelude></include-prelude>
<!--如果节点值为:true则表示这个文件为jsp文档(xml格式),如果为false,则表示为标准的jsp文件-->
<is-xml></is-xml>
<!--设定JSP网页的编码-->
<page-encoding></page-encoding>
<!--若为true表示不支持<%scription%>语法-->
<scripting-invalid></scripting-invalid>
<!--设定值所影响的范围,如:/CH2 或者/*.jsp -->
<url-pattern></url-pattern>
</jsp-property-group>
<!--用来设定JSP网页用到的Tag Library路径-->
<taglib>
<!--用于指定TLD文件对应Web站台的存放位置-->
<taglib-location></taglib-location>
<!--用于指定TLD文件的URI,JSP网页的taglib指令可以由这个URI存取到TLD文件-->
<taglib-uri></taglib-uri>
</taglib>
</jsp-config>

<!--Web应用图标:指出IDE和GUI工具用来表示Web应用的大图标和小图标-->
<icon>
<!--用于指定大图标-->
<large-icon></large-icon>
<!--用于指定小图标-->
<small-icon></small-icon>
</icon>

<!--一旦命名了一个过滤器,就要利用filter-mapping元素把它与一个或多个servlet或JSP页面相关联-->
<filter-mapping>
<!--该元素有四个可能的值:即REQUEST(默认),FORWARD,INCLUDE和ERROR,可以在一个<filter-mapping>元素中加入任意数目的<dispatcher>,使得filter将会作用于直接从客户端过来的request,通过forward过来的request,通过include过来的request和通过<error-page>过来的request。如果没有指定任何< dispatcher >元素,默认值是REQUEST -->
<dispatcher></dispatcher>
<!--用于指定上文定义的filter名称-->
<filter-name></filter-name>
<!--用于指定上文定义的servlet名称-->
<servlet-name></servlet-name>
<!--描述用于解析URL的模式-->
<url-pattern></url-pattern>
</filter-mapping>

<!--过滤器元素将一个名字与一个实现javax.servlet.Filter接口的类相关联-->
<filter>
<!--声明描述信息-->
<description></description>
<!--用于定义Web应用的名称-->
<display-name></display-name>
<!--用于指定当前filter对应的类的路径-->
<filter-class></filter-class>
<!--用于对当前filter取一个名称,以便在后面的映射时使用-->
<filter-name></filter-name>
<!--指定应用的大图标和小图标-->
<icon></icon>
<!--用于指定当前filter的一些初始化参数-->
<init-param></init-param>
</filter>

<!--在返回特定HTTP状态代码时,或者特定类型的异常被抛出时,能够制定将要显示的页面-->
<error-page>
<!--用于指定Http的错误代码-->
<error-code></error-code>
<!--用于指定程序中的异常(异常的完整路径)-->
<exception-type></exception-type>
<!--用于指定程序出现错误时,跳转到的页面-->
<location></location>
</error-page>

<!--声明Web应用的环境项-->
<env-entry>
<!--声明描述信息-->
<description></description>
<!--一个相对于java:comp/env环境JNDI名-->
<env-entry-name></env-entry-name>
<!--(java.lang程序包中一个类型的完全限定类名,java.lang.Boolean、java.lang.String等)组成-->
<env-entry-type></env-entry-type>
<!--用于指定环境条目的值-->
<env-entry-value></env-entry-value>
</env-entry>

<!--声明一个EJB的主目录的引用-->
<ejb-ref>
<!--声明描述信息-->
<description></description>
<!--当前bean从一个不同jar包中引用另外一个bean的名称。通过ejb-link元素定义的名称必须使用"#"和bean注册名与Web应用程序中war文件的位置相关联-->
<ejb-link></ejb-link>
<!--java:comp/env的对应的EJB引用名-->
<ejb-ref-name></ejb-ref-name>
<!--用于声明实体或会话的bean类型-->
<ejb-ref-type></ejb-ref-type>
<!--用于指定EJB Home接口的完全限定名称-->
<home></home>
<!--bean的remote接口的完全限定名称-->
<remote></remote>
</ejb-ref>

<!--声明一个EJB的本地主目录的应用-->
<ejb-local-ref>
<!--声明描述信息-->
<description></description>
<!--当前bean从一个不同jar包中引用另外一个bean的名称。通过ejb-link元素定义的名称必须使用"#"和bean注册名与Web应用程序中war文件的位置相关联-->
<ejb-link></ejb-link>
<!--java:comp/env的对应的EJB引用名-->
<ejb-ref-name></ejb-ref-name>
<!--用于声明实体或会话的bean类型-->
<ejb-ref-type></ejb-ref-type>
<!--用于指定包含企业Bean本地接口的完全限定名称-->
<local></local>
<!--用于指定包含企业Bean本地Home接口的完全限定名称-->
<local-home></local-home>
</ejb-local-ref>

<!--定义了WEB应用的名字-->
<display-name></display-name>

<!--声明WEB应用的描述信息-->
<description></description>

<!--该元素声明应用范围内的初始化参数-->
<context-param>
<!--声明描述信息-->
<description></description>
<!--用于指定上下文参数的名称-->
<param-name></param-name>
<!--用于指定上下文参数的值-->
<param-value></param-value>
</context-param>

在发布一个组件时,同时使用web.xml与注解时,则注解优先于web.xml里的配置。

 
三、访问Servlet

HTTP请求最常用的方式有两种:GET和POST。

1、GET:

通过HTTP GET请求访问HelloServlet发布时的url进行访问:http://localhost:8080/hello

2、POST:(form表单)

<h1>hello servlet 实例</h1>

<a href="hello">Get方式请求servlet</a>

<hr/>

<form action="hello" method="post">

<input type="submit" value="Post方式请求servlet"/>

</form>

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Java Web Servlet知识点讲解(二)的更多相关文章

  1. Java Web Servlet知识点讲解(一)

    一.Web应用架构 如图所示: HTTP协议:一个简单的请求一响应协议,通常运行在TCP之上,它指定了客户端可能发送给服务器什么样的信息以及得到什么样的响应. JDBC:Java语言中用来规范客户端程 ...

  2. java web hello world(二)基于Servlet理解监听

    java web最开始实现是通过Servlet实现,这里就来实现下,最原始的监听是如何实现的. 第一步,创建一个基本的web项目 ,参见(java web hello world(一)) 第二步,we ...

  3. Java Web学习(十二)Tomcat核心

    一.引言 其实按道理来说,学习Java web应该在前面的篇幅就写有关tomcat相关的知识点,不过近期看了一些资料,觉得以前仅仅只是知道用tomcat去发布我的项目,一些细节的东西也没有好好总结,这 ...

  4. java web开发入门十二(idea创建maven SSM项目需要解决的问题)基于intellig idea(2019-11-09 11:23)

    一.spring mvc action返回string带双引号问题 解决方法: 在springmvc.xml中添加字符串解析器 <!-- 注册string和json解析适配器 --> &l ...

  5. Java Web入门学习(二) Eclipse的配置

    Java Web学习(二) Eclipse的配置 一.下载Eclipse 1.进入Eclipse官网,进行下载 上图,下载Eclipse IDE for JaveEE Developers 版本,然后 ...

  6. Java Web -- Servlet(1) 必备知识

    学习Java WEB开发必备的基本概念: 1.WEB 本意是蜘蛛网和网的意思.在网页设计中我们称为网页的意思. 现广泛译作网络.互联网等技术领域.表现为三种形式,即超文本(hypertext).超媒体 ...

  7. java web Servlet开发(二)

    一.ServletConfig讲解 1.1.配置Servlet初始化参数 在Servlet的配置文件web.xml中,可以使用一个或多个<init-param>标签为servlet配置一些 ...

  8. Java Web之路(二)Servlet之HttpServletResponse和HttpServletRequest

    HttpServletResponse 1.告诉服务器应用使用UTF-8解析文本的两种方式,告诉客户端要使用什么编码 response.setHeader("content-type&quo ...

  9. java web学习总结(十二) -------------------Session

    一.Session简单介绍 在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下).因此,在需要保存用户数据时,服务 ...

随机推荐

  1. 创建dynamics CRM client-side (八) - 获取attribute的值 和 设置disable

    大家可以用下面的方式来获取attribute的值 formContext.getAttribute("address1_shippingmethodcode").getText() ...

  2. 文件系统(02):基于SpringBoot框架,管理Xml和CSV文件类型

    本文源码:GitHub·点这里 || GitEE·点这里 一.文档类型简介 1.XML文档 XML是可扩展标记语言,是一种用于标记电子文件使其具有结构性的标记语言.标记指计算机所能理解的信息符号,通过 ...

  3. 如何在OpenStack中对云主机类型进行重新配置

    目标:很多用户在OpenStack启动一个虚拟机,选择了一个云主机配置类型,例如2CPU 4GB内存,使用了一段时间,感觉这个配置并不能满足需求,所以希望能够提高配置,那么OpeNStack的管理界面 ...

  4. 如何优雅地使用containerd?这里有一份必读的技巧攻略

    前 言 Docker是我们常用的容器runtime,友好的CLI,丰富的社区资料,外加研发运维人员多年的经验积累,使用Docker几乎是没有任何门槛的事.而k3s为了降低资源消耗,将默认的runtim ...

  5. Qt qApp

    qApp A global pointer referring to the unique application object. It is equivalent to the pointer re ...

  6. C语言实现银行家算法

    #include <stdio.h> #include <stdlib.h> #include <string.h> #include <stdbool.h& ...

  7. vcs/verdi filist

    . 现在很多verilog 的filelist 文件中用如下形式来指定文件所在的目录就行了,而不必指定具体文件 ./testbench/ppc460_PLB4/p464s_test_top_tb.v ...

  8. AI产品经理工作流程——需求分析和产品设计

    1.AI产品设计常见失败原因 技术驱动产品设计,即我有什么技术就做什么产品.尽管许多公司不惜重金招聘高级AI算法工程师,确实这样也能帮助企业拿到大量的融资,但也容易给公司带来技术决定产品设计的局限.然 ...

  9. BZOJ 1601 [Usaco2008 Oct]灌水 (建图+mst)

    题意: 300个坑,每个坑能从别的坑引水,或者自己出水,i从j饮水有个代价,每个坑自己饮水也有代价,问让所有坑都有谁的最少代价 思路: 先建一个n的完全图,然后建一个超级汇点,对每个点连w[i],跑m ...

  10. 牛客练习赛25 A 因数个数和(数论分块)

    题意: q次询问,每次给一个x,问1到x的因数个数的和. 1<=q<=10 ,1<= x<=10^9 1s 思路: 对1~n中的每个数i,i作为i,2i,3i,...的约数,一 ...