HTTP响应

HTTP响应分为四个部分:

  1. 首行:HTTP/1.1(首行)  200(状态码)  OK(状态码描述)
  2. header:
  3. 空行:表示header的结束标记
  4. body:正文

HTTP状态码:描述了这次响应的结果(成功??失败??原因是啥??

  • 200:OK:成功了
  • 404:NOT FOUND:访问资源不存在——》在服务器中没找到
  • 403:FORBIDDEN:访问被拒绝(没有权限)
  • 302:Move trmporarily:重定向(类似于呼叫转换)

    教务系统申请个域名,过了一段时间,要换个域名,若换了域名,那么,老学员咋整??可以配置个重定向,如果老学员访问旧域名,则自带跳转到新的域名

    302这样的响应报文中,会在header里带有个location属性,通过这个属性来描述要跳转到哪个新的地址??

    所谓的重定向是指:可以重定向到外部资源的(跳转到别的网站)

下面我们来看一个图,来了解一下重定向与请求转发之间的区别??

  • 505:服务器内部错误(服务器代码抛异常了)
  • gateway timeout(响应时间太久了,浏览器等不了了)

其实,这么多状态码,可以分为几个大类的:

  • 2**:成功
  • 3**:重定向
  • 4**:客户端错误
  • 5**:服务器错误

HTTP协议里,有不少地方是程序员可以自定义的!!

  1. URL中的路径
  2. URL中的query string
  3. header中的键值对
  4. header中的cookie的键值对
  5. body

学习HTTP很好的办法,就是写爬虫,写一个程序,作为HTTP客户端,构造各种HTTP请求,通过这些请求,来获取你想要的一些效果~~,当然,爬虫犯法,轻易不做!!

那么,我们如何来构造一个HTTP请求呢??(代码)

对于GET/POST请求,我们可以通过form标签来进行构造,这也是比较常见/重要的前后端交互的方式!

对于GET请求,可以通过在form标签中设置method属性为"get"来构造HTTP请求。例如:

<body><form action="https://sogou.com" method="get"><input type="text" name="key" value="value"><input type="submit" value="提交"></form>      
</body>
在这个例子中,当用户点击提交按钮时,浏览器会发送一个GET请求到"https://sogou.com"。

根据结果,我们可以看到,这个请求,搜狗的服务器没有做啥特别的处理,仍然是普普通通的返回搜狗的主页了!!

当然,在后续咱们自己写的服务器代码,就可以根据需要,来获取URL中的query string ,从而完成不同的功能!!

form标签只能构造GET和POST,无法构造PUT,DELETE,OPTIONS等方法的请求!!

另外还有一种功能更强大的,构造http请求的方式,Ajax(读法:阿加克斯)

Ajax也是浏览器提供的一种,通过js构造http请求的方式!!

a——》异步的!asynchronize

  1. 同步的等待:我一直死死盯着女神宿舍门口,等待对象一露头,就立马扑上去!
  2. 异步的等待:我找个阴凉地方坐下,并拿出一本Java书,读得津津有味,等到对象出来以后,她再来喊我~~

综上:A等待B

  • 同步:A始终盯着B,A负责关注B啥时候就绪
  • 异步:A不盯着B,B就绪之后主动通知A

HTML中,通过Ajax的方式发起HTTP请求,就属于“异步”的方式!

这一行代码执行“发送请求”,操作之后,不必等待服务器响应回来,就可以立即先往下执行,当服务器的响应回来了之后,再由浏览器通知到咱们的代码中!

那么,在代码中,如何使用Ajax呢??

  1. js原生提供了Ajax的api,但是原生api特别难用!!
  2. jquery提供的Ajax,api针对原生api的封装,简单很多!!
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><!-- <form action="https://sogou.com" method="get"><input type="text" name="key" value="value"><input type="submit" value="提交"></form>       --><!-- 引入jquery --><script src="https://code.jquery.com/jquery-3.6.0.min.js"></script><script>$.ajax({type: "GET",url: "https://www.sogou.com?studentName=zhangsan",success: function(data) {console.log("当服务器返回的响应达到浏览器之后,浏览器触发该回调,通知到咱们的代码中");},error: function(jqXHR, textStatus, errorThrown) {console.log("请求失败,错误信息:", textStatus, errorThrown);}});console.log("浏览器立即往下,执行后续代码");</script>
</body>
</html>

注意:该代码直接执行,只能看到构造的请求,无法获取到正确的响应,因为,发送请求给搜狗的服务器,人家的服务器没有处理咱们的响应,等后面咱们自己能写服务器了之后,就可以给咱们自己的服务器发请求,自然就能够处理了!!

和form标签相比,Ajax功能更强!

  1. Ajax支持PUT ,DELETE等方法
  2. Ajax发送的请求可以灵活设置header
  3. Ajax发送的body也是可以灵活设置的

测试——》免不了需要构造HTTP,写代码构造吗??

其实还有更方便的构造HTTP请求的方式:使用第三方工具:postman

postman(课堂上使用的,也是未来在各大公司经常用的)

postman可以生成构造请求的代码,方便咱们在自己的程序中集成!!

 HTTPS——》HTTP+安全层(SSL):SSL是用来加密的协议(SSL/TLS)

在这里,就需要提一下:臭名恶照的运营商劫持事件!

网络上,如果文明传输数据是非常危险的!!需要加密才能保证安全!!

HTTPS其实主要是涉及到其中的SSL部分!

SSL并非仅仅是在HTTPS中使用,在其他地方也可也使用!

进行安全传输核心就是加密!

加密:其中一种最简单有效的办法,叫做:对称加密!!

a(明文)+key(密钥)——》b(密文)  :加密的过程

b(密文)+key(密钥)——》a(明文)  :解密的过程

对称加密的安全性的前提是:密钥不能被黑客知道!!

非对称加密:

服务器生成的一对密钥:公钥+私钥

明文+公钥——》密文  :使用公钥加密

密文+私钥——》明文  :使用私钥解密

当然反过来也可以:

明文+私钥——》密文  :使用私钥加密

密文+公钥——》明文  :使用公钥解密

公钥可以公开,私钥是私藏的!

在这儿就不得不说一下著名的:中间人攻击事件了!(感兴趣的可 自行百度搜索)中间人攻击_百度百科

解决中间人攻击的关键,在于让客户端能够辨别,当前这个响应(公钥)是服务器真实的公钥

这就需要引入一个“证书”(本质上是引入第三方的公证机构!)

  1. 引入对称加密,针对业务数据
  2. 让服务器生成一对非对称密钥,公钥1 和私钥1,把公钥1连同证书一起发送给客户端(自己持有私钥)
  3. 客户端拿到证书进行校验,拿着颁发证书的认证机构提供的公钥2,对于证书的签名进行解密,计算校验和是否匹配
  4. 客户端拿着服务器发来的公钥1针对对称密钥进行加密,发给服务器!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/144965.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C#实现数据导出任一Word图表的通用呈现方法及一些体会

疲惫的修改 应人才测评产品的需求&#xff0c;导出测评报告是其中一个重要的环节&#xff0c;报告的文件类型也多种多样&#xff0c;其中WORD输出也扮演了一个重要的角色。 实现方法比较简单&#xff0c;结合分析结果数据&#xff0c;通过WORD模板文件进行替换输出。在实现的…

BadNets: Identifying Vulnerabilities in the Machine Learning Model Supply Chain

BadNets: Identifying Vulnerabilities in the Machine Learning Model Supply Chain----《BadNets:识别机器学习模型供应链中的漏洞》 背景&#xff1a; 许多用户将训练过程外包给云计算&#xff0c;或者依赖于经过训练的模型&#xff0c;然后根据特定的任务对模型进行微调。这…

Homeassistant docker配置

Homeassistant docker配置 【说明】本系列为自用教程&#xff0c;记录以便下次使用 【背景】一台J1900 4G64G的小主机&#xff0c;安装了OP系统&#xff0c;里面自带了Docker。为实现Homeassistant&#xff08;简称HA&#xff09;控制智能家居设备&#xff0c;进行如下配置。 【…

改进YOLO系列 | YOLOv5/v7 引入 Dynamic Snake Convolution | 动态蛇形卷积

准确分割拓扑管状结构,如血管和道路,在各个领域中至关重要,可以确保下游任务的准确性和效率。然而,许多因素使任务复杂化,包括细小的局部结构和可变的全局形态。在这项工作中,我们注意到管状结构的特殊性,并利用这一知识来引导我们的DSCNet,以在三个阶段同时增强感知:…

使用反射拼接SQL语句 和 使用 反射 + 注解 拼接SQL语句

以下知识本人都是用 Maven工程 总结的 1、使用反射拼接SQL语句 package com.csdn.anno; import java.io.IOException; import java.io.InputStream; import java.lang.reflect.Field; import java.util.Properties; public class AnnotationTest {public static void main(Str…

JVM 堆外内存查看方法

JVM 堆外内存查看方法 概述 是否曾经想过为什么Java应用程序通过众所周知的*-Xms和-Xmx调整标志消耗的内存比指定的数量大得多 &#xff1f;由于各种原因和可能的优化&#xff0c;JVM可能会分配额外的本机内存。这些额外的分配最终可能使消耗的内存超出-Xmx* 限制。在本教程中…

vue源码笔记之——响应系统

vue是一种声明式范式编程&#xff0c;使用vue者只需要告诉其想要什么结果&#xff0c;无需关心具体实现&#xff08;vue内部做了&#xff0c;底层是利用命令式范式&#xff09; 1. reactive为什么只能操作对象&#xff0c;对于基本数据类型&#xff0c;需要用ref&#xff1f; …

YOLOv8改进实战 | 更换主干网络Backbone之2023最新模型LSKNet,旋转目标检测SOTA

前言 传统的YOLOv8系列中,Backbone采用的是较为复杂的C2f网络结构,这使得模型计算量大幅度的增加,检测速度较慢,应用受限,在某些真实的应用场景如移动或者嵌入式设备,如此大而复杂的模型时难以被应用的。为了解决这个问题,本章节通过采用LSKNet轻量化主干网络作为Backb…

【技能树笔记】网络篇——练习题解析(八)

目录 前言 一、LAN技术 1.1 堆叠与集群 1.2 MSTP的特点 二、WAN技术 2.1 PPP链路建立 2.2 PPPoE 2.3 组播 2.3.1 组播的IP 2.3.2 组播分发树 2.3.3 组播协议 三、IPv6基础 3.1 IPv6地址 3.2 IPv6协议 3.3 IPv6过渡技术 总结 &#x1f308;嗨&#xff01;我是Filotimo__&#x1…

用python计算积分

先安装这个包 pip install scipy运行 import tkinter as tk from scipy.integrate import quad# 创建主窗口 root tk.Tk() root.title("积分计算器")# 定义计算积分的函数 def calculate_integral():# 获取用户输入的函数表达式function function_entry.get()# 获…

Android 10.0 Launcher3定制化之动态时钟图标功能实现

1.概述 在10.0的系统产品rom定制化开发中,在Launcher3中的定制化的一些功能中,对于一些产品要求需要实现动态时钟图标功能,这就需要先绘制时分秒时针表盘,然后 每秒刷新一次时钟图标,时钟需要做到实时更新,做到动态时钟的效果,接下来就来分析这个功能的实现 如图: 2.动…

基于指数分布优化的BP神经网络(分类应用) - 附代码

基于指数分布优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码 文章目录 基于指数分布优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码1.鸢尾花iris数据介绍2.数据集整理3.指数分布优化BP神经网络3.1 BP神经网络参数设置3.2 指数分布算法应用 4.测试结果…