学习前端web的心路历程------Servlet相关知识点及HTTP协议


在这里插入图片描述

Servlet其他知识点

  1. 概念
  2. 步骤
  3. 执行原理
  4. 生命周期

  5. Servlet3.0 注解配置

6.Servlet的体系结构

Servlet -- 接口
	|
GenericServlet -- 抽象类
	|
HttpServlet  -- 抽象类

* GenericServlet:将Servlet接口中其他的方法做了默认空实现,只将service()方法作为抽象
	* 将来定义Servlet类时,可以继承GenericServlet,实现service()方法即可

* HttpServlet:对http协议的一种封装,简化操作
	1. 定义类继承HttpServlet
	2. 复写doGet/doPost方法

7.Servlet相关配置

1. urlpartten:Servlet访问路径
  1. 一个Servlet可以定义多个访问路径 : @WebServlet({"/d4","/dd4","/ddd4"})
  2. 路径定义规则:
	1. /xxx:路径匹配
	2. /xxx/xxx:多层路径,目录结构
	3. *.do:扩展名匹配

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=zhangsan	

HTTP协议

请求消息:客户端发送给服务器端的数据

* 数据格式:
	1. 请求行
	2. 请求头
	3. 请求空行
	4. 请求体

响应消息:服务器端发送给客户端的数据

* 数据格式:
  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>

在这里插入图片描述

  • 19
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 18
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

铅华殿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值