极速pk10直播_Java匹马行天下之JavaWeb核心技术——Servlet

  • 时间:
  • 浏览:3

Servlet是在服务器上运行的小tcp连接,也不我要 无需 无需 无需 无需 无需 无需 无需 Java类,但比较特殊,不须要new,自动就都须要运行。有的是创建、垃圾回收和销毁过程。Servlet是JavaWeb的三大组件之一(Servlet、Filter、Listener),它属于动态资源。Servlet的作用是处理请求,服务器会把接收到的请求交给Servlet来处理,在Servlet中通常须要:

  • 接收请求数据;
  • 处理请求;
  • 完成响应。

这俩 客户端发出登录请求,可能性输出注册请求,有有哪些请求都应该由Servlet来完成处理。Servlet须要大伙当事人来编写,每个Servlet须要实现javax.servlet.Servlet接口。Servlet对象驻留在服务器内存中。

1、编写无需 无需 无需 无需 Servlettcp连接

       写无需 无需 无需 无需 java类,实现Servlet接口,实现了该接口,该类有的是的是普通的类了。

package servletdemo;

import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import java.io.IOException;
@WebServlet("/servlet")
public class servletDemo implements Servlet {

    @Override
    public void init(ServletConfig servletConfig) throws ServletException {
        System.out.println("Hello Servlet");

    }

    @Override
    public ServletConfig getServletConfig() {
        return null;
    }

    @Override
    public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {

    }

    @Override
    public String getServletInfo() {
        return null;
    }

    @Override
    public void destroy() {

    }
}

部署应用到tomcat服务器。

实例化-->初始化-->服务->销毁

      出生:(实例化-->初始化)第一次访问Servlet就出生了(默认情况汇报下)。(说明我要改变它的出生时机,比如让servlet在服务器启动时就创建)

      活着:(服务)应用活着,servlet就活着。(Servlet是单实例,其中的service()法律土办法是多tcp连接的。)

      死亡:(销毁)应用被卸载了,servlet就销毁了。

package servletdemo;

import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import java.io.IOException;
@WebServlet("/servlet")
public class servletDemo implements Servlet {

    //Servlet生命周期的法律土办法:实例化法律土办法(new 对象,无参构造)
    //在servlet第一次被访问时调用
    public servletDemo() {
        System.out.println("*******servletDemo执行了");
    }

    //Servlet生命周期的法律土办法:初始化法律土办法
    //在servlet第一次被访问时调用
    @Override
    public void init(ServletConfig servletConfig) throws ServletException {
        System.out.println("*********init执行了");

    }

    @Override
    public ServletConfig getServletConfig() {
        return null;
    }

    //Servlet生命周期的法律土办法:服务法律土办法
    //每次访问时还还可以


被调用
    @Override
    public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {
        System.out.println("*******service执行了");
    }


    @Override
    public String getServletInfo() {
        return null;
    }

    //Servlet生命周期的法律土办法:销毁法律土办法
    //当应用被卸载时调用
    @Override
    public void destroy() {
        System.out.println("*******destroy执行了");
    }
}

实现Servlet有三种法律土办法:

  •  实现javax.servlet.Servlet接口;
  • 继承javax.servlet.GenericServlet类;
  • 继承javax.servlet.http.HttpServlet类;

自定义Servlet类的继承特性,如下图:

 1、实现javax.servlet.Servlet接口(参见:编写无需 无需 无需 无需 servlettcp连接)

 2、继承javax.servlet.GenericServlet类(抽象类)(适配器模式)

    GenericServlet类(抽象类)可能性实现了Servlet接口,大伙用哪个法律土办法就调用哪法律土办法,无需再去全部实现了,哪怕是全部的空实现。

3、继承javax.servlet.http.HttpServlet(抽象类)(模板法律土办法设计模式)

    模板是HttpServlet类中的私有service()法律土办法(开发中常用法律土办法)

    HttpServlet类(抽象类)继承了GenericServlet类(抽象类)

package servletdemo;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@WebServlet("/servlet1")
public class servlet extends HttpServlet {
    //具体实现1
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        System.out.println("******MydoGet*******");
        System.out.println(req.getRemoteAddr());
    }

    //具体实现2
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        System.out.println("*******MydoPost******");
    }

}

  

     注意: 无需重写父类Httpservlet中的service()法律土办法,可能性该法律土办法会调用Httpservlet中私有的service()法律土办法,

          而该私有的service()法律土办法会根据不同的提交表单的法律土办法,会调用相应的doGet()、doPost()、doHead()等法律土办法。

          大伙去重写有有哪些不同的表单提交的法律土办法即可。

       Servlet(接口) --> GenericServlet(抽象类/适配器) --> HttpServlet(功能抽象类/模板) --> (继承HttpServlet,具体实现类,重写其功能)

4、公牛表白的故事

此故事纯属当事人脑洞虚构

故事内容:草原上有一头公牛喜欢一头母牛,但是公牛不敢直接向母牛表白,有一天公牛找到一头小牛,想让小牛把他想对母牛说话语说给母牛听,小牛答应了,剧情很鸡血,就另无需 无需 无需 无需 ,看我用servlet实现

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<body>
<h2>公牛表白准备</h2>
<a href="/servlet2">去表白</a>
</body>
</html>

  

package com.demo.servlet;

import javax.servlet.*;
import javax.servlet.annotation.WebServlet;
import java.io.IOException;
@WebServlet("/servlet2")
public class ServletDemo2 extends GenericServlet {
    @Override
    public void service(ServletRequest req, ServletResponse res) throws ServletException, IOException {
        System.out.println("我是草原上的公牛");
        System.out.println("我让小牛把我对母牛的爱传给她");
        System.out.println("该说话语我给小牛说了,小牛听到了给我回复收到,并把他说话语传给母牛");
        ServletContext application = this.getServletContext();
        application.setAttribute("name","母牛");
        application.getRequestDispatcher("/servlet3").forward(req,res);
        
    }
}

  

package com.demo.servlet;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

@WebServlet("/servlet3")
public class ServletDemo3 extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        doPost(req,resp);
        System.out.println("我是小牛");
        //设置输出格式和字符编码
        resp.setContentType("text/html;charset=utf-8");
        //向页面输出内容
        PrintWriter out = resp.getWriter();
        out.println("<h1>我是小牛</h1>");
        ServletContext application = this.getServletContext();
        String name = (String) application.getAttribute("name");
        System.out.println("收到的名字:"+name);
        out.println("收到的名字:"+name);
        System.out.println("小牛收到");
        application.setAttribute("love","公牛说他爱你");
        application.getRequestDispatcher("/servlet4").forward(req,resp);

    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        System.out.println("我是dopost");
        resp.setContentType("text/html;charset=utf-8");
        PrintWriter out = resp.getWriter();
        out.println("<h1>我是servlet33</h1>");
    }

    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        super.service(req, resp);
        System.out.println("我是service333");
        resp.setContentType("text/html;charset=utf-8");
        PrintWriter out = resp.getWriter();
        out.println("<h1>我是servlet333</h1>");
    }
}

  

package com.demo.servlet;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
@WebServlet("/servlet4")
public class Servlet4 extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        doPost(req,resp);
        System.out.println("我是母牛");
        String love = (String) this.getServletContext().getAttribute("love");
        System.out.println(love);
        resp.setContentType("text/html;charset=utf-8");
        //向页面输出内容
        PrintWriter out = resp.getWriter();
        out.println("收到的表白:"+love);
        System.out.println("母牛收到");
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

    }
}

  5、servlet的映射细节

      1、servlet的映射细节一:

无需 无需 无需 无需 servlet都须要配置多个映射路径(可能性说:多个映射路径都须要指向同无需 无需 无需 无需 servlet),只无需 无需 无需 无需 name是一样的就行

                     2、servlet的映射细节二:     

 通配符代表任意字符串

        url-pattern*.xxx     .xxx结尾的请求都都须要访问  注:无需加/

        url-pattern/*        任意字符串结尾的请求都都须要访问

        url-pattern/xxxx/*   /xxxx/开头的请求都都须要访问

6、对servlet配置有三种法律土办法

1、在web.xml中对servlet进行配置

2、利用注解进行配置

     在servlet类的底下写入注解@WebServlet("/hello")

7、实例一——在web.xml中配置

1、在Web.xml中配置路径和参数

<!DOCTYPE web-app PUBLIC
 "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
 "http://java.sun.com/dtd/web-app_2_3.dtd" >

<web-app>
  <display-name>Archetype Created Web Application</display-name>
  <servlet>
    <servlet-name>Servletdemo1</servlet-name>
    <servlet-class>com.demo.servlet.Servletdemo1</servlet-class>
    <init-param>
      <param-name>name</param-name>
      <param-value>tom</param-value>
    </init-param>
    <init-param>
      <param-name>password</param-name>
      <param-value>1234</param-value>
    </init-param>

  </servlet>
  <servlet-mapping>
    <servlet-name>Servletdemo1</servlet-name>
    <url-pattern>/servlet</url-pattern>
  </servlet-mapping>

  <context-param>
    <param-name>k</param-name>
    <param-value>xxxxxxxx</param-value>
  </context-param>
</web-app>

  

2、在servlet中获取参数和值

package com.demo.servlet;

import javax.servlet.*;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.Enumeration;


public class Servletdemo1 implements Servlet {
    private  ServletConfig servletConfig;

    @Override
    public void init(ServletConfig config) throws ServletException {
        servletConfig=config;
        System.out.println("init调用了");

    }

    @Override
    public ServletConfig getServletConfig() {
        return servletConfig;
    }

    @Override
    public void service(ServletRequest req, ServletResponse res) throws ServletException, IOException {
        //设置输出格式和字符编码
        res.setContentType("text/html;charset=utf-8");
        //向页面输出内容
        PrintWriter out = res.getWriter();
        out.println("我是service"+"<br>");
        System.out.println("我是service");

        //法律土办法一
        String name = servletConfig.getInitParameter("name");
        String password = servletConfig.getInitParameter("password");

        System.out.println("在控制台输出信息:");
        System.out.println("name:"+name+"password:"+password);

        out.println("name:"+name+" "+"password:"+password+"<br>");

        //法律土办法二
        Enumeration<String> en = servletConfig.getInitParameterNames();
        while (en.hasMoreElements()){
            String names = en.nextElement();
            String values = servletConfig.getInitParameter(names);

            System.out.println("在控制台输出信息:");
            System.out.println(names+" "+values);
            out.println(names+" "+values+"<br>");
        }

        String k = servletConfig.getServletContext().getInitParameter("k");
        System.out.println("在控制台输出信息:");
        System.out.println("k:"+k+"<br>");
        out.println("k"+k);
    }

    @Override
    public String getServletInfo() {
        return null;
    }

    @Override
    public void destroy() {

    }
}

8、实例二——利用注解配置

package com.demo.servlet;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

@WebServlet("/hello")
public class Servlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        doPost(req,resp);
        ServletContext servletContext = this.getServletContext();
        servletContext.setAttribute("user","Tom");
        String user = (String)servletContext.getAttribute("user");

        //从请求的地址栏或表单中获取信息
        String user2 = req.getParameter("user");

        System.out.println("获取Context容器中的信息:"+user);
        System.out.println("在控制台输出从访问的地址栏获取的信息:"+user2);
        resp.setContentType("text/html");
        resp.setCharacterEncoding("utf-8");

        PrintWriter out = resp.getWriter();
        out.append("<!DOCTYPE html>")
                .append("<html><head></head><body>")
                .append("用户是"+user)
                .append("</body></html>");

    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

    }
}

  

    整个生命周期是单实例,每次访问时为多tcp连接。

      一:单实例变成多实例,但过时了,可能性耗费资源多,服务器压力大。

      二:加tcp连接锁,但数据会重复经常出现(没法同步机制),且运行效率低。

      三:处理tcp连接安全什么的什么的问题的最佳法律土办法:无需写全局变量,而写局部变量(即改变变量的作用域)。

    ServletContext: 代表的是整个应用。无需 无需 无需 无需 应用必须无需 无需 无需 无需 ServletContext对象。单实例。

无需 无需 无需 无需 项目必须无需 无需 无需 无需 ServletContext对象,服务器会为每个应用创建无需 无需 无需 无需 ServletContext对象,大伙都须要在N多个Servlet中来获取你无需 无需 唯一的对象,使用它都须要给多个Servlet传递数据,与Tomcat同生同死。

  • ServletContext对象的创建是在服务器启动时完成的;
  • ServletContext对象的销毁是在服务器关闭时完成的。

ServletContext对象的作用是在整个Web应用的动态资源直接共享数据。这俩 在AServlet中向ServletContext对象中保存无需 无需 无需 无需 值,但是在BServlet中就都须要获取你无需 无需 值,这无需 无需 无需 无需 数据共享。

1、获取ServletContext

在Servlet中获取ServletContext对象:

  •  在void init(ServletConfig config)中:

ServletContext context = config.getServletContext();

public class DemoServlet implements Servlet {

    public void init(ServletConfig config) throws ServletException {

       ServletContext context = config.getServletContext();

    }

}
  • GenericServlet类有getServletContext()法律土办法,无需 无需 无需 无需 都须要直接使用this.getServletContext()类获取。 在GenericServlet或HttpServlet中获取ServletContext对象:
public class HttpServletDemo extends HttpServlet {

    @Override

    protected void doPost(HttpServletRequest req, HttpServletResponse resp)

           throws ServletException, IOException {

       ServletContext context = this.getServletContext();

    }

}
  •   HttpSession中也都须要通过getServletContext()法律土办法来获得

2、域对象的功能

ServletContext是JavaWeb四大域对象之一:

  •  PageContext
  •  ServletRequest
  •  HttpSession
  •  ServletContext

所有域对象有的是有存取数据的功能,可能性域对象外部是否是需 无需 无需 无需 Map,用来存储数据,下面是ServletContext对象用来操作数据的法律土办法:

  •  void setAttribute(String name,Object val):用来存储无需 无需 无需 无需 对象,也都须要成为存储无需 无需 无需 无需 域,参数分别为域的属性名和属性值,可能性多次调用该法律土办法,但是使用相同的name,没法就会覆盖上一次的值,你无需 无需 特性与Map这俩 。
  •  Object getAttribute(String name):用来获取ServletContext中的数据,当前在获取前一天须要先存储。
  •  void removeAttribute(String name):用来移除ServletContext中的域属性,可能性参数name不占据 ,没法该法律土办法有哪些有的是做。
  •  Enumeration getAttributeNames():获取所有域属性的名称。

2获取全局配置信息:

 法律土办法:public String getInitParamenter(String name) // 根据配置文件中的key得到value

3、读取简单的资源文件(即只所含key=value的形式):

    法律土办法:public String getRealPath(String path)// 根据资源名称得到资源的绝对路径,都须要得到当前应用任何位置的任何资源。

public class AServlet extends HttpServlet {
	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		//获取所含盘符的路径
		String path = this.getServletContext().getRealPath("/a.txt");
		
		//获取资源路径后,再获取输入流对象
		InputStream is = this.getServletContext().getResourceAsStream("/a.txt");
		
		//获取当前路径下的所有资源路径
		Set<String> paths = this.getServletContext().getResourcePaths("/WEB-INF");
		
	}
}

4、Servlet的转发与重定向

 转发和重定向都能让浏览器获得另外无需 无需 无需 无需 URL所指向的资源,但两者的外部运行机制有着很大的区别。

1、转发:有三种法律土办法获得转发对象(RequestDispatcher):三种是通过HttpServletRequest的getRequestDispatcher()法律土办法获得,三种是通过ServletContext的getRequestDispatcher()法律土办法获得;

     前一天的request范围中存放的变量无需失效,就像把无需 无需 无需 无需 页面拼到了一起去。 这俩 :

request.getRequestDispatcher (“demo.jsp"). forward(request, response);//转发到demo.jsp

     详解:假设浏览器访问servlet1,而servlet1想让servlet2为客户端服务。此时servlet1调用forward()法律土办法,将请求转发给servlet2。但是调用forward()法律土办法,对于浏览器来说是透明的,浏览器并我要知道为其服务的Servlet可能性加在Servlet2,它只知道发出了无需 无需 无需 无需 请求,获得了无需 无需 无需 无需 响应。浏览器URL的地址栏不变。

2、重定向:HttpServletResponse的sendRedirect()法律土办法。

     服务器根据此请求寻找资源并发送给客户,它都须要重定向到任意URL,必须共享request范围内的数据。这俩 :response.sendRedirect(“demo.jsp");//重定向到demo.jsp

     详解:假设浏览器访问servlet1,而servlet1想让servlet2为客户端服务。此时servlet1调用sendRedirect()法律土办法,将客户端的请求重新定向到Servlet2。接着浏览器访问servlet2,servlet2对客户端请求作出反应。浏览器URL的地址栏改变。

3、主要区别:

(1)sendRedirect()法律土办法不但都须要在占据 同无需 无需 无需 无需 主机上的不同Webtcp连接之间进行重定向,但是都须要将客户端重定向到无需 无需 服务器上的Webtcp连接资源。而forward()法律土办法必须将请求转发给同一Web应用的组件。

(2)sendRedirect()法律土办法必须转发到“/WEB-INF/”路径下的jsp页面资源,而getRequestDispatcher().forword()都须要重定向到“/WEB-INF/”路径下的jsp页面资源。如 request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request, response);

(3)转发:浏览器URL的地址栏不变。

        重定向:浏览器URL的地址栏改变。

5、实现Servlet的请求转发:

    法律土办法:public RequestDispatcher getRequestDispatcher(String path) //参数表示要跳转到哪去

6、依赖和关联

      可能性是通过参数传过来的对象,就叫依赖。

     通过法律土办法得到的对象,就叫关联。

1、HTTP请求常用法律土办法

Cookie[] getCookies()

返回无需 无需 无需 无需 数组,所含客户端发送该请求的所有的 Cookie 对象。

Enumeration getAttributeNames()

返回无需 无需 无需 无需 枚举,所含提供给该请求可用的属性名称。

HttpSession getSession()

返回与该请求关联的当前 session 会话,可能性可能性请求没法 session 会话,则创建无需 无需 无需 无需 。

HttpSession getSession(boolean create)

返回与该请求关联的当前 HttpSession,可能性可能性没法当还还可以 话,且创建是真的,则返回无需 无需 无需 无需 新的 session 会话。

String getRequestedSessionId()

返回由客户端指定的 session 会话 ID。

Object getAttribute(String name)

以对象形式返回已命名属性的值,可能性没法给定名称的属性占据 ,则返回 null。

String getCharacterEncoding()

返回请求主体中使用的字符编码的名称。

String getContentType()

返回请求主体的 MIME 类型,可能性我要知道类型则返回 null。

String getContextPath()

返回指示请求上下文的请求 URI 帕累托图。

String getQueryString()

返回所含在路径后的请求 URL 中的查询字符串。

String getRemoteUser()

可能性用户已通过身份验证,则返回发出请求的登录用户,可能性可能性用户未通过身份验证,则返回 null。

int getParameterMap()

将参数封装成 Map 类型。

2、设置HTTP响应头的法律土办法

void reset()

清除缓冲区中占据 的任何数据,包括情况汇报码和头。

void resetBuffer()

清除响应中基础缓冲区的内容,不清除情况汇报码和头。

void setCharacterEncoding(String charset)

设置被发送到客户端的响应的字符编码(MIME 字符集)这俩 ,UTF-8。

void setStatus(int sc)

为该响应设置情况汇报码。

void setIntHeader(String name, int value)

设置无需 无需 无需 无需 所含给定的名称和整数值的响应报头。

HTTP Header 响应实例:

//导入必需的 java 库
import java.io.IOException;
import java.io.PrintWriter;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet("/Refresh")
//扩展 HttpServlet 类
public class Refresh extends HttpServlet {
    // 处理 GET 法律土办法请求的法律土办法
      public void doGet(HttpServletRequest request,
                        HttpServletResponse response)
                throws ServletException, IOException
      {
          // 设置刷新自动加载时间为 5 秒
          response.setIntHeader("Refresh", 5);
          // 设置响应内容类型
          response.setContentType("text/html;charset=UTF-8");
         
          //使用默认时区和语言环境获得无需

无需

无需

无需

日历  
          Calendar cale = Calendar.getInstance();  
          //将Calendar类型转加在Date类型  
          Date tasktime=cale.getTime();  
          //设置日期输出的格式  
          SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");  
          //格式化输出  
          String nowTime = df.format(tasktime);
          PrintWriter out = response.getWriter();
          String title = "自动刷新 Header 设置 - 菜鸟教程实例";
          String docType =
          "<!DOCTYPE html>\n";
          out.println(docType +
            "<html>\n" +
            "<head><title>" + title + "</title></head>\n"+
            "<body bgcolor=\"#f0f0f0\">\n" +
            "<h1 align=\"center\">" + title + "</h1>\n" +
            "<p>当前时间是:" + nowTime + "</p>\n");
      }
      // 处理 POST 法律土办法请求的法律土办法
      public void doPost(HttpServletRequest request,
                         HttpServletResponse response)
          throws ServletException, IOException {
         doGet(request, response);
      }
}

  以上测试实例是占据 TomcatTest 项目下,对应的 web.xml 配置为:

<?xml version="1.0" encoding="UTF-8"?>  
<web-app>  
  <servlet>  
     <!-- 类名 -->  
    <servlet-name>Refresh</servlet-name>  
    <!-- 所在的包 -->  
    <servlet-class>com.runoob.test.Refresh</servlet-class>  
  </servlet>  
  <servlet-mapping>  
    <servlet-name>Refresh</servlet-name>  同底下的类名
    <!-- 访问的网址 -->  
    <url-pattern>/TomcatTest/Refresh</url-pattern>  
    </servlet-mapping>  
</web-app> 

  现在,调用底下的 Servlet,每隔 5 秒会显示当前系统时间。

3、HTTP情况汇报码

404:服务器无法找到所请求的页面。

403:禁止访问所请求的页面。

401:所请求的页面须要用户名和密码。

405:在请求中指定的法律土办法是不允许的。

60 7:所请求的页面可能性临时转移到无需 无需 无需 无需 新的 URL。

60 0:未完成的请求。服务器遇到了无需 无需 无需 无需 意外的情况汇报。

  下面的法律土办法可用于在 Servlet tcp连接中设置 HTTP 情况汇报码。有有哪些法律土办法通过 HttpServletResponse 对象可用。

public void setStatus ( int statusCode )

该法律土办法设置无需 无需 无需 无需 任意的情况汇报码。setStatus 法律土办法接受无需 无需 无需 无需 int(情况汇报码)作为参数。可能性您的反应所含了无需 无需 无需 无需 特殊的情况汇报码和文档,请确保在使用 PrintWriter 实际返回任何内容前一天调用 setStatus。

public void sendError(int code, String message)

该法律土办法发送无需 无需 无需 无需 情况汇报码(通常为 404),连同无需 无需 无需 无需 在 HTML 文档外部自动格式化并发送到客户端的短消息。

// 设置错误代码和因为
response.sendError(407, "Need authentication!!!" );

4、Servlet接口&访问法律土办法介绍

  Servlet是实现了javax.servlet.Servlet接口的类,你无需 无需 接口规定了特定的法律土办法来处理特定的请求,大伙只须要实现Servlet相关的法律土办法,Servlet规范是建立在HTTP协议上的,http1.1规范支持OPTIONS/GET/POST/HEAD/PUT/DELETE/TRACE等7种访问法律土办法。下面大伙重点介绍Get/Post。

1、GET:表示查询信息,URL中附带少许参数信息,URL总长度不超过255个字符,参数还还可以 在浏览器的地址栏中显示

2、POST:表示提交信息,一般用于提交大数据信息可能性文件,提交的内容不收长度限制,无需 无需 无需 无需 会在地址栏中显示。

4、OPTIONS /PUT /DELETE /TRACE:是被声明了但还没法被使用web访问法律土办法,几乎无需。