mirror of
https://github.com/ZSCNetSupportDept/website.git
synced 2025-10-28 17:05:03 +08:00
94 lines
62 KiB
HTML
94 lines
62 KiB
HTML
<!doctype html>
|
||
<html lang="en" dir="ltr" class="blog-wrapper blog-post-page plugin-blog plugin-id-default" data-has-hydrated="false">
|
||
<head>
|
||
<meta charset="UTF-8">
|
||
<meta name="generator" content="Docusaurus v3.6.0">
|
||
<title data-rh="true">Web的历史1️⃣-HTTP | 中山学院网络维护科</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:image" content="https://developer.zsxyww.com/img/docusaurus-social-card.jpg"><meta data-rh="true" name="twitter:image" content="https://developer.zsxyww.com/img/docusaurus-social-card.jpg"><meta data-rh="true" property="og:url" content="https://developer.zsxyww.com/blog/Web的历史1️⃣-HTTP"><meta data-rh="true" property="og:locale" content="en"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docusaurus_tag" content="default"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="docsearch:docusaurus_tag" content="default"><meta data-rh="true" property="og:title" content="Web的历史1️⃣-HTTP | 中山学院网络维护科"><meta data-rh="true" name="description" content="注:这些文章本来是打算作为开发组后端培训文本的开篇而写的,但是我发现文章的内容过于复杂且有点离题,所以稍微修改了一下单独作为3篇独立的文章发布。"><meta data-rh="true" property="og:description" content="注:这些文章本来是打算作为开发组后端培训文本的开篇而写的,但是我发现文章的内容过于复杂且有点离题,所以稍微修改了一下单独作为3篇独立的文章发布。"><meta data-rh="true" property="og:type" content="article"><meta data-rh="true" property="article:published_time" content="2025-07-13T03:23:58.000Z"><link data-rh="true" rel="icon" href="/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://developer.zsxyww.com/blog/Web的历史1️⃣-HTTP"><link data-rh="true" rel="alternate" href="https://developer.zsxyww.com/blog/Web的历史1️⃣-HTTP" hreflang="en"><link data-rh="true" rel="alternate" href="https://developer.zsxyww.com/blog/Web的历史1️⃣-HTTP" hreflang="x-default"><script data-rh="true" type="application/ld+json">{"@context":"https://schema.org","@type":"BlogPosting","@id":"https://developer.zsxyww.com/blog/Web的历史1️⃣-HTTP","mainEntityOfPage":"https://developer.zsxyww.com/blog/Web的历史1️⃣-HTTP","url":"https://developer.zsxyww.com/blog/Web的历史1️⃣-HTTP","headline":"Web的历史1️⃣-HTTP","name":"Web的历史1️⃣-HTTP","description":"注:这些文章本来是打算作为开发组后端培训文本的开篇而写的,但是我发现文章的内容过于复杂且有点离题,所以稍微修改了一下单独作为3篇独立的文章发布。","datePublished":"2025-07-13T03:23:58.000Z","author":[],"keywords":[],"isPartOf":{"@type":"Blog","@id":"https://developer.zsxyww.com/blog","name":"Blog"}}</script><link rel="alternate" type="application/rss+xml" href="/blog/rss.xml" title="中山学院网络维护科 RSS Feed">
|
||
<link rel="alternate" type="application/atom+xml" href="/blog/atom.xml" title="中山学院网络维护科 Atom Feed"><link rel="stylesheet" href="/assets/css/styles.6a14feb4.css">
|
||
<script src="/assets/js/runtime~main.75faf0df.js" defer="defer"></script>
|
||
<script src="/assets/js/main.1799b9a7.js" defer="defer"></script>
|
||
</head>
|
||
<body class="navigation-with-keyboard">
|
||
<script>!function(){function t(t){document.documentElement.setAttribute("data-theme",t)}var e=function(){try{return new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}}()||function(){try{return window.localStorage.getItem("theme")}catch(t){}}();null!==e?t(e):window.matchMedia("(prefers-color-scheme: dark)").matches?t("dark"):(window.matchMedia("(prefers-color-scheme: light)").matches,t("light"))}(),function(){try{const c=new URLSearchParams(window.location.search).entries();for(var[t,e]of c)if(t.startsWith("docusaurus-data-")){var a=t.replace("docusaurus-data-","data-");document.documentElement.setAttribute(a,e)}}catch(t){}}()</script><div id="__docusaurus"><div role="region" aria-label="Skip to main content"><a class="skipToContent_fXgn" href="#__docusaurus_skipToContent_fallback">Skip to main content</a></div><nav aria-label="Main" class="navbar navbar--fixed-top"><div class="navbar__inner"><div class="navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/"><div class="navbar__logo"><img src="/img/logo.svg" alt="ZSCNetworkSupport_logo" class="themedComponent_mlkZ themedComponent--light_NVdE"><img src="/img/logo.svg" alt="ZSCNetworkSupport_logo" class="themedComponent_mlkZ themedComponent--dark_xIcU"></div><b class="navbar__title text--truncate">ZSCNetworkSupport</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/">首页</a><a class="navbar__item navbar__link" href="/docs/wiki/首页">wiki</a><a class="navbar__item navbar__link" href="/docs/devdocs/首页">开发组文档</a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/blog">文章</a></div><div class="navbar__items navbar__items--right"><a href="https://github.com/ZSCNetSupportDept/" target="_blank" rel="noopener noreferrer" class="navbar__item navbar__link">GitHub<svg width="13.5" height="13.5" aria-hidden="true" viewBox="0 0 24 24" class="iconExternalLink_nPIU"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"></path></svg></a><div class="toggle_vylO colorModeToggle_DEke"><button class="clean-btn toggleButton_gllP toggleButtonDisabled_aARS" type="button" disabled="" title="Switch between dark and light mode (currently light mode)" aria-label="Switch between dark and light mode (currently light mode)" aria-live="polite" aria-pressed="false"><svg viewBox="0 0 24 24" width="24" height="24" class="lightToggleIcon_pyhR"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" class="darkToggleIcon_wfgR"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><div class="navbarSearchContainer_Bca1"><div class="navbar__search searchBarContainer_NW3z" dir="ltr"><input placeholder="Search" aria-label="Search" class="navbar__search-input searchInput_YFbd"><div class="loadingRing_RJI3 searchBarLoadingRing_YnHq"><div></div><div></div><div></div><div></div></div></div></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="__docusaurus_skipToContent_fallback" class="main-wrapper mainWrapper_z2l0"><div class="container margin-vert--lg"><div class="row"><aside class="col col--3"><nav class="sidebar_re4s thin-scrollbar" aria-label="Blog recent posts navigation"><div class="sidebarItemTitle_pO2u margin-bottom--md">Recent posts</div><div role="group"><h3 class="yearGroupHeading_rMGB">2025</h3><ul class="sidebarItemList_Yudw clean-list"><li class="sidebarItem__DBe"><a aria-current="page" class="sidebarItemLink_mo7H sidebarItemLinkActive_I1ZP" href="/blog/Web的历史1️⃣-HTTP">Web的历史1️⃣-HTTP</a></li><li class="sidebarItem__DBe"><a class="sidebarItemLink_mo7H" href="/blog/Web的历史2️⃣-动态网页">Web的历史2️⃣-动态网页</a></li><li class="sidebarItem__DBe"><a class="sidebarItemLink_mo7H" href="/blog/Web的历史3️⃣-Web应用">Web的历史3️⃣-Web应用</a></li><li class="sidebarItem__DBe"><a class="sidebarItemLink_mo7H" href="/blog/2025/5/9/女生宿舍的网络结构解释">女生宿舍的网络结构解释</a></li></ul></div><div role="group"><h3 class="yearGroupHeading_rMGB">2024</h3><ul class="sidebarItemList_Yudw clean-list"><li class="sidebarItem__DBe"><a class="sidebarItemLink_mo7H" href="/blog/2024/09/27/给纯新手的网维快速入门指南">给纯新手的网维快速入门指南</a></li></ul></div></nav></aside><main class="col col--7"><article><header><h1 class="title_f1Hy">Web的历史1️⃣-HTTP</h1><div class="container_mt6G margin-vert--md"><time datetime="2025-07-13T03:23:58.000Z">July 13, 2025</time> · <!-- -->16 min read</div></header><div id="__blog-post-container" class="markdown"><p><em>注:这些文章本来是打算作为开发组后端培训文本的开篇而写的,但是我发现文章的内容过于复杂且有点离题,所以稍微修改了一下单独作为3篇独立的文章发布。</em></p>
|
||
<p><em>本文章的许多图片都直接来自 <a href="https://developer.mozilla.org" target="_blank" rel="noopener noreferrer">MDN</a>,在这里先感谢图片的创作者。</em></p>
|
||
<h2 class="anchor anchorWithStickyNavbar_LWe7" id="网络的起源">网络的起源<a href="#网络的起源" class="hash-link" aria-label="Direct link to 网络的起源" title="Direct link to 网络的起源"></a></h2>
|
||
<p>人们最初发明网络的目的很简单:在不同的电脑之间传输文件。那个时候没有U盘,也没有蓝牙,计算机领域的前辈们必须从头设计一个高效的传输文件的办法。</p>
|
||
<p>假如我们的电脑上有一个文件<code>example.docx</code>,放在我们电脑的文件夹<code>documents</code>里面,我们如何使用最原始的方法把它传递给另外一台电脑呢?</p>
|
||
<p>早期的程序员编写了一类叫做"HTTP服务器"的程序,程序的功能是选择电脑上的一个文件夹,将这个文件夹暴露在互联网上让所有人操作。这个文件夹叫做HTTP服务的“根目录”。</p>
|
||
<p>要使用这个程序,我们还要先给电脑分配一个IP地址,IP地址是一台电脑在互联网上的唯一标识,假如我们电脑的的IP地址是<code>123.45.67.89</code>。我们在这台电脑上启动一个HTTP服务程序。在程序的设置里指定根目录是我们存放文件的文件夹<code>documents</code>。</p>
|
||
<p>前面说过,这个HTTP服务程序的作用是把你电脑上一个指定的文件夹(我们称为“根目录”)暴露在互联网上,所有人都可以下载这个文件夹下的文件。于是这个时候,我们打开随便另一台电脑(前提是有网),在浏览器地址栏中输入<code>http://123.45.67.89/example.docx</code>,这时候就会发生神奇的事情:浏览器会提示你下载<code>example.docx</code>,这样,文件就从一台电脑传输到了另一台电脑。</p>
|
||
<p>假如<code>documents</code>文件夹下面还有另外一个文件<code>hi.txt</code>,那么当你在浏览器地址栏中输入<code>http://123.45.67.89/hi.txt</code>时,你就会发现浏览器显示了<code>hi.txt</code>这份文件的内容,因为浏览器可以直接显示<code>txt</code>文件,而不能直接显示<code>docx</code>文件。</p>
|
||
<p><img decoding="async" loading="lazy" alt="IIS根目录" src="/assets/images/iis-changeroot-websoft9-72efa0f7652462650d11b04bba150819.png" width="960" height="400" class="img_ev3q"></p>
|
||
<blockquote>
|
||
<p><em>IIS是Windows官方的HTTP服务器,有着图形化的配置界面,其它大部分HTTP服务器都需要通过命令行和配置文件进行配置。</em></p>
|
||
</blockquote>
|
||
<h2 class="anchor anchorWithStickyNavbar_LWe7" id="http协议">HTTP协议<a href="#http协议" class="hash-link" aria-label="Direct link to HTTP协议" title="Direct link to HTTP协议"></a></h2>
|
||
<p>等等,刚才所讲的操作为什么能发生呢?当我在浏览器中输入网址并按下回车键的时候,这一切的背后到底发生了什么?</p>
|
||
<p>我们之前提到了,要把电脑中的一个文件夹暴露在网络上供所有人访问,就需要启动一个"HTTP服务程序",这个HTTP是什么呢?</p>
|
||
<p>HTTP协议,是<code>HyperText Transfer Protocol</code>的缩写,即"超文本传输协议"。是通过网络在电脑之间进行文件传输的默认协议。进行HTTP文件传输的双方,一个称之为”客户端“(Client),一个称之为"服务端"(Server)。</p>
|
||
<p>我们刚才就是在我们的电脑上部署了HTTP服务端,而浏览器就是我们通信中的客户端。浏览器首先对服务器发送信息(行话叫做"请求"),要求获取某个文件;然后服务器返回这个文件(行话叫做“响应”)。</p>
|
||
<p>一次完整的HTTP通信总是由客户端请求(Request)和服务端响应(Response)组成。在HTTP协议中,总是由客户端先发起一次HTTP请求,然后由服务端返回这次请求的响应,这样才是一次完整的HTTP通信。</p>
|
||
<p>实际上,HTTP协议中的“客户端”不仅仅是指浏览器,但我们通常用的浏览器确实就是最常见的HTTP客户端。但其实像curl这样的命令行工具,或者手机APP,或者是浏览器里的JavaScript代码,当它们向服务器请求数据时,也可以被称作客户端。</p>
|
||
<p><img decoding="async" loading="lazy" alt="HTTP请求示意图" src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAA8AAAAELCAMAAAAhuB/3AAAABGdBTUEAALGPC/xhBQAAAAFzUkdCAK7OHOkAAAAhdEVYdENyZWF0aW9uIFRpbWUAMjAxNjowOTowNSAwOTo0Mjo1MLPOBpQAAAAldEVYdGRhdGU6bW9kaWZ5ADIwMTYtMDktMDRUMjM6NDI6NDcrMDA6MDDawlcBAAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDE2LTA5LTA0VDIzOjQyOjQ3KzAwOjAwq5/vvQAAAAlwSFlzAAAYmwAAGJsBSXWDlAAAAFFQTFRF////5+fn0tLSODg4GRkZAgIC9vb2AAAAvLy8YGBgBwcHjY2NdnZ2Dw8PKCgopKSkSkpKcnJy0NDQi4uLCwsLV1dXFhYWmpqaHh4e7e3tf39/xB6yJgAAGzNJREFUeNrsnQuX8iyyRiUBiktIMrc1s87//6GnCmKidqt9syGdZ6+Z701LFCTsFDf1dAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAh8L79SiiNsAZ5d3J8f8/ivPqzRF4XsuBiMbuGy9BtB5pVOjRmfpAYRwsa0j+5Mm/f1r3VlFP7s0ReEagNHtN9I3Y6RwEBgs9kRkTUV8EVu5OLDVvxVbOQuBP3y8pyT+RTK48u0Vie3XeRcKdK2LVKrBCB+i4/gYJvjbQnAVeb/IXsTc3kXuROaefBYbGz8evNJaqEuc6vn1yxZ9OmgZDhuQxS2RP7irhfE00Ga270oW23pC3WeBp5JMHVO0hISp3+m6MWxc6D9NSEdMlSpEPmEVPy40rab9oy61Ku3ykuEmRtqjTx0Ngs7nGYdjHIJ0fVjOMc06J/PeSMC8J504QeTdLABeBE995tRGB+SEfDQw+JI7M5R+LwERjHKWP50kH3xsjEUGfJ6oG0lNMNGWBI3e+vTF8pDhkRE0BlfosBPOYZVCl+yN3z8SBV0tc7nI8HblmR0ngXpHlhH67PDnc8mVggTtKVtzlh0KQLhQq/qCtqX8r8JQflHjgs9/SpC6611rCrfUxCzzKZIylrPKQn4WFjWej4FmmoRMrbIJjRq48zVUs81u2mEhJEnRO2IYlHKu7pdvE12hcnFY0ysnyXHBAgYe3ArOE3CIGbiLFb3nsQmDu3022PNlxt87mICIqT/wsf3+sDLZ+NPdgeo6iC5E9LX2byLUrkxELriS4cjzxEMXMKgtc6lnGwMN2MjjslMqVwGFpEXppJqvAOj9Y/olF4LIk2WeVCz1q9WNDYeVKoHVOLQJzMOX7oDrdJnRa58mrHLzLGDjmK9NlgcdyMiLwIcfA5ynObhM45QjsXHcr8MztaJaGNmi54ZcIfO5V8yPLs8ADcfuxiMaVbLcNGUVg/keJoOpNwgoPjF0ZA+vcGdJiO6r1sFiTB1+n3AzOAut1HHsj8FXo1ssYWKZjZBIroQ/3EUbKBkeZXdBSqdEke/aUhcx1H0qCtpcCDzlJL90eY9xJab4KVir/5A16PodEZpHdyUazTFSJrNwpU9xtC+5KYL06n/KurT4L7Gm28iJyxC3TpQCNn90yKWmTF25doMB9Gb8GWo7JeU5h4oSUN2tdCMzBV8+ibBbY88tQkL/42gUe9Uyo20Myc5sJZSPAuozEjYr/l+yFwBwUdDxHgtCPsulABO5y65HoaxOZkbC37/kE1sgjkb6syU1j6KVa56XavF46OrcJeZTjWV9ZgNI6d8ZD3+kcd6NOM/w97DB41qGsS3asaMyaqtlob0/LX/m/kz4LfBrGEDhs8+Nd3hGkh3x06vqypxoAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAOAzTCNVZ5z2VGP16gmt9R528tpQQ6R+UL/xxrvQxvsNHQSGwF/GBWoQ/wv+8l0rDa4a/+X8//2ffyQi0+1I4GPl2374nUvIc+1QOgTp1Y1aGTKuYs2v+Ts+UBAYAn/JXw6/wbVXLBmbxtfmoSsHvi1/7gpoCAyBvwKLMtsmp5deHZYGoqHmG7zMv3ZZIPBemX5lsPnVHuYrw5I1NFbtY1zlP5KxEBgCf6EVtdt3e21Y8kRVx53X+at2b6QQuGHmpmdPeJD4yltXX/nWeZV/v5cQDIHbUmRuuHQd0ctmmYbKAfg2f7WXUTAEbutqxIMWL9QNwG/z7ylAYAjcTohru4PgiKqunb3Nv3aJIPAOiY3XyvyyKbba8e6d/Gv3CSDw/vCN7x94XflM5Unfd/L3L5yyg8AQ+E+Vb6o8hfVe/opogsAQGAJ/qAebKveg38k/7aIPDYEhcP3yhcrLZ+/mP+9iHhoCQ+Dq5as9+/5+/q2vCUBgCNxI+YbK80V38jd72MsBgSFw9fKNdT/HcC//2sWCwBB4H+WrHeru5D/sYSEJAkPg2uVrcwi8k0EwBIbAtcvX6BB4H4NgCAyBa5evr/y27+avd7ASDIEhcO3ypcr7KO/m7yvvL4HAEHgP5au9Z/Fu/tMOWikEhsCVy+cqb4S+n7/awUcKITAErly+ZuewdjGLBYEhcOXyzZXf9YP82/6KIwgMgVsoX21LHuQ/t/8F720IPM3Bw9+DCtzoPqwWevf7EHjqDe3ma3gh8E9jK88UPcrfEVkI/DDfYi8EPq7AtSV5lL9tfxq6psB2tRcCH1fg2outD/Nv/2t16gkcx9/+/VkI3GL5ar/ph/nr5ttlPYHf+wHpJ78E/oVk+50nqxe+tn03+YACN7yKtId1pL8u8A89+bde+4AC1w5yD/P3za8joQuNLnTd8oXKlz48FjhA4Lv5YhILAktLcJUNeJC/a37DEZaRIDAEhsDfyRcbOY4scFf5s0iP81fNf6vOkbZSWufc1eVQ/ICDwFXLVzvGPcm/+Z0czXyYwf7UK2pybpsb+9d2eH44DHZtkBnTd1+7H1gI/G2a3sexg50cf+fTSBcCK89wr5z553aoHAX+ZzbrzCI3SElIX+vFxR+/OR9R4Kb3cexgJ8efFPg2h+XQlWtl03lc45erMy/L9S4uCSry4IhfpnSwO3eVukTerqfBQWAIDIF/WWC+Zv21wJ18eZkdAnenE8tpZ+5nO03nJ8rRlhplys1EfpR++k1AYAgMgZ8L3J8/AHoWeBCjB0rO5V/TGClN3tCVwFtqoEk5Y1SXEIF/gLHyV7c+yb9v/edV/pLAOmOeCcwhVJ0bZC/z0H1+ijbSM06cFsxpmZ3cBF5TLQUrvWq13ikg8HdoeiflDvZSHkvgZdZ5WK/OMi8d5aOfSWQeydl8zeyVwFuq/Bj00F2GeggMgSHw73ShDQs+D+ri6njvQ37CuvQ0udJruhJ4Sz0p2cOdJggMgSFwnTHwxdWRizflTrErMdY51d1GYEMXqZIUR+IeNQT+CRr+RqwyPWIgcOMCn0ZZRVLlJBE0rxPnMXAgW44uUjubnzJA4B+6bF+tRc8Xz8cX59/8ZugPl8959VcFVmUSi3ple4nGmmbrkjxJ5qs7LUdrasyzlpLJSBEC/7bAfvv0Wu4iaQh88Ue3/JhTKvvHpsvq8Tdv1A5JxoLuDwgsa0T85nlsa/LldLLk6xPly2fMILPQWyofaCOv1DWwDpyn4HQ/HUjgVOYqY95lA4Gvy1cWWHj4N8tf8+Xw4FZgjka9H81XV/F+vl78MhkRl66C97dJ6rbD5fzyngbf5fSxzC+fYq/y4hE/1Ft+xdNFqp28niebc/L1Bea2zPeb4TgCX52+FEgpCLxYKU08UonEy5ZDt9bcRT0pyguj64+Y3/9q3bbG3h9H/34JvyLwKe8NvfreiGcfzejsnxB47UJPOm+N44Mg6wzqTwvswzzdF6kM8HrqJRIraRZKtiRpKzUnmwl7tZ5Z2kyXQ9e8nuQD/a90wEX/NYH7tYEg8GsELq3M0Sw/dKv4MgXuhHjKi9tyf+2ot3wZk+5Py57Q0ElmU/rkBFKbAveU/GD47Voyw/TZ78jbncD543PTHZFsnjQ3ycnVF5sV96ajFln5iWZO2+lh6zwvJyU5yRj9fzlF9O9KghYbyIwQ+EUR2MjKteMxup74OPCgnayTYdCUO9cDxUgp8pUYZJQ0xl66T9ISPhmt2hQ4yCqg5eZW5jji52Zb9yjwpcM35dN8x+5khq+XO9vEEg95MBxl9sDKY+e3O8n1z0NHbiBy0sin5+8As8YsD+YokGeV9O1vnbcvcOd2IXAeA+suN7X/Z+9clJtHdQBs7jeDvXtmzsx5/xc9SPiWtHGatikkSDO7vxvs4Bh/IISQ+OLWDaNr7oZzw6mYoAE0NM6gXchnicV65x7PiNCSFdquAHOTYIE+K3i583p8Z/eLAlwY1h9AAuxGAE6h/wJQmR9OaW+HmvNmt+EwHhtvyxZ6a+ftJCAfnYojFoj8obw2s1B2wl8CuESjDeiJgr1lwNdO5KbTg09zbshcEIxCuxsYJnOTjLki97ibfktWaL4CPO5RvLMijdOHPgAGSeHq/sALqWy+4RwaeI0aKZbR1F60up4SDLn70lxRcCbUvdOx4IPTAwH8i3PgyefB12LnKYtRMTdLMBMzYzAcC9D/MwxlEyQGoHaP+zA+AWD9YxV62ZFicZf2JPxj96jvA9y6XN5w1kTKGueIirEx5eFwMGINH5dStc9cH0/Cp+FV4X0tYATwUwFGc0UBOOGDBgMEM3OmNzPskGk2ZoZhF/O4tdV7ADxd3hRTD4VXeTuAZ1NWf1VK8CB2O6XDteFxbfVZltmGyB/7w0m2fMmEW/L2kH4E8B8BHPZ+1kuRG8Enua4xwcrBPpdpA+CfG7E0+NFpCNIw4/JHND0YsW6p0Gib4tiT45QqT5T0YGOe6Trj2cDk6j6Y5yLoGAxTD1FOinZ9vNzEdT0qF/jICeCnAmx9fnULwAwsyzrB8Wx8nsYI9LWJuIk5f32AdmPSh7cBGGa+4MtiAWU5xwddi97MiAUfqNJb44iro1EJU/Y4o0xSuzE5gg9ffm75HWH5JAnz5O3xxtILML8WEMBPNWLBdQXg3GkaWWL/lDWkgHEVQ25u4YvLt0lY/poAB7nZmSUsT+JLGmKcLdpVpUmj7gHgW8tIoBvPOJWQy5PiwuMzCdLOUe4LyDoIKaWwVyctrohysXVZodJ40LgJ4N8FBA2yAlfzuCzKEZv9spiCTZgbEt7oUXgvQilX0mFbhRcE+K/rfzFHjr98bsTrnwDS+v0RwA+2wakrJQFMABPATQOsGwGJACaACeAXBokAJoAJYAKYACaACWACmACudn8U1I4AJoBf+P4orCwBTAATwAQwAUwAE8AEMAFMAD8klNyMACaAX/j+KL0oAUwAE8AEMAFMABPABDABTAA/JFPlN+FO/cZMBDABfPPtYd0DXNvVyd4D2BLABPBtBS2OrG+AMaZLRTmvn+1RoQhgAvgTgCEy78w7BrhtZ+jmXaEJ4PoA7wwTwC8FMFti2T7hvZgJ4JcCeAmT0iXAvrKd97R+d5k27rqwRIb8UQfEPrv6gedMADcCMDD83x4BbtqX8vQXOyOcc/JnyV1n86oAfxaZ+k7g6m8U/9LFT/puef1phwDPlX/0af3SzGePA0fPAKFaLR8YToOm6dLqZfGcrTisCw8s4PqUjcZeFqx5y9nX1PM3Apj95GJ9fvGTvpsAbtyT487wbBclnA0mCggy7zzo1PrQOxgTORAJSToxV2/J3QkHai5vzrHA5ldC8hLH2bYNMCnQlwDnSXCXc+CmPTlO/TgWxDRGmDcqhcxrtBnBbXtEhnqKRvHBKCUCbJywUyypqhwL0WiwkuUReC9QRlqBHXmQnAB+GYBLrNAuAbaPpzn9s/rPMycVgFkqefxgqMZUxYNS2+VZudZCQvowCMINGV8xk/HgHF4/LiBsBSX3mCMj1ksBvC0EdwmwrryOdFb/eeeyZjlBHRncQVgePrPkaa3GdIl2G4vxe2zJoxjh1WfWOkyAAyDsBSVdhiWAXwfg3Y2jU4Bbjop1HhELcxUnN23v85aq2GJSQ7tnr8HiLa0Rx7mx8SvAe0G5gvcFsFueUnCMuU3+3Q+Xj8e9o7WlIOjKRMwzb8meUwfgU0vvn/SiN+s/t5AfzUz4Pk8wBcaxF984dhiBFZ6flmKOGrfbAV4LQo8j8PpVcun4ivxnP9w+9tOV8qNEB4C0fn8NryOd9y0fALZlwN59qxV885RsWdi1JTUgQ2KHxcRdVOi1gGOB6xZgnHqUtOL/2w819GjcgnVPr48eOjo9qrY2i/UJcO3IrSf1n2v3HwAGry7N0u69leBvXGWSW7HMjE5GcZZHEcVLcu2tYFBqHILHbJOO9Qfw9Vcvh6tKkvbsxkXtDiXikRWy6LJBZEVbo1bOkiu0TyJNRUMfmCjZGNfTDlcSwN8WW3k/0u362bl97SPAXBqlAMtFOFopxepaZaNRSG0mNh9kUBWkf5WHghEWhGVf68BfB9itGtEKMAfdhXsTIy74JUx5jIsCc36iuTMcpvyQPereWeFREd3mttP2KwngHzVgXT3oZv13lqiPY+RqiGGzCMce3Qrs4N0yknMhAlykg3QcTDEZWRcOBYN2adTwUU8jcLEAxLsAx7WlFoB1Ah5n6CKnrPdoA8t4CdbdTbRDUL4oN7mXhFzSRjKcreynbVcSwD+RWNkb+mb9bs9n36y8BcCbteomwGAdDFm/2ebA0s1S5kE293I+rjNotarYpU+WhrEyP5IG/ptwVjTsp21XEsA/EVH5Z9+sXxpBAP8FwGVRyJ8AvHgas+1NLALT3MwopLmHq/PHETWeEodBmGkZu0UulGgBk2XZDk87XEkAv6MVq/YKNc2BL0ZgfnwTHdq0yqIbYiilBYOVMmUOXM4Ky0oeOL1Js47F62nHKwng7wuvHLfmVv28+Xg6vRmxrgBmChrIXs5hJ2i1oo0nONq05APAy2n292a/XQPcqi9W85kJewc4t1DE5mOwJhy0ddDhzrk1yx5tcFpNqDjDKRvA+2nblQTwjyRVzl9yo/7UelqV7gEu9kdnlBsV+HooH+yklAa7mJhwOT33wi54UKQ3gPfTtisJ4HecBL/CFLhzgMssZ0pg4MrDaIBVdI97vJjIcMLIOkljIoyxuwq9nbZfSQC/3yT4JabA7wCwXWxIfIlBYu11kbZXLcEsW69h5e+1oAREgbvjK5clFko+df8/2+KmMPsCgDR/f77yfoZP65/vmThWVwvmwhC2rTNwHNYH5ixusiGA+7i7bgEWlT0mPq0/3lsFXp0dQcGTh6hIcvXNtLjpSD51vzMBTADXv7+psjv0Z/Wzux6eR4C5hc0yAlcrtziVggCuJIoA/tv7U5W9KT+p3921rB0BPlpWpCkuetooArgr6Rdg8dtL6j+v39/1o7wN8Ijmr2BmApgA7uL+bOXAWB/r/8IdOTPiLprxA8AMjWJRWQK4KwmNP5Unxs7wlfcNfKj/CzqBuwrnvQM8SAWTaEEA9yWtrzw+MXrVWNmMdV0/+0LClJJaxTnxEeBgpvyVEwHcmZh1o2J3t6dV3SH4un6xbT39zhw4f50YIoR5JoC7ktoBGisqCK7yEHxZPzNfMIufAJw7AJ7/IoA7kxkjDLTbvTzRZTkPgVW3DlzWn74wAJ8CbE00jADuTbRq2A49mqc69z/56x+q/2v3cgbwUCJLFoDLVNkSwO8vk6ns0XBb2LM7F3kI51hJwVjq51/7qacAO7AXLAAv4V8I4A4kGTPrFm9sUs9W73MPoWouBm/12y/+1DWD77pXZt0igxteNBRq+ISXmIuWEcA9KNHeGG/buy3YN/lsC3ke+Ewc63VfWP8//0RTWRUggF+aYMwJLcZ2IGaTk6rk4Hs2Qd40If51+B3qPSVi9YbYRl7jS/mbqTlGSKgsaXqlt4UAbnAQLkNeO5IVgj9b3dK2smh6AUl+Q3G1zQg1BgkJCQkJCQkJCQkJCQlJ78KcNEZioP+Bz5DiV7DrYxISkjYFPD9kKhm9wY3dZZ7VdHlMQkLSKr9KlCw7UQ9j2czkIJDH8ZiEhKRNEWsMADHrIS37l2Ad+XhMQkLSpvhj4Gh78BW3jUdWISEhGbQx+mI8Nj4tiSqPxyQkJC2KvcrHgmnfTdLXxyQkJC3KxyhePPht18fxmOSVhZveZO5lDrzMdDU7DMt7MC37lcBaJM1L6A5g2UfDzmsYvGgmlopFWnvDj8f0+hPABHCrVixlfNADTwByLHqHg4nx8ZiEVGhSoVs1Y4HDpDfgx1G8sqRC76vjMck7GDs6k24WQbWTPs5lwzQbZRanr49JXl5kbwDTzI/kncR1xi95AJO8l8S+AKYYPCRkxiITFgkJKdEVFGgy3ZC8nYyqF37J/5fkHYX1YYqmlU+Sd5XWorU/I/477aAjee9x2L6xdNqe3130ptwkJCSVxf3A8VteXMhp5yEJSYUR+Jd2bsw0HpOQVBAEWE8Og0O7Mo7CP+tH4Bi9ZkyzUzkrsCngSS4M2sHcw3njKIwWCUkVgLUyCj1IywZgbuL+0eIDAEgLMNOP+RIv81UwBzbSwcYlPnS0CZOEpDWAhRkHlsw0jP9v79563AaBMAwbcxjAJ/7/ry0zThzvbqNUvXDS6n2kVgnx3kT6Ahgz2GNorb89mpKW5XCLuGEV77xu1erBnsc9wFKnflXQDS98lcB7Apx19XuTdXC2hb9KOjfpuQ0uacfbm6Y+YhYrG70HWMfPEgkw8MY5cC6lLXtH6voIej03eYm2Pj4eY+S9HO0eYH2vf0SAgfcNoSUES+vUO9em9d4fTanUPvUtQz52eeyxtQDHPcCZAAMXSzr8dTZK1jHxbGntY+gah3PToIu8vdN1px54+NYDJwIMXGzV0kFzD2q22e1q818vm56Y9Ghy9nipXrtod7uF+UuAbQ5cmQMDV+shnaba569JxGc9isHrfauoS0mPpk1XiVyNSYtU5k2vPwe4Ti7onHmVQh0E4Eq6rlvn2wuZvPWnca8o9Ghqxzqwrvnqi1OAQ/8FED0IPAvPRgMXz4Kn29NTrmypz4n1gasxu29NbiuTu1+v4+l934f+36fFad4/GzM9MPBv4ekrgAADIMAAAAAAAAD4/40vF3LHQUvgZc5+Az7Pi8eZ0yJit5259Qx8lk1eBzhL2LQIFgEGPkz5gwAXuZ1aQYCBj+BKrcUNQ4sSmgZ4q4s9HZ3mKkFfhbaFdR9gV1lCf38LsGsxBp0MOx9CKZxoAVxt1qobWqVusqKwQUL1UTfybyKt2ZZ+iVE3GWoHHMSXYw7cJDYvMdu+w7JwJCtwtRR1+2A+akoGjarV3bCt/k73FZ5Oayyybz+yf1Ur3WnNu8ny7Ve+TuBa2UpwDIscAdYhcewvo81ytdSVyDb8JsCjWAX4fq3THhzAGwJs/aa/l6QLtwJXtjnf5PMJZucAz/crdDAtceVQVuD6APs9wNuPANdi3LMAFwn7Fb19bIvc5skArnMfQv/sgetxybMeeP36UxC5DQ1cbBWn96pistLsjwAnq2uX1/Y0wPZHwxamoQRnPwKOrxO4Vp/Jem9l6nRI/AiwnmemHzwPsC4jeVuBGqW2qTGEBq6nT2M06ztrT+ojwPqBLOX5ELrPfH3URyu1G5YeZjpg4A3SX3zy4wJ2JwEAAAAAAAAAAAAAAAAAAAAAAADf/AJNAMGHNHcznQAAAABJRU5ErkJggg==" width="960" height="267" class="img_ev3q"></p>
|
||
<p>实际上,HTTP协议不仅可以获取一个文件(就像我们所做的),也可以向服务端上传一个文件,或是修改某个文件的内容...</p>
|
||
<p>一次HTTP通信要进行什么操作(获取or上传等),由HTTP请求中的“方法”指定,方法是"请求头"的一部分。</p>
|
||
<p>"请求头"是什么?别着急,下面我们介绍HTTP协议的具体内容:</p>
|
||
<h3 class="anchor anchorWithStickyNavbar_LWe7" id="请求">请求<a href="#请求" class="hash-link" aria-label="Direct link to 请求" title="Direct link to 请求"></a></h3>
|
||
<p>前面说了,HTTP通信总是以客户端发送请求开始,服务端是没法主动给客户端发信息的。</p>
|
||
<p>一个HTTP请求包含请求头(HTTP Request Header)和请求体(Request Body),请求头主要包含了:</p>
|
||
<ul>
|
||
<li>协议版本:告诉服务器,这次交流,要使用哪个版本的HTTP协议</li>
|
||
<li>目标:要访问哪个电脑,例如刚才的<code>123.45.67.89</code></li>
|
||
<li>URI:要操作哪个文件,例如<code>example.docx</code>,IP地址或者网址后面的内容就是URI了</li>
|
||
<li>方法:要对这个文件做什么,比如获取这个文件的内容,还是在服务器上创建这个文件</li>
|
||
<li>自定义参数:除了上面的信息,客户端还可以发送一些额外的内容给服务端,这些内容总是以<code>Key=Value</code>的形式存在。在正常的URI后有一个<code>?</code>,表示参数的开始,<code>&</code>表示不同参数之间的分隔。</li>
|
||
</ul>
|
||
<p>例如:<code>http://123.45.67.89/example.docx?compressed=true&method=gzip</code></p>
|
||
<p>这就是让服务器压缩发来的文件,使用gzip压缩。</p>
|
||
<p>参数的内容不是HTTP标准,也就是服务端如何理解参数,完全靠程序员写的代码。如果程序员没有设置,那么参数就毫无用处。</p>
|
||
<h4 class="anchor anchorWithStickyNavbar_LWe7" id="http方法">HTTP方法<a href="#http方法" class="hash-link" aria-label="Direct link to HTTP方法" title="Direct link to HTTP方法"></a></h4>
|
||
<p>HTTP方法定义了这个请求具体要对指定的文件做什么,其中:</p>
|
||
<ul>
|
||
<li><code>GET</code>:获取指定文件的内容。</li>
|
||
<li><code>POST</code>:上传一个文件,内容放在请求体(下面会讲到)。</li>
|
||
<li><code>DELETE</code>:删除某个文件。</li>
|
||
</ul>
|
||
<p>其实这里还有一些方法的,我们以后讲。</p>
|
||
<p>我们日常使用浏览器,比如在地址栏中输入<code>baidu.com</code>,其实就是在对这个地址做GET请求,浏览器会把你的输入内容自动补全成 <code>GET http://www.baidu.com/</code> 这一HTTP请求</p>
|
||
<div class="theme-admonition theme-admonition-tip admonition_xJq3 alert alert--success"><div class="admonitionHeading_Gvgb"><span class="admonitionIcon_Rf37"><svg viewBox="0 0 12 16"><path fill-rule="evenodd" d="M6.5 0C3.48 0 1 2.19 1 5c0 .92.55 2.25 1 3 1.34 2.25 1.78 2.78 2 4v1h5v-1c.22-1.22.66-1.75 2-4 .45-.75 1-2.08 1-3 0-2.81-2.48-5-5.5-5zm3.64 7.48c-.25.44-.47.8-.67 1.11-.86 1.41-1.25 2.06-1.45 3.23-.02.05-.02.11-.02.17H5c0-.06 0-.13-.02-.17-.2-1.17-.59-1.83-1.45-3.23-.2-.31-.42-.67-.67-1.11C2.44 6.78 2 5.65 2 5c0-2.2 2.02-4 4.5-4 1.22 0 2.36.42 3.22 1.19C10.55 2.94 11 3.94 11 5c0 .66-.44 1.78-.86 2.48zM4 14h5c-.23 1.14-1.3 2-2.5 2s-2.27-.86-2.5-2z"></path></svg></span>提示</div><div class="admonitionContent_BuS1"><p>打开浏览器的F12开发者菜单,选择"Network",可以看到你在访问这个网站时与服务器所进行的所有HTTP请求</p></div></div>
|
||
<p>在浏览器地址栏里直接输入网址,默认就是发送GET请求。你可能会好奇,POST这些请求是怎么发出去的呢?这通常是由网页中的JavaScript代码在背后发送的。我们在之后的内容会讲到这一点。</p>
|
||
<p><img decoding="async" loading="lazy" alt="请求头" src="data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" style="background-color:#fff" viewBox="-.5 -.5 310 191">
  <rect width="100%" height="100%" fill="#FFF"/>
  <rect width="297" height="87" x="7" y="58" fill="#e6e6e6" pointer-events="all" rx="6.96" ry="6.96"/>
  <g stroke="#000" stroke-miterlimit="10">
    <path fill="none" d="M32.62 58.64 30.9 30" pointer-events="stroke"/>
    <path d="m32.93 63.88-2.75-6.84 2.44 1.6 2.22-1.88Z" pointer-events="all"/>
  </g>
  <path fill="none" d="M0 0h60v30H0z" pointer-events="all"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe center;width:58px;height:1px;padding-top:15px;margin-left:1px">
        <div data-drawio-colors="color: rgb(0, 0, 0);" style="box-sizing:border-box;font-size:0;text-align:center">
          <div style="display:inline-block;font-size:16px;font-family:Helvetica;color:#000;line-height:1.2;pointer-events:all;white-space:normal;overflow-wrap:normal">
            <div style="font-size:16px">Method</div>
          </div>
        </div>
      </div>
    </foreignObject>
    <text x="30" y="20" font-family="Helvetica" font-size="16" text-anchor="middle">Method</text>
  </switch>
  <path fill="none" d="M56 0h60v30H56z" pointer-events="all"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe center;width:58px;height:1px;padding-top:15px;margin-left:57px">
        <div data-drawio-colors="color: rgb(0, 0, 0);" style="box-sizing:border-box;font-size:0;text-align:center">
          <div style="display:inline-block;font-size:16px;font-family:Helvetica;color:#000;line-height:1.2;pointer-events:all;white-space:normal;overflow-wrap:normal">Path</div>
        </div>
      </div>
    </foreignObject>
    <text x="86" y="20" font-family="Helvetica" font-size="16" text-anchor="middle">Path</text>
  </switch>
  <path fill="none" d="M113 0h122v30H113z" pointer-events="all"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe center;width:120px;height:1px;padding-top:15px;margin-left:114px">
        <div data-drawio-colors="color: rgb(0, 0, 0);" style="box-sizing:border-box;font-size:0;text-align:center">
          <div style="display:inline-block;font-size:16px;font-family:Helvetica;color:#000;line-height:1.2;pointer-events:all;white-space:normal;overflow-wrap:normal">Protocol version</div>
        </div>
      </div>
    </foreignObject>
    <text x="174" y="20" font-family="Helvetica" font-size="16" text-anchor="middle">Protocol version</text>
  </switch>
  <path fill="none" d="M127 161h60v30h-60z" pointer-events="all"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe center;width:58px;height:1px;padding-top:176px;margin-left:128px">
        <div data-drawio-colors="color: rgb(0, 0, 0);" style="box-sizing:border-box;font-size:0;text-align:center">
          <div style="display:inline-block;font-size:16px;font-family:Helvetica;color:#000;line-height:1.2;pointer-events:all;white-space:normal;overflow-wrap:normal">
            <div style="font-size:16px">Headers</div>
          </div>
        </div>
      </div>
    </foreignObject>
    <text x="157" y="181" font-family="Helvetica" font-size="16" text-anchor="middle">Headers</text>
  </switch>
  <g stroke="#000" stroke-miterlimit="10">
    <path fill="none" d="M79.45 58.2 83.73 30" pointer-events="stroke"/>
    <path d="m78.67 63.39-1.26-7.27 2.04 2.08 2.57-1.38Z" pointer-events="all"/>
  </g>
  <g stroke="#000" stroke-miterlimit="10">
    <path fill="none" d="M153.71 58.24 166.96 30" pointer-events="stroke"/>
    <path d="m151.48 62.99.86-7.33 1.37 2.58 2.85-.6Z" pointer-events="all"/>
  </g>
  <rect width="36" height="21" x="15" y="65" fill="#f2fffc" pointer-events="all" rx="1.68" ry="1.68"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe flex-start;width:1px;height:1px;padding-top:76px;margin-left:19px">
        <div data-drawio-colors="color: #333333;" style="box-sizing:border-box;font-size:0;text-align:left">
          <div style="display:inline-block;font-size:16px;font-family:monospace;color:#333;line-height:1.2;pointer-events:all;white-space:nowrap">
            <p style="line-height:100%">
              <font color="#509ad4" style="font-size:16px">GET</font>
            </p>
          </div>
        </div>
      </div>
    </foreignObject>
    <text x="19" y="80" fill="#333" font-family="Monospace" font-size="16">GET</text>
  </switch>
  <rect width="17" height="21" x="70" y="64.5" fill="#f5f5ff" pointer-events="all" rx="1.36" ry="1.36"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe flex-start;width:1px;height:1px;padding-top:75px;margin-left:74px">
        <div data-drawio-colors="color: #333333;" style="box-sizing:border-box;font-size:0;text-align:left">
          <div style="display:inline-block;font-size:16px;font-family:monospace;color:#333;line-height:1.2;pointer-events:all;white-space:nowrap">
            <p style="line-height:100%">/</p>
          </div>
        </div>
      </div>
    </foreignObject>
    <text x="74" y="80" fill="#333" font-family="Monospace" font-size="16">/</text>
  </switch>
  <rect width="100" height="22" x="101" y="64" fill="#f5ebef" pointer-events="all" rx="1.76" ry="1.76"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe flex-start;width:1px;height:1px;padding-top:75px;margin-left:105px">
        <div data-drawio-colors="color: #333333;" style="box-sizing:border-box;font-size:0;text-align:left">
          <div style="display:inline-block;font-size:16px;font-family:monospace;color:#333;line-height:1.2;pointer-events:all;white-space:nowrap">
            <p style="line-height:100%">
              <font color="#5d837e" style="font-size:16px">HTTP</font>/<font color="#cd5b92" style="font-size:16px">1.1</font>
            </p>
          </div>
        </div>
      </div>
    </foreignObject>
    <text x="105" y="80" fill="#333" font-family="Monospace" font-size="16">HTTP/1.1</text>
  </switch>
  <rect width="284" height="48" x="15" y="90" fill="#cfe3f5" pointer-events="all" rx="3.84" ry="3.84"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe flex-start;width:278px;height:1px;padding-top:114px;margin-left:19px">
        <div data-drawio-colors="color: #333333;" style="box-sizing:border-box;font-size:0;text-align:left">
          <div style="display:inline-block;font-size:16px;font-family:monospace;color:#333;line-height:1.2;pointer-events:all;white-space:normal;overflow-wrap:normal">
            <div style="font-size:16px">
              <font color="#5d837e" style="font-size:16px">Host</font>: developer.mozilla.org</div>
            <div style="font-size:16px">
              <font color="#5d837e" style="font-size:16px">Accept-Language</font>: fr</div>
          </div>
        </div>
      </div>
    </foreignObject>
    <text x="19" y="119" fill="#333" font-family="Monospace" font-size="16">Host: developer.mozilla.org...</text>
  </switch>
  <g stroke="#000" stroke-miterlimit="10">
    <path fill="none" d="M157 144.37V161" pointer-events="stroke"/>
    <path d="m157 139.12 2.33 7-2.33-1.75-2.33 1.75Z" pointer-events="all"/>
  </g>
</svg>" width="310" height="191" class="img_ev3q"></p>
|
||
<h4 class="anchor anchorWithStickyNavbar_LWe7" id="请求体">请求体<a href="#请求体" class="hash-link" aria-label="Direct link to 请求体" title="Direct link to 请求体"></a></h4>
|
||
<p>对于某些方法,需要在请求时向服务器夹带一些东西(比如POST需要你带上新文件的内容),请求体就是装载这些东西的.</p>
|
||
<p>像GET请求就没有请求体,因为GET请求不需要夹带信息.</p>
|
||
<div class="theme-admonition theme-admonition-tip admonition_xJq3 alert alert--success"><div class="admonitionHeading_Gvgb"><span class="admonitionIcon_Rf37"><svg viewBox="0 0 12 16"><path fill-rule="evenodd" d="M6.5 0C3.48 0 1 2.19 1 5c0 .92.55 2.25 1 3 1.34 2.25 1.78 2.78 2 4v1h5v-1c.22-1.22.66-1.75 2-4 .45-.75 1-2.08 1-3 0-2.81-2.48-5-5.5-5zm3.64 7.48c-.25.44-.47.8-.67 1.11-.86 1.41-1.25 2.06-1.45 3.23-.02.05-.02.11-.02.17H5c0-.06 0-.13-.02-.17-.2-1.17-.59-1.83-1.45-3.23-.2-.31-.42-.67-.67-1.11C2.44 6.78 2 5.65 2 5c0-2.2 2.02-4 4.5-4 1.22 0 2.36.42 3.22 1.19C10.55 2.94 11 3.94 11 5c0 .66-.44 1.78-.86 2.48zM4 14h5c-.23 1.14-1.3 2-2.5 2s-2.27-.86-2.5-2z"></path></svg></span>提示</div><div class="admonitionContent_BuS1"><p>正常地使用浏览器,是没法做出GET外的请求的,但是浏览器在控制台里可以自定义请求,以<code>Firefox</code>为例,在F12的<code>Network</code>一栏中点<code>New Request</code>(有一个加号)就可以发送自定义请求。<code>curl</code>等HTTP命令行工具也可以发送请求.</p></div></div>
|
||
<h3 class="anchor anchorWithStickyNavbar_LWe7" id="响应">响应<a href="#响应" class="hash-link" aria-label="Direct link to 响应" title="Direct link to 响应"></a></h3>
|
||
<p>回应也分为回应头和回应体,回应头主要包含:</p>
|
||
<ul>
|
||
<li>状态码:针对请求的回应有对应的状态,比如,如果GET请求没有问题,成功返回的话就返回<code>200 OK</code>状态码,如果找不到请求里对应的文件就会返回<code>404 Not Found</code></li>
|
||
<li>内容格式:向浏览器说明回应体(若有)是什么格式的,文本文件的编码设置等,比如html文件?图片?docx文档?有没有被压缩?如果有,压缩格式?这决定了浏览器如何对待这些文件</li>
|
||
<li>内容的大小:返回所请求资源的大小(若有)</li>
|
||
</ul>
|
||
<p>回应体就是包含了回应的主体内容了,如果是GET请求的话,那么就回应了所GET文件的内容,如果是其他请求的话,可能也会没有回应体,具体看使用的方法</p>
|
||
<p><img decoding="async" loading="lazy" alt="回应体" src="data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" style="background-color:#fff" viewBox="-0.5 -0.5 422 205">
  <rect width="100%" height="100%" fill="#FFF"/>
  <rect width="381" height="105" x="30" y="51" fill="#e6e6e6" pointer-events="all" rx="3.15" ry="3.15"/>
  <path fill="none" d="M233 0h137v30H233z" pointer-events="all"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe center;width:135px;height:1px;padding-top:15px;margin-left:234px">
        <div data-drawio-colors="color: rgb(0, 0, 0);" style="box-sizing:border-box;font-size:0;text-align:center">
          <div style="display:inline-block;font-size:16px;font-family:Helvetica;color:#000;line-height:1.2;pointer-events:all;white-space:normal;overflow-wrap:normal">Status message</div>
        </div>
      </div>
    </foreignObject>
    <text x="302" y="20" font-family="Helvetica" font-size="16" text-anchor="middle">Status message</text>
  </switch>
  <path fill="none" d="M137 0h94v30h-94z" pointer-events="all"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe center;width:92px;height:1px;padding-top:15px;margin-left:138px">
        <div data-drawio-colors="color: rgb(0, 0, 0);" style="box-sizing:border-box;font-size:0;text-align:center">
          <div style="display:inline-block;font-size:16px;font-family:Helvetica;color:#000;line-height:1.2;pointer-events:all;white-space:normal;overflow-wrap:normal">Status code</div>
        </div>
      </div>
    </foreignObject>
    <text x="184" y="20" font-family="Helvetica" font-size="16" text-anchor="middle">Status code</text>
  </switch>
  <path fill="none" d="M0 0h118v30H0z" pointer-events="all"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe center;width:116px;height:1px;padding-top:15px;margin-left:1px">
        <div data-drawio-colors="color: rgb(0, 0, 0);" style="box-sizing:border-box;font-size:0;text-align:center">
          <div style="display:inline-block;font-size:16px;font-family:Helvetica;color:#000;line-height:1.2;pointer-events:all;white-space:normal;overflow-wrap:normal">Protocol version</div>
        </div>
      </div>
    </foreignObject>
    <text x="59" y="20" font-family="Helvetica" font-size="16" text-anchor="middle">Protocol version</text>
  </switch>
  <path fill="none" d="M192 175h60v30h-60z" pointer-events="all"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe center;width:58px;height:1px;padding-top:190px;margin-left:193px">
        <div data-drawio-colors="color: rgb(0, 0, 0);" style="box-sizing:border-box;font-size:0;text-align:center">
          <div style="display:inline-block;font-size:16px;font-family:Helvetica;color:#000;line-height:1.2;pointer-events:all;white-space:normal;overflow-wrap:normal">
            <div style="font-size:16px">Headers</div>
          </div>
        </div>
      </div>
    </foreignObject>
    <text x="222" y="195" font-family="Helvetica" font-size="16" text-anchor="middle">Headers</text>
  </switch>
  <rect width="36" height="21" x="197" y="56" fill="#f2fffc" pointer-events="all" rx="1.68" ry="1.68"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe center;width:1px;height:1px;padding-top:66px;margin-left:215px">
        <div data-drawio-colors="color: #333333;" style="box-sizing:border-box;font-size:0;text-align:center">
          <div style="display:inline-block;font-size:16px;font-family:monospace;color:#333;line-height:1.2;pointer-events:all;white-space:nowrap">OK</div>
        </div>
      </div>
    </foreignObject>
    <text x="215" y="71" fill="#333" font-family="Monospace" font-size="16" text-anchor="middle">OK</text>
  </switch>
  <rect width="42" height="21" x="139" y="56" fill="#f5f5ff" pointer-events="all" rx="1.68" ry="1.68"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe center;width:1px;height:1px;padding-top:66px;margin-left:160px">
        <div data-drawio-colors="color: #333333;" style="box-sizing:border-box;font-size:0;text-align:center">
          <div style="display:inline-block;font-size:16px;font-family:monospace;color:#333;line-height:1.2;pointer-events:all;white-space:nowrap">200</div>
        </div>
      </div>
    </foreignObject>
    <text x="160" y="71" fill="#333" font-family="Monospace" font-size="16" text-anchor="middle">200</text>
  </switch>
  <rect width="92" height="22" x="38" y="55" fill="#f5ebef" pointer-events="all" rx="1.76" ry="1.76"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe center;width:1px;height:1px;padding-top:66px;margin-left:84px">
        <div data-drawio-colors="color: #333333;" style="box-sizing:border-box;font-size:0;text-align:center">
          <div style="display:inline-block;font-size:16px;font-family:monospace;color:#333;line-height:1.2;pointer-events:all;white-space:nowrap">
            <p style="line-height:100%">
              <font color="#5d837e" style="font-size:16px">HTTP</font>/<font color="#cd5b92" style="font-size:16px">1.1</font>
            </p>
          </div>
        </div>
      </div>
    </foreignObject>
    <text x="84" y="71" fill="#333" font-family="Monospace" font-size="16" text-anchor="middle">HTTP/1.1</text>
  </switch>
  <rect width="368" height="63" x="38" y="83" fill="#cfe3f5" pointer-events="all" rx="1.89" ry="1.89"/>
  <switch transform="translate(-.5 -.5)">
    <foreignObject width="100%" height="100%" pointer-events="none" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow:visible;text-align:left">
      <div xmlns="http://www.w3.org/1999/xhtml" style="display:flex;align-items:unsafe center;justify-content:unsafe flex-start;width:362px;height:1px;padding-top:115px;margin-left:42px">
        <div data-drawio-colors="color: #333333;" style="box-sizing:border-box;font-size:0;text-align:left">
          <div style="display:inline-block;font-size:16px;font-family:monospace;color:#333;line-height:1.2;pointer-events:all;white-space:normal;overflow-wrap:normal">
            <div style="font-size:16px">
              <font color="#5d837e" style="font-size:16px">date</font>: Tue, 18 Jun 2024 10:03:55 GMT</div>
            <div style="font-size:16px">
              <font color="#5d837e" style="font-size:16px">cache-control</font>: public, max-age=3600</div>
            <div style="font-size:16px">
              <font color="#5d837e" style="font-size:16px">content-type</font>: text/html</div>
          </div>
        </div>
      </div>
    </foreignObject>
    <text x="42" y="119" fill="#333" font-family="Monospace" font-size="16">date: Tue, 18 Jun 2024 10:03:55 GMT...</text>
  </switch>
  <g stroke="#000" stroke-miterlimit="10">
    <path fill="none" d="M222 152.37V175" pointer-events="stroke"/>
    <path d="m222 147.12 2.33 7-2.33-1.75-2.33 1.75Z" pointer-events="all"/>
  </g>
  <g stroke="#000" stroke-miterlimit="10">
    <path fill="none" d="M229.63 53.02 273.15 30" pointer-events="stroke"/>
    <path d="m224.99 55.48 5.09-5.34-.45 2.88 2.64 1.25Z" pointer-events="all"/>
  </g>
  <g stroke="#000" stroke-miterlimit="10">
    <path fill="none" d="m163.22 50.5 12-20.5" pointer-events="stroke"/>
    <path d="m160.56 55.04 1.53-7.22 1.13 2.68 2.89-.33Z" pointer-events="all"/>
  </g>
  <g stroke="#000" stroke-miterlimit="10">
    <path fill="none" d="M60.68 48.64 59.75 30" pointer-events="stroke"/>
    <path d="m60.94 53.88-2.68-6.87 2.42 1.63 2.25-1.86Z" pointer-events="all"/>
  </g>
</svg>" width="422" height="205" class="img_ev3q"></p>
|
||
<h3 class="anchor anchorWithStickyNavbar_LWe7" id="例子">例子<a href="#例子" class="hash-link" aria-label="Direct link to 例子" title="Direct link to 例子"></a></h3>
|
||
<p><code>GET</code>方法从服务器获得一个资源,我们在浏览器的地址栏输入一个地址时,就是在对这个URI做<code>GET</code>请求,前面的例子也是通过<code>GET</code>方法来进行的。</p>
|
||
<p>比如,发送<code>GET http://developer.zsxyww.com/test/test.txt</code>,那么就会把我们服务器根目录上<code>test</code>文件夹里面的<code>test.txt</code>这个文件发过来</p>
|
||
<p><code>POST</code>方法向服务器上传一个资源,例如使用某个客户端发送<code>POST http://example.org/sheet.xlsx</code>,在request body里面带上你的这个文件,那么<code>example.org</code>网站的根目录下就会多出一个叫做<code>sheet.xlsx</code>的文件</p>
|
||
<p>除了上面介绍的这些方法,还有<code>DELETE</code>,<code>PATCH</code>等方法,分别对应了删除,修改一个资源,你可以在你的电脑上通过<code>curl</code>等程序,或者通过浏览器控制台来进行常规的<code>GET</code>之外的方法请求</p>
|
||
<div class="theme-admonition theme-admonition-tip admonition_xJq3 alert alert--success"><div class="admonitionHeading_Gvgb"><span class="admonitionIcon_Rf37"><svg viewBox="0 0 12 16"><path fill-rule="evenodd" d="M6.5 0C3.48 0 1 2.19 1 5c0 .92.55 2.25 1 3 1.34 2.25 1.78 2.78 2 4v1h5v-1c.22-1.22.66-1.75 2-4 .45-.75 1-2.08 1-3 0-2.81-2.48-5-5.5-5zm3.64 7.48c-.25.44-.47.8-.67 1.11-.86 1.41-1.25 2.06-1.45 3.23-.02.05-.02.11-.02.17H5c0-.06 0-.13-.02-.17-.2-1.17-.59-1.83-1.45-3.23-.2-.31-.42-.67-.67-1.11C2.44 6.78 2 5.65 2 5c0-2.2 2.02-4 4.5-4 1.22 0 2.36.42 3.22 1.19C10.55 2.94 11 3.94 11 5c0 .66-.44 1.78-.86 2.48zM4 14h5c-.23 1.14-1.3 2-2.5 2s-2.27-.86-2.5-2z"></path></svg></span>提示</div><div class="admonitionContent_BuS1"><p>httpbin.org 这个网站可以让你试验HTTP协议的方 |