Servlet概念
servlet是一个运行在服务端的小程序
- servlet就是一个接口,定义了浏览器访问到java类的规则
- 我们自己定义一个类,实现servlet接口,复写方法,做好相关的配置就可以实现浏览器访问自己的java类(浏览器动态获取资源)
Servlet实现步骤
- 创建javaEE项目,配置好tomcat
- 定义一个类实现servlet接口,复写方法
- 在项目的web.xml中配置
<!--配置servlet-->
<servlet>
<servlet-name>demo</servlet-name>
<servlet-class>cn.wbe.servlet.ServletDemo</servlet-class>
</servlet>
<!--配置servlet映射(类似于访问路径),通过servletDemo映射找demo,然后通过demo找到真正访问的类-->
<servlet-mapping>
<servlet-name>demo</servlet-name>
<url-pattern>/servletDemo</url-pattern>
</servlet-mapping>
代码示例如下图
实现servlet接口
配置web.xml文件
运行结果如下图,访问一次,调用一次service方法
servlet执行原理
servlet的生命周期
- 被创建:执行init方法,只执行一次,默认情况是第一次访问的时候创建servlet对象
- 可以配置执行Servlet的创建时机,在servlet标签下增加一个 load-on-startup标签,根据值来决定创建时机
1.1 ----默认值为负数,表示servlet在第一次被访问时,创建
1.2 ----值为0或正整数,表示servlet在服务器启动时,创建
- 可以配置执行Servlet的创建时机,在servlet标签下增加一个 load-on-startup标签,根据值来决定创建时机
<servlet>
<servlet-name>demo</servlet-name>
<servlet-class>cn.wbe.servlet.ServletDemo</servlet-class>
<load-on-startup>5</load-on-startup>
</servlet>
- 提供服务:执行service方法,执行多次, 每次访问Servlet时,Service方法都会被调用一次
- 被销毁:执行destroy方法,只执行一次,只有服务器正常关闭时,才会执行destroy方法
------destroy方法在Servlet被销毁之前执行,一般用于释放资源
servlet3.0注解配置
- 创建javaEE项目,配置好tomcat
- 定义一个类实现servlet接口,复写方法
- 在类上使用@WebServlet注解,进行配置
@WebServlet(元素=值),有个特殊的value元素代表的是注解里面最重要的元素,value有个特殊的特性,就是属性只有一个的话value元素不用写,刚好@WebServlet中最重要的元素是urlPatterns,刚好我也只需要写一个属性,所以可以这样写@WebServlet(值)
@WebServlet注解如下
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface WebServlet {
String name() default "";//相当于<Servlet-name>
String[] value() default {};//代表urlPatterns()属性配置
String[] urlPatterns() default {};//相当于<url-pattern>
/*
urlpartten:Servlet访问路径
1. 一个Servlet可以定义多个访问路径 : @WebServlet({"/d","/dd","/ddd"}),代表多个路径访问同一个资源
2. 路径定义规则:
1. /xxx:路径匹配
2. /xxx/xxx:多层路径,目录结构
3. *.do:扩展名匹配,*号表示通配符
*/
int loadOnStartup() default -1;//相当于<load-on-startup>
WebInitParam[] initParams() default {};
boolean asyncSupported() default false;
String smallIcon() default "";
String largeIcon() default "";
String description() default "";
String displayName() default "";
}
IDEA会为每一个tomcat部署的项目单独建立一份配置文件
- 查看控制台的log:Using CATALINA_BASE: “C:\Users\Administrator.IntelliJIdea2019.3\system\tomcat\Tomcat_9_0_30_servletTest”
servlet体系结构
Servlet – 接口
|
GenericServlet – 抽象类
- GenericServlet:将Servlet接口中其他的方法做了默认空实现,只将service()方法作为抽象
将来定义Servlet类时,可以继承GenericServlet,实现service()方法即可
|
HttpServlet – 抽象类
- HttpServlet:对http协议的一种封装,简化操作,实现了service()方法,里面有根据请求方法判断调用doGet/doPost方法
1. 定义类继承HttpServlet
2. 复写doGet/doPost方法
代码示例
package cn.web.servlet;
import javax.servlet.GenericServlet;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.annotation.WebServlet;
import java.io.IOException;
@WebServlet(urlPatterns = "/demo2")
public class ServletDemo2 extends GenericServlet {
@Override
public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {
System.out.println("继承子类调用成功");
}
}
package cn.web.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;
@WebServlet(urlPatterns = "/demo3")
public class ServletDemo3 extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
System.out.println("doGet....");
}
}
HTTP协议:
* 概念:Hyper Text Transfer Protocol 超文本传输协议
* 传输协议:定义了,客户端和服务器端通信时,发送数据的格式
* 特点:
1. 基于TCP/IP的高级协议
2. 默认端口号:80
3. 基于请求/响应模型的:一次请求对应一次响应
4. 无状态的:每次请求之间相互独立,不能交互数据
* 历史版本:
* 1.0:每一次请求响应都会建立新的连接
* 1.1:复用连接(定时一段时间看是否还会有数据发送过来,如果没有则断开连接,有的话则复用这个连接接收数据)
* 请求消息数据格式
1. 请求行
请求方式 请求url 请求协议/版本
GET /login.html HTTP/1.1
* 请求方式:
* HTTP协议有7中请求方式,常用的有2种
* GET:
1. 请求参数在请求行中,在url后。
2. 请求的url长度有限制的
3. 不太安全
* POST:
1. 请求参数在请求体中
2. 请求的url长度没有限制的
3. 相对安全
2. 请求头:客户端浏览器告诉服务器一些信息
请求头名称: 请求头值
* 常见的请求头:
1. User-Agent:浏览器告诉服务器,我访问你使用的浏览器版本信息
* 可以在服务器端获取该头的信息,解决浏览器的兼容性问题
2. Referer:http://localhost/login.html
* 告诉服务器,我(当前请求)从哪里来?
* 作用:
1. 防盗链:
2. 统计工作:
3. 请求空行
空行,就是用于分割POST请求的请求头,和请求体的。
4. 请求体(正文):
* 封装POST请求消息的请求参数的
* 字符串格式:
POST /login.html HTTP/1.1 //请求行
Host: localhost //请求头
User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:60.0) Gecko/20100101 Firefox/60.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
Accept-Encoding: gzip, deflate
Referer: http://localhost/login.html
Connection: keep-alive
Upgrade-Insecure-Requests: 1
请求空行
username=lisi //请求体
* 响应消息数据格式:
1. 响应行
1.1 组成:协议/版本 响应状态码 状态码描述
1.2 响应状态码:服务器告诉客户端浏览器本次请求和响应的一个状态。
1. 状态码都是3位数字
2. 分类:
1. 1xx:服务器就收客户端消息,但没有接受完成,等待一段时间后,发送1xx多状态码
2. 2xx:成功。代表:200
3. 3xx:重定向。代表:302(重定向),304(访问缓存)
4. 4xx:客户端错误。
* 代表:
* 404(请求路径没有对应的资源)
* 405:请求方式没有对应的doXxx方法
5. 5xx:服务器端错误。代表:500(服务器内部出现异常)
2. 响应头:
1. 格式:头名称: 值
2. 常见的响应头:
1. Content-Type:服务器告诉客户端本次响应体数据格式以及编码格式
2. Content-disposition:服务器告诉客户端以什么格式打开响应体数据
* 值:
* in-line:默认值,在当前页面内打开
* attachment;filename=xxx:以附件形式打开响应体。文件下载
3. 响应空行
4. 响应体:传输的数据
* 响应字符串格式
HTTP/1.1 200 OK
Content-Type: text/html;charset=UTF-8
Content-Length: 101
Date: Wed, 06 Jun 2018 07:08:42 GMT
<html>
<head>
<title>$Title$</title>
</head>
<body>
hello , response
</body>
</html>