在
Servlet3.0 以后
,我们可以不需要在 web.xml 里面配置 servlet,只需要加上@WebServlet
注解就可以修改该 Servlet 的属性了。
注解方式提升开发效率,但是学习阶段两种方式还是都需要掌握的,弄清由来。
1.初始项目
-
javaweb-demo项目的树形结构图
-
demo-01 和 demo-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新的注解方式,十分方便。
参考文档介绍获取更详细的信息
网友评论