Servlet and HTTP
一、Servlet
1、概念
1、servlet概念: server applet 可以在服务器端运行的小程序
- servlet是一个接口,是定义了java类被浏览器访问到(tomcat识别)的规则
- 要用到servlet 我们需要定义一个类去实现servlet接口,然后复写servlet的方法
2、执行步骤
**2、开始实践:**步骤
(1).创建JavaEE项目
(2).定义一个类,实现Servlet接口
如: public class ServletSimple implements Servlet
(3).实现接口中的抽象方法
(4).配置Servlet
<servlet>
<servlet-name>simple</servlet-name>
<servlet-class>Linyous.web.servlet.ServletSimple</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>simple</servlet-name>
<url-pattern>/simple</url-pattern>
</servlet-mapping>
3、执行原理
3、执行原理
1. 当服务器接受到客户端浏览器的请求后,会解析请求URL路径,获取访问的Servlet的资源路径
2. 查找web.xml文件,是否有对应的标签体内容。
3. 如果有,则在找到对应的全类名
4. tomcat会将字节码文件加载进内存,并且创建其对象
5. 调用其方法
4、生命周期
(1)、创建: 执行init方法,一般只执行一次(可以修改)
-
默认情况下,第一次被访问时,Servlet被创建
-
可以配置执行Servlet的创建时机。
-
在<servlet>标签下配置 1. 第一次被访问时,创建 * <load-on-startup>的值为负数 2. 在服务器启动时,创建 * <load-on-startup>的值为0或正整数
-
Servlet的 init方法,只执行一次,说明一个Servlet在内存中只存在一个对象,Servlet是单例的
⚠️在多个用户同时访问时,可能存在线程安全问题。
解决:尽量不要在Servlet中定义成员变量。即使定义了成员变量,也不要对修改值
(2)、操作运行: 执行service方法,这个方法可以多次执行
在每次访问Servlet时,service方法都会被调用一次
(3)、销毁 : 执行destroy方法,只执行一次
- 只有服务器正常关闭时,才会执行destroy方法。
- destroy方法在Servlet被销毁之前执行,一般用于释放资源
5、Servlet3.0 注解配置
5、Servlet 3.0
在servlet3.0后*支持注解配置。可以不需要web.xml了。
使用步骤
-
创建JavaEE项目,选择Servlet的版本3.0以上,可以不创建web.xml
-
定义一个类,实现Servlet接口
-
复写方法
-
在类上使用@WebServlet注解,进行配置
@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>
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 "";
}
6、Servlet的体系结构
GenericServlet: 将Servlet接口中其他的方法做了默认空实现,只将service()方法作为抽象
* 将来定义Servlet类时,可以继承GenericServlet,实现service()方法即可
HttpServlet: 对http协议的一种封装,简化操作
1. 定义类继承HttpServlet
2. 复写doGet/doPost方法
7、Servlet相关配置
urlpartten: Servlet访问路径
1、一个Servlet可以定义多个访问路径 : @WebServlet({“linyous1”,“linyous2”,“linyous3”})
2、路径定义的规则
(1). /xxx: 路径匹配
(2). /xxx/xxx:多层路径,目录结构
(3). *.do: 扩展名匹配
二、HTTP
1、概念
HTTP: Hyper Text Transfer Protocol 超文本传输协议
⚠️传输协议: 定义了 客户端和服务器端通信时发送数据的格式
HTTP的特点:
1. 基于TCP/IP的高级协议
2. 默认端口号:80
3. 基于请求/响应模型的:一次请求对应一次响应
4. 无状态的:每次请求之间相互独立,不能交互数据
HTTP的版本
1.0: 每一次请求响应都会建立新的连接
1.1:复用连接
2、请求消息数据格式
1、请求行
GET / Linyous.html HTTP/1.1
GET / Linyous.html HTTP/1.1
请求方式 请求url 请求协议/版本
HTTP的请求方式: 一共有七种,常见的有2种
1、GET:
(1). 请求参数在请求行中,在url后。
(2). 请求的url长度有限制的
(3). 不太安全
2、POST:
(1). 请求参数在请求体中
(2). 请求的url长度没有限制的
(3). 相对安全
2、请求头
**请求头:**客户端浏览器告诉服务器一些信息
请求头名称: 请求头值
常见的请求头:
1、User-Agent: 浏览器 响应 服务器,我访问你使用的浏览器版本信息
(可以在服务器端获取头的信息来解决浏览器的兼容性问题)
2、Referer: http://localhost/linyous.html
功能是告诉服务器,当前这个请求从哪里来
⚠️作用:
1. 防盗链
2. 统计数据
3、请求空行
空行,就是用于分割POST请求的请求头,和请求体的。
4、请求体
请求体(正文) 封装POST请求消息的请求参数的
从网站扒出来的字符串格式:
POST /Linyous.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