一、定义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>
原文地址:https://www.cnblogs.com/huangdanlei/p/12202420.html