网络通信的奥秘:HTTP详解 (七)

通过form表单构造HTTP请求

  • action:构造的HTTP请求的URL是什么.
  • method:构造的HTTP请求的⽅法是GET还是POST(form只⽀持GET和POST). input的重要参数:
  • type:表⽰输⼊框的类型.text表⽰⽂本,password表⽰密码,submit表⽰提交按钮.
  • name:表⽰构造出的HTTP请求的querystring的key.querystring的value就是输⼊框的⽤⼾输 ⼊的内容.
  • value:input标签的值.对于type为submit类型来说,value就对应了按钮上显⽰的⽂本.

点击"提交",此时就会构造出HTTP请求并发送出去.

构造的HTTP请求

注意:由于我们的服务器的地址是随便写的,因此⽆法获取到正确的HTTP响应.

体会form代码和HTTP请求之间的对应关系

修改上⾯的代码,把form的method修改为POST

主要的区别:

  • method从GET变成了POST
  • 数据从querystring移动到了body中.

通过ajax构造HTTP请求

在JavaScript中可以通过ajax的⽅式构造HTTP请求.

发送GET请求

创建test.html,在<script>标签中编写以下代码

此处使⽤的是jquery的ajax,⽽不是原生ajax.原⽣ajax⽐较难⽤.

注意:如果把send中的地址改成其他服务器的地址(⽐如http://www.sogou.com/index.html这种), ⼤概率是会出错的.

错误形如:

这个错误是因为ajax默认不能"跨域",也就是"百度下⾯的html中的ajax不能访问搜狗的内容".这样的设定也是完全合理的.如果想要强⾏进⾏跨域,则需要服务器进⾏配合,在服务器的响应中"允许跨域"才可以.

浏览器和服务器交互过程(引⼊ajax后):

发送POST请求

对于POST请求,需要设置body的内容

  1. 先使⽤setRequestHeader设置Content-Type
  2. 再通过send的参数设置body内容. 发送application/x-www-form-urlencoded数据(数据格式同form的post)

发送application/json数据

通过Javasocket构造HTTP请求

所谓的"发送HTTP请求",本质上就是按照HTTP的格式往TCPSocket中写⼊⼀个字符串. 所谓的"接受HTTP响应",本质上就是从TCPSocket中读取⼀个字符串,再按照HTTP的格式来解析. 我们基于Socket的知识,完全可以构造出⼀个简单的HTTP客⼾端程序,⽤来发送各种类型的HTTP请求.

使⽤Java构造的HTTP客⼾端不再有"跨域"限制了,此时也可以⽤来获取其他服务器的数据了. 跨域只是浏览器的⾏为,对于ajax有效.对于其他语⾔来说⼀般都和跨域⽆关.

相关推荐
Ashlee_code2 小时前
BSS供应商:电信与金融领域的幕后支撑者
大数据·网络·金融·系统架构·跨境·金融机构·场外期权
节点小宝2 小时前
节点小宝免费版流量机制解析:点对点直连技术与备用流量设计
网络·网络协议·p2p
玖涯菜菜子3 小时前
申请软著,怎么快速整理软件源代码
软件工程
阿猿收手吧!3 小时前
windows本机vscode通过ssh免密登录远程linux服务器 && git push/pull 免密
服务器·windows·vscode
创业之路&下一个五年4 小时前
按照ip的转换为二进制的方式理解a\b\c类地址的边界
服务器·网络·tcp/ip
陌路204 小时前
Linux29初识网络:核心概念与分层逻辑
网络
skywalk81634 小时前
尝试Auto-coder.chat使用星河社区AIStudio部署的几个大模型:文心4.5-21b、Deepseek r1 70b、llama 3.1 8b
linux·服务器·人工智能·大模型·aistudio
huangdengji4 小时前
基于openresty反向代理、dns劫持、实现对http请求、响应内容抓包
网络协议·http·openresty
Acrelhuang5 小时前
覆盖全场景需求:Acrel-1000 变电站综合自动化系统的技术亮点与应用
大数据·网络·人工智能·笔记·物联网