大家好,今天分享一下@WebServlet注解
首先,我们要知道,我们要写一个servlet程序,web,xml里的配置项很重要,里面包含了很多关于类绑定,以及服务器资源的请求路径问题(就是注册)
先把我这个看一遍,这个原生的servlet程序
将这里的servlet 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"
metadata-complete="true">
<!-- 这是注册servlet-->
<servlet>
<servlet-name>hi</servlet-name>
<!-- hi 可以随便写,是一个别名-->
<servlet-class >ceshi.FirstServlet</servlet-class>
<!-- 这里一定要指向我们自己刚才写的类,写清楚它所在的具体路径-->
</servlet>
<!-- 这是配置它的请求路径-->
<servlet-mapping>
<servlet-name > hi</servlet-name>
<!-- 可以随便写,就是一个别名-->
<url-pattern >/hi</url-pattern>
<!-- 通过别名引用一个类,给它设置一个网络访问路径(网名),它必须以/开头。 -->
</servlet-mapping>
</web-app>
因为, 在你依然使用原生代码进行项目开发的前提之下,你的项目里不可能只有一个页面,那就要写很多个servlet程序 ,每一个servlet程序在web.xml当中都要一次一对一的的绑定, 随着绑定的次数越来越多,就会变得难以维护
就是在这种情况下,我们使用@WebServle注解来取代原先servlet在web.xml中繁琐的配置
有关于这个@WebServle注解有几个点
- 它是servlet3.0 提出的
- 它实现的效果和原先servlet在web.xml中 配置是一模一样的
这个@WebServle注解有几个常用的属性
看这个
这三个是常用的
看上面三个属性, 其实是和下面的标签属性是对应的, 或者说等效的
回来再看我们原生的配置
<?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>
<servlet-name>hi</servlet-name>
<!-- hi 可以随便写,是一个别名-->
<servlet-class >ceshi.FirstServlet</servlet-class>
<!-- 这里一定要指向我们自己刚才写的类,写清楚它所在的具体路径-->
</servlet>
<!-- 这是配置它的请求路径-->
<servlet-mapping>
<servlet-name > hi</servlet-name>
<!-- 可以随便写,就是一个别名-->
<url-pattern >/hi</url-pattern>
<!-- 通过别名引用一个类,给它设置一个网络访问路径(网名),它必须以/开头。 -->
</servlet-mapping>
</web-app>
name 和 <servlet-name>hi</servlet-name>
是等效的
value 和 urlPatterns属性
是等效的(就是一样的效果),但是不可以同时使用
urlPattern和 <url-pattern >/hi</url-pattern>
是等效的
做个案例
选择webapp
起一个项目名
配置maven
搭建成功
导jar包
、
<dependencies>
<!--加入servlet依赖(servlet的jar)-->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
</dependency>
<!--jsp的依赖(jsp相关的jar加进来)-->
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>javax.servlet.jsp-api</artifactId>
<version>2.2.1</version>
</dependency>
</dependencies>
截图
看目录结构
创建一个package (不创建也可以)
写一个类(类名随你)
这样写一个最简单的servlet程序
(就是一个继承了HttpServlet 的类)
就是输出一句话,遇见你,真的好好
package shuaige.com;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
public class AnnotationServlet extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("遇见你,真的好好");
}
}
代码截图:(这样做,是为了让看我博客的人清晰的知道整个项目的目录结构)
加一个@WebServlet这样的注解
写上相应的属性
package shuaige.com;
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(name ="AnnotationServlet",value ="/ann")
public class AnnotationServlet extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("遇见你,真的好好");
}
}
点击这个位置
配置Tomcat
注意这个页面
这样做
这样做
启动Tomcat
请求我们写的路径
成功输出
到这里,我们有关于@WebServlet注解就到这里了,但是还是要强调一点:
1.首先我希望你可以将先把我这个看一遍
这是原生的servlet程序
2. 在整个过程当中,你会发现,我们根本没写web.xml
3. 我们使用注解的方式取代了web.xml
4. 其它的属性自己看看就行
好了,有关于@WebServlet注解的解释和使用就到这里,谢谢大家