美文网首页
Servlet的两种配置方式:web.xml和@WebServl

Servlet的两种配置方式:web.xml和@WebServl

作者: 会微笑的leo | 来源:发表于2020-10-11 18:03 被阅读0次

Servlet3.0 以后,我们可以不需要在 web.xml 里面配置 servlet,只需要加上 @WebServlet 注解就可以修改该 Servlet 的属性了。

注解方式提升开发效率,但是学习阶段两种方式还是都需要掌握的,弄清由来。

1.初始项目

  • javaweb-demo项目的树形结构图

  • demo-01demo-02是两个module(两个web工程),便于区分两种配置方式

  • demo-01使用web.xml配置servlet

  • demo-02使用@WebServlet配置servlet

2.web.xml配置(传统配置)

  • 原始的web.xml文件长这个亚子
 <?xml version="1.0" encoding="UTF-8"?>
 <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
  version="4.0">
 </web-app>
  • 创建一个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("/helloServlet")
     public class helloServlet extends HttpServlet {
      @Override
      protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
          req.setCharacterEncoding("utf-8");
          resp.setCharacterEncoding("utf-8");
     ​
          PrintWriter writer = resp.getWriter();
          writer.write("hello Servlet ");
      }
     ​
      @Override
      protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
          doGet(req, resp);
      }
     }
  • web.xml注册这个servlet
     <?xml version="1.0" encoding="UTF-8"?>
     <web-app xmlns = "http://xmlns.jcp.org/xml/ns/javaee"
      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
      xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
      version="4.0"
      <!--metadata-complete="true"-->
      >
     ​
      <servlet>
          <servlet-name>hello</servlet-name>
          <servlet-class>com.hu.servlet.helloServlet</servlet-class>
      </servlet>
      <servlet-mapping>
          <servlet-name>hello</servlet-name>
          <url-pattern>/hello</url-pattern>
      </servlet-mapping>
     ​
     </web-app>
  • servlet-name: servlet的名字

  • servlet-class:你所写的servlet的类名

  • servelt-mapping

    • servlet-name:匹配查找注册好的servlet

    • url-pattern:访问路径

    http://localhost:8080/项目名称/hello

重要的事情说三遍!

这里需要注意的是我上面把metadata-complete注释掉了,这个属性当设置为true,则容器在部署时只依赖部署描述文件,忽略所有的注解(同时也会跳过web-fragment.xml的扫描,亦即禁用可插性支持);如果设置为false或不配置该属性,则表示启用注解支持(和可插性支持)。

这里需要注意的是我上面把metadata-complete注释掉了,这个属性当设置为true,则容器在部署时只依赖部署描述文件,忽略所有的注解(同时也会跳过web-fragment.xml的扫描,亦即禁用可插性支持);如果设置为false或不配置该属性,则表示启用注解支持(和可插性支持)。

这里需要注意的是我上面把metadata-complete注释掉了,这个属性当设置为true,则容器在部署时只依赖部署描述文件,忽略所有的注解(同时也会跳过web-fragment.xml的扫描,亦即禁用可插性支持);如果设置为false或不配置该属性,则表示启用注解支持(和可插性支持)。

3.使用注解方式配置(@WebServlet

这种方式就很方便了,不需要在web.xml写上一大堆的东西,就只用在servlet类写上@WebServlet("/helloServlet2")

 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("/helloServlet2")
 public class helloServlet2 extends HttpServlet {
  @Override
  protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
      req.setCharacterEncoding("utf-8");
      resp.setCharacterEncoding("utf-8");
 ​
      PrintWriter writer = resp.getWriter();
      writer.write("hello Servlet2 ");
  }
 ​
  @Override
  protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
      doGet(req, resp);
  }
 }

http://localhost:8080/项目名称/helloServlet

4.web.xml和@WebServlet注解同时使用?

答案是可以的,应用场景目前我还没遇到,初学者没有必要这样去使用,推荐选择使用servlet新的注解方式,十分方便。

参考文档介绍获取更详细的信息

Servlet3.0新特性讲解

相关文章

网友评论

      本文标题:Servlet的两种配置方式:web.xml和@WebServl

      本文链接:https://www.haomeiwen.com/subject/bciepktx.html