Servlet(java web基础篇)

servletjava web基础篇)

Servlet是Java提供的一门动态web资源开发技术,不同的用户访问看到的效果不一样。Servlet是lavaEE规范之一,其实就是一个接口,将来我们需要定义Servlet类实现Servlet:接口,并由web服务器运行Servlet。

快速入门

创建web项目,导入Servlet依赖坐标
<dependency>
	<groupId>javax.servlet</groupId>
	<artifactId>javax.servlet-api</artifactId>
	<version>3.1.0</version>
    <!--依赖范围-->
	<scope>provided</scope>
</dependency>
创建:定义一个类,实现Servlet接口,并重写接口中所有方法,并在service方法中输入一句话
public class ServletDemo1 implements Servlet{
    public void service(...){
        System.out.println("hello servlet~")
    }
}
配置:在类上使用@WebServlet注解,配置该Servlet的访问路径
@WebServlet("/demo1")
public class ServletDemo1 implements Servlet{}
访问:启动Tomcat,浏览器输入URL访问该Servlet
http://localhost:8080/web-demo/demo1

Servlet执行流程

在上面的流程中,我们只实现了类,但没有实例化对象,但在输入URL时,我们能够打印输出,因此对于Servlet执行流程进行学习时必要的。

http://localhost:8080  可以访问到Tomcat服务器
/web-demo				可以访问到项目
/demo1					可以访问到资源Servlet
Web服务器创建Servlet对象,并调用了Servlet()方法 和 Service()方法

Servlet生命周期

对象的生命周期指一个对象从被创建到被销毁的整个过程。
Servlet)运行在Servlet容器(web服务器)中,其生命周期由容器来管理,分为4个阶段:

  • 加载和实例化:默认情况下,当Servlet第一次被访问时,由容器创建Servlet)对象

    @WebServlet(urlPatterns ="/demo",loadOnStartup=1)
    
    • 负整数:第一次被访问时创建Servlet对象
    • 0或正整数:服务器启动时创建Servlet)对象,数字越小优先级越高
  • 初始化:在Servlet实例化之后,容器将调用Servlet的init()方法初始化这个对象,完成一些如加载配置文件、创建连接等初始化的工作。该方法只调用一次

  • 请求处理:每次请求Servlet时,Servlet容器都会调用Servlet的service()方法对请求进行处理。

  • 服务终止:当需要释放内存或者容器关闭时,容器就会调用Servlet实例的destroy(方法(只调用一次)完成资源的释放。在destroy()方法调用之后,容器会释放这个Servlet实例,该实例随后会被 Java 的垃圾收集器所回收

// 获取ServletConfig对象  通过设置全局变量,来保留init方法中的config,用来返回tConfig
ServletConfig getServletConfig()
// 获取Servlet信息 返回作者、版本以及版权信息
String getServletInfo()

Servlet体系结构

Servlet(Servlet体系根接口) <- GenericServlet(Servlet抽象实现类) <- HttpServlet(HTTP协议封装的Servlet实现类)
//所以接下来自定义Servlet,会继承HttpServlet,重写doGet方法 Get 请求方式处理逻辑   doPost方法  Post 请求方式处理逻辑
package javax.servlet.http;

import javax.servlet.GenericServlet;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import java.io.IOException;

public abstract class HttpServlet extends GenericServlet implements java.io.Serializable {

    // ... 其他成员变量和方法

    @Override
    public void service(ServletRequest req, ServletResponse res) throws ServletException, IOException {
        HttpServletRequest request;
        HttpServletResponse response;

        // 检查请求和响应是否是HttpServletRequest和HttpServletResponse的实例
        try {
            request = (HttpServletRequest) req;
            response = (HttpServletResponse) res;
        } catch (ClassCastException e) {
            throw new ServletException("Non-HTTP request or response");
        }

        // 根据请求方法调用相应的处理方法
        String method = request.getMethod();
        if (method.equals("GET")) {
            doGet(request, response);
        } else if (method.equals("POST")) {
            doPost(request, response);
        } else if (method.equals("PUT")) {
            doPut(request, response);
        } else if (method.equals("DELETE")) {
            doDelete(request, response);
        } else {
            // 其他HTTP方法的处理
            // ...
        }
    }

    // ... 其他方法,如doGet、doPost等
    @Override
    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        // 处理HTTP GET请求
        response.setContentType("text/html");
        PrintWriter out = response.getWriter();
        out.println("<html><body>");
        out.println("<h2>Hello, this is my custom HttpServlet for GET!</h2>");
        out.println("</body></html>");
    }

    @Override
    public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        // 处理HTTP POST请求
        response.setContentType("text/html");
        PrintWriter out = response.getWriter();
        out.println("<html><body>");
        out.println("<h2>Hello, this is my custom HttpServlet for POST!</h2>");
        out.println("</body></html>");
    }
    // ... 其他实现和逻辑

}

相对于普通的ServletHttpServlet的好处包括:

  1. 专注于HTTP协议: HttpServlet是专门设计用来处理HTTP请求和响应的,它在Servlet的基础上提供了更高层次的抽象,让开发者更容易处理HTTP协议相关的内容。
  2. 提供更简洁的API: HttpServlet提供了一系列的方法,如doGetdoPostdoPut等,方便开发者根据不同的HTTP请求类型编写相应的业务逻辑。
  3. 易于扩展: 开发者可以继承HttpServlet并覆盖相应的方法,轻松扩展和定制自己的HTTP处理逻辑,而无需处理HTTP协议的底层细节。
  4. 提供请求参数解析: HttpServlet提供了方便的方法来获取HTTP请求中的参数,简化了参数解析的流程。
  5. 支持Session管理: HttpServlet提供了对HTTP Session的支持,方便开发者在Web应用中管理用户的状态信息。

在实际开发中,特别是在Java EE或Spring等框架中,通常会优先使用HttpServlet,因为它提供了更高级别、更方便的API,使得开发者能够更轻松地处理HTTP请求和构建Web应用。

Servlet urlPattern配置

Servlet要想被访问,必须配置其访问路径(urlPattern)

  • 一个Servlet,可以配置多个urlPattern

    @WebServlet(urlPatterns {"/demo1","/demo2"})
    
  • urlPattern配置规则

    • 精确匹配

      • 配置路径

        @WebServlet("/user/select")
        
      • 访问路径

        localhost:8080/web-demo/user/select
        
    • 目录匹配(精确匹配要大于目录匹配)

      • 配置路径

        @WebServlet("/user/*")
        
      • 访问路径

        localhost:8080/web-demo/user/aaa
        localhost:8080/web-demo/user/bbb
        
    • 扩展名匹配(目录路径 > 扩展名路径)

      • 配置路径

        @WebServlet("*.do")
        
      • 访问路径

        localhost:8080/web-demo/aaa.do
        localhost:8080/web-demo/bbb.do
        
    • 任意匹配

      • 配置路径

        @WebServlet("/")
        @WebServlet("/*")
        /***
        /和/*区别:
        	当我们的项目中的Servlet配置了"/",会覆盖掉tomcat中的
        	DefaultServlet,当其他的url-pattern都匹配不上时都会走这
        	个Servlet
        	当我们的项目中配置了“/*”,意味着匹配任意访问路径
        ***/
        
      • 访问路径

        localhost:8080/web-demo/hehe
        localhost:8080/web-demo/haha
        

XML配置方式编写Servlet

Servlet从3.0版本后开始支持使用注解配置,3.0版本前只支持XML配置文件的配置方式。

  • 步骤:

    • 编写Servlet类

    • 在web.xml中配置该Servlet

      <!--servlet 全类名-->
      <servlet>
      	<servlet-name>demo5</servlet-name>
      	<servlet-class>***.web.servlet.ServletDemo5</servlet-class>
      </servlet>
      <!--servlet 访问路径-->
      <servlet-mapping>
      	<servlet-name>demo5</servlet-name>
      	<url-pattern>/demo5</url-pattern>
      </servlet-mapping>
      

Servlet优化

  • Web层的Servlet个数太多了,不利于管理和编写
  • 将Servlet进行归类,对于同一个实体的操作方法,写到一个Servleti中。比如:BrandServlet、UserServlet
优化步骤
  • 自定义Servlet,使用请求路径进行方法分发

    // BaseServlet
    public class BaseServlet extends HttpServlet{
        //根据请求的最后一段路径来进行方法分发
    	@override
    	protected void service(HttpServletRequest req,HttpServletResponse resp)throws ServletException,IOException{
            //1.获取请求路径
    		String uri = req.getRequestURI();  //  brand-case/brand/selectAll
    		//2.获取最后一段路径,方法名
    		int index = uri.lastIndexOf('/')
    		String methodName = uri.substring(index 1);//  /selectAll?selectALl?
    
    		//3.执行方法
    		//3.1获取BrandServlet  /UserServlet字节码对象Class
    		//谁调用我(this所在的方法),我(this)代表谁
    		//System.out.println(this);/BrandServlet?HttpServlet?BrandServlet
    		CLass<?extends BaseServLet> cls = this.getClass();
            //2.2获取方法Method对象 反射
    		try{
                Method method cls.getMethod(methodName,HttpServletRequest.class,HttpServletResponse.class);
    			// 2.3执行方法
    			method.invoke(this,req,resp);
            }catch (NoSuchMethodException e){
    			e.printstackTrace();
            }catch (IllegalA***essException e){
    			e.printStackTrace();
            }catch (InvocationTargetException e){
    			e.printstackTrace();
       		}
    }
    
  • 替换HttpServlet的根据请求方式进行方法分发

    // BrandServlet
    @WebServlet("/brand/*")
    public class BrandServlet extends BaseServlet{
    	public void selectAll(HttpServletRequest req,HttpServletResponse resp)throws ServletException,IOException{
    		System.out.println("brand selectAll...");
    	}
    	public void add(HttpServletRequest req,HttpServletResponse resp)throws ServletException,IOException{
    		System.out.println("brand add...");
    	} 
    }
    

如果觉得文章对您有帮助,请帮忙点赞或者收藏,如果在文章中发现什么错误或不准确的地方,欢迎与我交流。

转载请说明出处内容投诉
CSS教程_站长资源网 » Servlet(java web基础篇)

发表评论

欢迎 访客 发表评论

一个令你着迷的主题!

查看演示 官网购买