http | |
---|---|
namn | Hypertext Transfer Protocol |
Nivå (enligt OSI-modellen ) | Applicerad |
Familj | TCP/IP |
Skapad i | 1992 |
Port/ID | 80/ TCP |
Specifikation | RFC 124 , RFC 1945 , RFC 2616 , RFC 2617 , RFC 6266 , RFC 7230 , RFC 7240 , RFC 8446 . |
Huvudsakliga implementeringar (klienter) | Webbläsare , till exempel Internet Explorer , Mozilla Firefox , Opera , Google Chrome , Yandex Browser , Microsoft Edge , etc. |
Kärnimplementationer ( servrar ) | Apache , IIS , nginx , Google Web Server , etc. |
Mediafiler på Wikimedia Commons |
HTTP ( HyperText Transfer Protocol - " hypertext transfer protocol ") är ett applikationslagers dataöverföringsprotokoll, ursprungligen i form av hypertextdokument i HTML -format , som för närvarande används för att överföra godtyckliga data.
Grunden för HTTP är "klient-server"-tekniken , det vill säga förekomsten av:
HTTP är nu allmänt förekommande på World Wide Web för att hämta information från webbplatser . 2006 överträffade HTTP - trafiken i Nordamerika den för P2P-nätverk med 46 %, varav nästan hälften var video- och ljudströmning [ 1] .
HTTP används också som en "transport" för andra applikationslagerprotokoll som SOAP , XML-RPC , WebDAV .
Huvudobjektet för manipulation i HTTP är resursen som pekas på av en URI (Uniform Resource Identifier) i en klientförfrågan. Vanligtvis är dessa resurser filer som lagras på servern , men de kan vara logiska objekt eller något abstrakt. En egenskap hos HTTP-protokollet är möjligheten att specificera i begäran och svaret hur samma resurs representeras av olika parametrar: format , kodning , språk, etc. (särskilt HTTP-rubrik används för detta ). Det är tack vare möjligheten att specificera hur meddelandet är kodat som klienten och servern kan utbyta binär data , även om detta protokoll är text.
HTTP är ett applikationslagerprotokoll ; dess motsvarigheter är FTP och SMTP . Meddelanden utbyts enligt det vanliga "request-response"-schemat. HTTP använder globala URI:er för att identifiera resurser . Till skillnad från många andra protokoll är HTTP tillståndslöst. Detta innebär att inget mellantillstånd lagras mellan begäran-svarspar. Komponenter som använder HTTP kan oberoende lagra tillståndsinformation relaterad till senaste förfrågningar och svar (t.ex. " cookies " på klientsidan, "sessioner" på serversidan). Webbläsaren som skickar förfrågningarna kan spåra svarsförseningar. Servern kan lagra IP-adresser och begära rubriker för de senaste klienterna. Protokollet i sig känner dock inte till tidigare förfrågningar och svar, det ger inget internt statligt stöd, det har inte sådana krav.
De flesta protokoll tillhandahåller etablering av en TCP-session under vilken auktorisering sker en gång, och ytterligare åtgärder utförs i samband med denna auktorisering. HTTP upprättar en separat TCP-session för varje begäran; senare versioner av HTTP tillät att flera förfrågningar gjordes i en enda TCP-session, men webbläsare begär vanligtvis bara sidan och de objekt som ingår i den (bilder, överlappande stilar, etc.) och avslutar sedan TCP-sessionen omedelbart. HTTP använder cookies för att stödja auktoriserad (icke-anonym) åtkomst ; Dessutom tillåter denna auktoriseringsmetod dig att spara sessionen även efter att klienten och servern har startat om.
Vid åtkomst till data via FTP eller filprotokoll bestäms filtypen (mer exakt vilken typ av data som finns i den) av filnamnstillägget, vilket inte alltid är bekvämt. HTTP, innan själva data överförs, sänder Content-Type: typ/subtyp-huvudet, vilket gör att klienten entydigt kan bestämma hur de skickade data ska behandlas. Detta är särskilt viktigt när man arbetar med CGI- skript, när filnamnstillägget inte indikerar typen av data som skickas till klienten, utan behovet av att köra den här filen på servern och skicka resultaten av programmet som skrivits i den här filen till klienten (i det här fallet, samma fil i beroende på förfrågningsargumenten och dess egna överväganden, kan den generera svar av olika typer - i det enklaste fallet bilder i olika format).
Dessutom tillåter HTTP klienten att skicka parametrar till servern, som kommer att skickas till CGI-skriptet som körs. För detta introducerades formulär i HTML .
Dessa funktioner i HTTP gjorde det möjligt att skapa sökmotorer (av vilka den första var AltaVista , skapad av DEC ), forum och internetbutiker. Detta kommersialiserade Internet, företag dök upp, vars huvudsakliga verksamhetsområde var tillhandahållande av internetåtkomst (leverantörer) och skapandet av webbplatser.
All programvara för att arbeta med HTTP-protokollet är indelad i tre breda kategorier:
För att skilja slutservrar från proxyservrar använder den officiella dokumentationen termen ursprungsserver . En och samma mjukvaruprodukt kan samtidigt utföra funktionerna hos en klient, server eller mellanhand, beroende på uppgifterna. HTTP-protokollspecifikationerna beskriver beteendet för var och en av dessa roller.
HTTP-protokollet designades ursprungligen för att komma åt hypertextdokument på World Wide Web. Därför är de huvudsakliga klientimplementeringarna webbläsare (användaragenter). För att se det sparade innehållet på webbplatser på en dator utan internetanslutning uppfanns offlinewebbläsare . När anslutningen är instabil används nedladdningshanterare för att ladda ner stora filer ; de tillåter dig att ladda ner de angivna filerna när som helst efter att anslutningen till webbservern har förlorats. Vissa virtuella atlaser (som Google Earth och NASA World Wind ) använder också HTTP.
Ofta används HTTP-protokollet av program för att ladda ner uppdateringar.
En hel rad robotprogram används i sökmotorer på Internet . Bland dem finns webbspindlar ( crawlers ) som går igenom hyperlänkar, sammanställer en databas med serverresurser och lagrar deras innehåll för vidare analys.
Huvudimplementationer: Apache , Internet Information Services (IIS), nginx , LiteSpeed Web Server (LSWS), Google Web Server , lighttpd .
Huvudimplementationer: Squid , UserGate , Multiproxy , Naviscope , nginx .
Varje HTTP-meddelande består av tre delar, som skickas i den ordning som anges:
Brödtexten i meddelandet kan utelämnas, men startraden och rubriken är obligatoriska element. Undantaget är version 0.9 av protokollet, där förfrågningsmeddelandet endast innehåller startraden och svarsmeddelandet endast innehåller meddelandetexten.
För protokollversion 1.1 måste begärandemeddelandet innehålla värdhuvudet .
Startsträngarna är olika för begäran och svar. Frågesträngen ser ut så här:
GET URI — för protokollversion 0.9; Метод URI HTTP/Версия - för andra versioner.Här:
För att begära en sida för den här artikeln måste klienten skicka strängen (endast en rubrik ges):
Hämta /wiki/HTTP HTTP/1.0 Värd: en.wikipedia.orgStartraden för serversvaret har följande format: HTTP/Версия КодСостояния Пояснение, där:
Till exempel kan startraden för serverns svar på en tidigare begäran se ut så här:
HTTP/1.0 200 OKHTTP-metod ( engelska HTTP-metod ) - en sekvens av alla tecken, förutom kontroll och avgränsare, som indikerar huvudoperationen på resursen. Vanligtvis är metoden ett kort engelskt ord skrivet med versaler. Observera att metodnamnet är skiftlägeskänsligt.
Servern kan använda vilka metoder som helst, det finns inga obligatoriska metoder för servern eller klienten. Om servern inte känner igen metoden som specificerats av klienten, bör den returnera statusen 501(Inte implementerad). Om metoden är känd för servern, men den inte är tillämplig på en viss resurs, returneras ett meddelande med en kod 405(Method Not Allowed). I båda fallen SKA servern inkludera en rubrik Allowmed en lista över metoder som stöds i svarsmeddelandet.
Utöver metoderna GEToch HEADanvänds ofta metoden POST.
ALTERNATIVAnvänds för att fastställa webbserverns funktioner eller anslutningsalternativ för en viss resurs. Som svar SKA servern inkludera en rubrik Allowmed en lista över metoder som stöds. Svarshuvudet kan också innehålla information om tillägg som stöds.
Det antas att klientförfrågan kan innehålla en meddelandekropp för att ange de uppgifter som är av intresse för honom. Formatet på kroppen och ordningen för att arbeta med det är inte definierat för närvarande; servern bör ignorera det för tillfället. Situationen är liknande med kroppen i serversvaret.
För att ta reda på funktionerna för hela servern måste klienten ange en asterisk - " *" - i URI:n. Förfrågningar " OPTIONS * HTTP/1.1" kan också användas för att kontrollera serverns tillstånd (liknande " ping ") och för att testa om servern stöder HTTP version 1.1-protokollet.
Resultatet av att köra den här metoden cachelagras inte .
HÄMTAAnvänds för att fråga efter innehållet i den angivna resursen. GETDu kan också starta en process med hjälp av en metod . I det här fallet bör information om hur processen fortskrider inkluderas i brödtexten i svarsmeddelandet.
Klienten kan skicka exekveringsparametrar för begäran i målresursens URI efter ?tecknet " ":
GET /path/resource?param1=value1¶m2=value2 HTTP/1.1
Enligt HTTP-standarden anses typbegäranden GETvara idempotenta [2]
Förutom den vanliga metoden GETfinns det också
Ordningen för utförande av sådana förfrågningar definieras separat av standarderna.
HEADLiknar metoden GET, förutom att det inte finns någon text i serversvaret. Frågan HEADanvänds vanligtvis för att hämta metadata , kontrollera om det finns en resurs ( URL -validering ) och se om den har ändrats sedan den senast användes.
Svarsrubriker kan cachelagras. Om resursmetadata inte matchar motsvarande information i cachen markeras kopian av resursen som föråldrad.
POSTAnvänds för att skicka användardata till en given resurs. Till exempel i bloggar kan besökare vanligtvis skriva in sina kommentarer på inlägg i ett HTML-formulär, varefter de skickas till servern med POST -metoden och den placerar dem på sidan. I det här fallet inkluderas de överförda uppgifterna (i bloggexemplet, kommentarstexten) i förfrågningstexten. På samma sätt, med metoden POST, laddas filer vanligtvis upp till servern.
Till skillnad från metoden anses GETmetoden POSTinte vara idempotent [2] , det vill säga upprepade upprepningar av samma frågor POSTkan ge olika resultat (till exempel, efter att varje kommentar har skickats, kommer en annan kopia av denna kommentar att visas).
Om exekveringsresultatet är 200(Ok), bör svarsinstansen inkludera ett meddelande om resultatet av begäran. Om en resurs har skapats SKA servern returnera ett svar 201(Created) med URI :n för den nya resursen i Location.
Svarsmeddelandet för metodexekveringsservern är POSTinte cachelagrat.
PUTSAnvänds för att ladda ner innehållet i begäran till den URI som anges i begäran. Om en resurs inte finns för den givna URI:n skapar servern den och returnerar statusen 201(Skapat). Om resursen har ändrats, returnerar servern 200(Ok) eller 204(Inget innehåll). Servern FÅR INTE ignorera ogiltiga rubriker Content-*som skickas av klienten tillsammans med meddelandet. Om någon av dessa rubriker inte kan kännas igen eller är ogiltig under nuvarande förhållanden, måste en felkod 501(ej implementerad) returneras.
Den grundläggande skillnaden mellan metoderna POSTligger PUTi att förstå syftet med resurs-URI. Metoden POSTförutsätter att innehållet som överförs av klienten kommer att bearbetas vid den specificerade URI. Genom att använda PUT, antar klienten att innehållet som laddas matchar resursen vid den givna URI:n.
Serversvarsmeddelanden till en metod PUTcachelagras inte.
PATCHLiknar PUT, men gäller bara för ett resursfragment.
DELETETar bort den angivna resursen.
SPÅRAReturnerar den mottagna begäran så att klienten kan se vilken information mellanservrar lägger till eller ändrar i begäran.
ANSLUTAKonverterar förfrågningsanslutningen till en transparent TCP/IP- tunnel, vanligtvis för att underlätta upprättandet av en säker SSL- anslutning via en okrypterad proxy .
Statuskoden är en del av den första raden i serverns svar. Det är ett tresiffrigt heltal [3] . Den första siffran anger statusklassen. Svarskoden följs vanligtvis av en mellanslagsseparerad förklarande fras på engelska, som förklarar för personen orsaken till ett sådant svar. Exempel:
201 Webbsida skapad 403 Åtkomst tillåts endast för registrerade användare 507 Otillräcklig lagringKunden lär sig av svarskoden om resultatet av sin förfrågan och bestämmer vilka åtgärder som ska vidtas härnäst. Uppsättningen av statuskoder är en standard och de beskrivs i relevanta RFC- dokument . Införandet av nya koder bör endast ske efter samråd med IETF . Klienten kanske inte känner till alla statuskoder, men den måste svara enligt kodklassen.
Det finns för närvarande fem klasser av statuskoder
Koden | Klass | Ändamål |
---|---|---|
1xx | Informationsinformation
(eng. informativ ) |
Information om överföringsprocessen.
I HTTP/1.0 bör meddelanden med sådana koder ignoreras. I HTTP/1.1 måste klienten vara beredd att acceptera denna meddelandeklass som ett normalt svar, men ingenting behöver skickas till servern. Meddelanden från själva servern innehåller endast svarsstartraden och, om så krävs, några svarsspecifika rubrikfält. Proxyservrar bör skicka sådana meddelanden vidare från servern till klienten. |
2xx | Framgång
(Engelska framgång ) |
Informera om fall av framgångsrik acceptans och handläggning av klientens begäran. Beroende på status kan servern fortfarande skicka meddelandets rubriker och brödtext. |
3xx | dirigera om
(eng. Omdirigering ) |
Informerar klienten om att ytterligare en begäran (vanligtvis av en annan URI) måste göras för att slutföra operationen. Från den här klassen hänvisar fem koder 301, 302, 303, 305och 307direkt till omdirigeringar (omdirigering). Adressen som klienten ska göra en begäran till anges av servern i Location. Detta gör att fragment kan användas i mål-URI. |
4xx | Klientfel
(Engelska klientfel ) |
Indikation på fel från klientsidan. När du använder alla metoder utom HEAD, måste servern returnera en hypertextförklaring för användaren i meddelandets brödtext. |
5xx | Serverfel
(Engelska serverfel ) |
Informera om fall av misslyckad drift på grund av fel på servern. För alla andra situationer än att använda metoden HEADMÅSTE servern inkludera en förklaring i meddelandets brödtext som klienten kommer att visa för användaren. |
HTTP-rubriker är strängar i ett HTTP-meddelande som innehåller ett kolonseparerat parameter-värdepar . Formatet på rubrikerna följer det allmänna formatet för ARPA-textnätverksmeddelanderubriker (se RFC 822 ). Rubriker måste separeras från meddelandetexten med minst en tom rad.
Exempel på rubriker:
Server: Apache/2.2.11 (Win32) PHP/5.3.0 Senast ändrad: lör, 16 januari 2010 21:16:42 GMT Content-Type: text/plain; charset=windows-1251 Innehåll-Språk: svI exemplet ovan representerar varje rad en rubrik. I det här fallet kallas det som står före kolon för namnet ( engelska namn ), och det som står efter det kallas för värdet ( engelskt värde ).
Alla rubriker är indelade i fyra huvudgrupper:
Detta är den ordning som det rekommenderas att skicka rubrikerna till mottagaren.
Alla rubriker som krävs för att HTTP ska fungera beskrivs i de centrala RFC :erna . Om det inte finns tillräckligt med befintliga kan du ange din egen. Traditionellt har namnen på sådana extra rubriker prefixet " X-" för att undvika namnkonflikter med eventuellt befintliga. Till exempel, som i rubriker X-Powered-Byeller X-Cache. Vissa utvecklare använder sina egna anpassade prefix. Exempel på sådana rubriker är de som Ms-Echo-Requestintroducerats Ms-Echo-Replyav Microsoft för WebDAV- tillägget .
HTTP-meddelandetexten ( message-body), om den finns, används för att förmedla objektkroppen som är associerad med begäran eller svaret. Meddelandetexten skiljer sig från objektkroppen ( entity-body) endast när en överföringskodning tillämpas, vilket indikeras av rubrikfältet Transfer-Encoding.
meddelandekropp = enhetskropp | <enhetskropp kodad enligt överföringskodning>Fältet Transfer-Encodingska användas för att indikera eventuell överföringskodning som tillämpas av applikationen för att säkerställa att meddelandet sänds säkert och korrekt. Ett fält Transfer-Encoding är en egenskap hos ett meddelande, inte ett objekt, och kan därför läggas till eller tas bort av vilken applikation som helst i begäran/svarskedjan.
Reglerna som styr giltigheten av en meddelandekropp i ett meddelande är olika för förfrågningar och svar.
Förekomsten av en meddelandekropp i en begäran indikeras genom att lägga till ett rubrikfält Content-Lengtheller till förfrågans rubriker Transfer-Encoding. En meddelandetext kan bara läggas till en begäran när begäranmetoden tillåter en objektkropp.
Huruvida meddelandekroppen är inkluderad i svarsmeddelandet eller inte beror på både förfrågningsmetoden och svarsstatuskoden. Alla svar på en begäran med en metod HEADfår inte innehålla en meddelandetext, även om objekthuvudfält ( entity-header) finns för att få det att se ut som om objektet finns. Inga svar med statuskoder 1xx(Informativ), 204(Inget innehåll) och 304(Inte ändrad) får innehålla en meddelandetext. Alla andra svar innehåller en meddelandetext, även om den är noll.
Kundförfrågan:
HÄMTA /wiki/ HTTP/1.1- sida Värd: en.wikipedia.org User-Agent: Mozilla/5.0 (X11; U; Linux i686; ru; rv:1.9b5) Gecko/2008050509 Firefox/3.0b5 Acceptera: text/html Anslutning: stäng (tom rad)Serversvar:
HTTP/1.1 200 OK Datum: ons, 11 februari 2009 11:20:59 GMT Server: Apache X-Powered-By: PHP/5.2.4-2ubuntu5wm1 Senast ändrad: ons, 11 februari 2009 11:20:59 GMT Innehåll-Språk: sv Content-Type: text/html; charset=utf-8 Innehållslängd: 1234 Anslutning: stäng (tom sträng) (begärd sida i HTML )Svaret ser likadant ut 203. Vad som är viktigt - direkt begärd data separeras från HTTP-rubriker med CR , LF , CR, LF.
OmdirigeringarAntag att det fiktiva företaget "Example Corp." det finns en huvudwebbplats på "http://example.com" och en aliasdomän "example.org" . Klienten skickar en begäran om sidan "Om" till den sekundära domänen (vissa rubriker utelämnas):
Hämta /about.html HTTP/1.1 Värd: example.org Användaragent: MyLonelyBrowser/5.0Eftersom "example.org" -domänen inte är en primär domän och företaget inte har för avsikt att använda den för andra ändamål i framtiden, kommer deras server att returnera en kod för en permanent omdirigering, som anger Locationmåladressen i rubriken:
HTTP/1.x 301 flyttade permanent Plats: http://example.com/about.html#contacts Datum: tors, 19 februari 2009 11:08:01 GMT Server: Apache/2.2.4 Content-Type: text/html; charset=windows-1251 Innehållslängd: 110 (tom rad) <html><body><a href="http://example.com/about.html#contacts">Klicka här</a></body></html>I titeln Locationkan du ange fragment som i det här exemplet. Webbläsaren angav inte ett fragment i begäran eftersom den är intresserad av hela dokumentet. Men den kommer automatiskt att rulla sidan till "kontakter"-fragmentet så snart den laddas. Ett kort HTML-dokument placerades också i brödtexten med en länk som skulle ta besökaren till målsidan om webbläsaren inte automatiskt navigerade till den. Titeln Content-Typeinnehåller egenskaperna för den specifika HTML-förklaringen, inte för dokumentet som finns på mål-URI:n.
Låt oss säga samma företag "Example Corp." har flera regionala kontor runt om i världen. Och för varje byrå har de en webbplats med motsvarande ccTLD . Hemsidesbegäran för huvudwebbplatsen "example.com" kan se ut så här:
Hämta /HTTP/1.1 värd: example.com Användaragent: MyLonelyBrowser/5.0 Acceptera: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 Acceptera-språk: ru,en-us;q=0.7,en;q=0.3 Acceptera-Charset: windows-1251,utf-8;q=0.7,*;q=0.7Servern tog hänsyn till rubriken Accept-Languageoch bildade ett svar med en tillfällig omdirigering till den ryska servern "example.ru" , som anger dess adress i rubriken Location:
HTTP/1.x 302 hittades Plats: http://example.ru/ Cache-kontroll: privat Datum: tors, 19 februari 2009 11:08:01 GMT Server: Apache/2.2.6 Content-Type: text/html; charset=windows-1251 Innehållslängd: 82 (tom rad) <html><body><a href="http://example.ru">Example Corp.</a></body></html>Var uppmärksam på rubriken Cache-Control: värdet "privat" talar om för resten av servrarna (främst proxyservrar) att svaret endast kan cachelagras på klientsidan. Annars är det möjligt att följande besökare från andra länder alltid går till en annan representation.
303Svarskoderna (Se övrigt) och 307(Temporär omdirigering) används också för omdirigering .
Återuppta och ladda ner fragmentLåt oss säga att en fiktiv organisation erbjuder sig att ladda ner en video från den senaste konferensen från webbplatsen på: "http://example.org/conf-2009.avi" - cirka 160 MB i storlek . Låt oss överväga hur den här filen återupptas i händelse av misslyckande och hur nedladdningshanteraren skulle organisera flertrådig nedladdning av flera fragment.
I båda fallen kommer kunder att göra sin första begäran så här:
GET /conf-2009.avi HTTP/1.0 Värd: example.org Acceptera: */* Användaragent: Mozilla/4.0 (kompatibel; MSIE 5.0; Windows 98) Referent: http://example.org/Titeln Refererindikerar att filen begärdes från sidans huvudsida. Nedladdningshanterare anger vanligtvis det också för att efterlikna övergången från webbplatssidan. Utan det kan servern svara 403(åtkomst förbjuden) om förfrågningar från andra webbplatser inte är tillåtna. I vårt fall returnerade servern ett framgångsrikt svar:
HTTP/1.1 200 OK Datum: Tors, 19 februari 2009 12:27:04 GMT Server: Apache/2.2.3 Senast ändrad: ons, 18 juni 2003 16:05:58 GMT ETag: "56d-9989200-1132c580" Innehållstyp: video/x-msvideo Innehållslängd: 160993792 Acceptera-intervall: byte Anslutning: stäng (tom sträng) (binärt innehåll i hela filen)Rubriken Accept-Rangesinformerar klienten om att den kan begära fragment från servern genom att ange deras offset från början av filen i byte. Om den här rubriken saknas, KAN klienten varna användaren om att filen med största sannolikhet inte kommer att laddas ned.
Baserat på rubrikvärdet Content-Lengthkommer nedladdningshanteraren att dela upp hela volymen i lika stora fragment och begära dem separat och organisera flera strömmar. Om servern inte anger en storlek kommer klienten inte att kunna implementera parallella nedladdningar, men den kommer fortfarande att kunna ladda ner filen tills servern svarar 416(Requested Range Not Satisfiable).
Låt oss säga att vid den 84:e megabyten avbröts internetanslutningen och nedladdningsprocessen stoppades. När internetanslutningen återställdes skickade nedladdningshanteraren automatiskt en ny begäran till servern, men med en instruktion att returnera innehållet från den 84:e megabyten:
GET /conf-2009.avi HTTP/1.0 Värd: example.org Acceptera: */* Användaragent: Mozilla/4.0 (kompatibel; MSIE 5.0; Windows 98) Område: bytes=88080384- Referent: http://example.org/Servern behöver inte komma ihåg vad och från vilka förfrågningar gjordes tidigare, och därför satte klienten in rubriken igen Referer, som om det vore dess allra första begäran. Det angivna huvudvärdet Rangesäger till servern: "Ge innehållet från byte 88080384 till slutet." I detta avseende kommer servern att returnera ett svar:
HTTP/1.1 206 Delvis innehåll Datum: Tors, 19 februari 2009 12:27:08 GMT Server: Apache/2.2.3 Senast ändrad: ons, 18 juni 2003 16:05:58 GMT ETag: "56d-9989200-1132c580" Acceptera-intervall: byte Innehållsintervall: byte 88080384-160993791/160993792 Innehållslängd: 72913408 Anslutning: stäng Innehållstyp: video/x-msvideo (tom sträng) (binärt innehåll från 84:e megabyte)Rubriken Accept-Rangeskrävs inte längre här, eftersom klienten redan är medveten om denna serverkapacitet. Att ett fragment överförs är känt för klienten av koden 206(Partial Content). Rubriken Content-Rangeinnehåller information om detta fragment: numren på start- och slutbyten, och efter snedstrecket, den totala storleken på hela filen i byte. Var uppmärksam på rubriken Content-Length - den indikerar storleken på meddelandekroppen, det vill säga det överförda fragmentet. Om servern returnerar flera fragment kommer den Content-Lengthatt innehålla deras totala volym.
Nu tillbaka till nedladdningshanteraren. Genom att veta den totala storleken på filen "conf-2009.avi" delade programmet upp den i 10 lika stora sektioner.
Den initiala hanteraren laddas vid den allra första begäran och avbryter anslutningen så snart den når början av den andra. Resten kommer att begäras separat. Till exempel skulle det fjärde avsnittet begäras med följande rubriker (vissa rubriker utelämnade - se hela exemplet ovan):
GET /conf-2009.avi HTTP/1.0 Område: byte=64397516-80496894Serversvaret i detta fall kommer att vara följande (en del av rubrikerna är utelämnade - se hela exemplet ovan):
HTTP/1.1 206 Delvis innehåll Acceptera-intervall: byte Innehållsintervall: byte 64397516-80496894/160993792 Innehållslängd: 16099379 (tom sträng) (binärt innehåll i fjärde delen)Om en sådan begäran skickas till en server som inte stöder fragment, kommer den att returnera ett standardsvar 200(OK) som visas i början, men utan rubriken Accept-Ranges.
Se även partiell GET , byteintervall , svar 206 , svar 416 .HTTP låter dig begära inte allt innehåll i resursen på en gång, utan bara det angivna fragmentet. Sådana förfrågningar kallas partiella GET; möjligheten att köra dem är valfri (men önskvärd) för servrar. Partialer används GETfrämst för att återuppta filer och snabba parallella nedladdningar i flera trådar. Vissa program laddar ner arkivhuvudet, visar den interna strukturen för användaren och begär sedan fragment med de angivna arkivelementen.
För att ta emot ett fragment skickar klienten en begäran till servern med en rubrik Rangesom anger de nödvändiga byteintervallen i den . Om servern inte förstår partiella förfrågningar (ignorerar rubriken Range), kommer den att returnera allt innehåll med status 200, precis som med en normal GET. I händelse av framgångsrikt slutförande returnerar servern ett 200svar med status 206(Partial Content) istället för en kod, inklusive rubriken i svaret Content-Range. Själva fragmenten kan skickas på två sätt:
Metoden GETändras till "villkorlig GET" om begäransmeddelandet innehåller ett rubrikfält If-Modified-Since. Som svar på "villkorlig GET" skickas den begärda resursens brödtext endast om den har ändrats sedan det datum som anges i rubriken If-Modified-Since. Algoritmen för att bestämma detta inkluderar följande fall:
Användningen av metoden "villkorlig GET" syftar till att avlasta nätverket, eftersom det tillåter att inte överföra redundant information över nätverket.
Innehållsförhandling är en mekanism för att automatiskt fastställa vilken resurs som krävs i närvaro av flera olika versioner av ett dokument. Förhandlingsämnen kan inte bara vara serverresurser, utan också returnerade sidor med felmeddelanden ( 403 , 404 , etc.).
Det finns två huvudtyper av avtal:
Båda typerna kan användas samtidigt eller var och en av dem separat.
Huvudprotokollspecifikationen ( RFC 2616 ) framhäver också den så kallade transparenta förhandlingen som den föredragna kombinationen av båda typerna . Den senare mekanismen ska inte förväxlas med den oberoende Transparent Content Negotiation-tekniken (TCN) , som inte är en del av HTTP-protokollet men kan användas med det. Båda har en betydande skillnad i funktionsprincipen och själva innebörden av ordet "transparent" (transparent). I HTTP-specifikationen betyder transparens att processen är osynlig för klienten och servern, och i TCN-tekniken innebär transparens tillgången till en komplett lista med resursalternativ för alla deltagare i dataleveransprocessen.
ServerhanteradOm det finns flera versioner av en resurs kan servern analysera klientens förfrågningsrubriker för att returnera vad den tycker är den bästa. Rubrikerna Accept, Accept-Charset, Accept-Encodingoch är huvudsakligen Accept-Languagestolkade User-Agent. Det är önskvärt för servern att inkludera en rubrik i svaret som Varyindikerar parametrarna med vilka innehållet särskiljs av den begärda URI:n.
Den geografiska platsen för klienten kan bestämmas från fjärr -IP-adressen . Detta är möjligt på grund av att IP-adresser, som domännamn , är registrerade på en specifik person eller organisation. Vid registrering anger du i vilken region det önskade adressutrymmet ska användas. Denna information är allmänt tillgänglig, och på Internet kan du hitta motsvarande fritt distribuerade databaser och färdiga programvarumoduler för att arbeta med dem (du bör fokusera på nyckelorden "Geo IP").
Man bör komma ihåg att denna metod kan bestämma platsen med en maximal noggrannhet av staden (härifrån bestäms landet). I detta fall är informationen relevant endast vid tidpunkten för registrering av adressutrymmet. Till exempel, om en Moskva-leverantör registrerar ett antal adresser som indikerar Moskva och börjar ge åtkomst till kunder från de närmaste förorterna, kan dess abonnenter på vissa webbplatser observera att de är från Moskva, och inte från Krasnogorsk eller Dzerzhinsky .
Serverhanterad förhandling har flera nackdelar:
I det här fallet bestäms innehållstypen endast på klientsidan. För att göra detta returnerar servern i ett svar med en statuskod 300(Multiple Choice) eller 406(Inte acceptabelt) en lista med alternativ, bland vilka användaren väljer lämpligt. Klientstyrd förhandling fungerar bra när innehållet skiljer sig åt på de vanligaste sätten (som språk och kodning) och en offentlig cache används.
Den största nackdelen är overheaden, eftersom du måste göra en ytterligare begäran för att få önskat innehåll.
Transparent förhandlingDenna förhandling är helt transparent för klienten och servern. I det här fallet används en delad cache, som innehåller en lista med alternativ, som för en klienthanterad förhandling. Om cachen förstår alla dessa alternativ, gör den själva valet, som i en serverhanterad förhandling. Detta minskar belastningen på ursprungsservern och eliminerar ytterligare begäran från klienten.
HTTP-kärnspecifikationen beskriver inte den transparenta förhandlingsmekanismen i detalj.
HTTP-protokollet stöder överföring av flera enheter inom ett enda meddelande. Entiteter kan dessutom överföras inte bara som en sekvens på en nivå, utan också som en hierarki med element inkapslade i varandra. Medietyper används för att beteckna flera innehåll multipart/*. Arbete med sådana typer utförs enligt de allmänna reglerna som beskrivs i RFC 2046 (om inte annat definieras av en specifik mediatyp). Om mottagaren inte vet hur man arbetar med typen, behandlar den den på samma sätt som multipart/mixed.
Gränsparametern betyder avgränsaren mellan de olika typerna av meddelanden som skickas. Till exempel skickar parametern DestAddress som skickas från formuläret värdet på e-postadressen, och elementet AttachedFile1 som följer efter det skickar det binära innehållet i .jpg-bilden
På serversidan kan meddelanden med flera innehåll skickas som svar på delmeddelandenGET när flera resursfragment efterfrågas. I det här fallet används mediatypen multipart/byteranges.
På klientsidan, när du skickar ett HTML- formulär, visas POST. Ett typiskt exempel är e-postsidor med bifogade filer. När du skickar ett sådant brev genererar webbläsaren ett meddelande av typen multipart/form-data, som integreras i det som separata delar som användaren anger, ämnet för brevet, mottagarens adress, själva texten och bifogade filer:
POST /send-message.html HTTP/1.1 Värd: mail.example.com Referens: http://mail.example.com/send-message.html Användaragent: BrowserForDummies/4.67b Content-Type: multipart/form-data; boundary="Asrf456BGe4h" Innehållslängd: (total längd inklusive underordnade rubriker) Anslutning: hålla vid liv Håll vid liv: 300 (tom sträng) (ingress saknas) --Asrf456BGe4h Innehåll-Disposition: form-data; name="DestAddress" (tom rad) [email protected] --Asrf456BGe4h Innehåll-Disposition: form-data; name="MessageTitle" (tom rad) Jag avskyr --Asrf456BGe4h Innehåll-Disposition: form-data; name="MessageText" (tom rad) Hej Vasily! Ditt husdjurslejon lämnade du efter dig jag förra veckan, slet isär hela min soffa. Vänligen hämta den snart! Bifogar två bilder på efterspelet. --Asrf456BGe4h Innehåll-Disposition: form-data; name="AttachedFile1"; filename="horror-photo-1.jpg" Innehållstyp: bild/jpeg (tom sträng) (binärt innehåll i första fotot) --Asrf456BGe4h Innehåll-Disposition: form-data; name="AttachedFile2"; filename="horror-photo-2.jpg" Innehållstyp: bild/jpeg (tom sträng) (binärt innehåll i andra fotot) --Asrf456BGe4h-- (saknar epilog)I exemplet i rubrikerna matchar Content-Dispositionparametern attributet i HTML-taggarna och . Parametern är lika med det ursprungliga filnamnet på användarens dator. Se RFC 1867 för mer information om HTML-formulärgenerering och filbilaga . namename<INPUT><TEXTAREA>filename
URI- scheman | |
---|---|
Officiell | |
inofficiell |
TCP / IP-protokoll efter lager av OSI-modellen | Grundläggande|
---|---|
Fysisk | |
kanaliserad | |
nätverk | |
Transport | |
session | |
Representation | |
Applicerad | |
Annat ansökt | |
Lista över TCP- och UDP-portar |
Webb och hemsidor | |
---|---|
globalt | |
Lokalt | |
Typer av webbplatser och tjänster |
|
Skapande och underhåll | |
Typer av layouter, sidor, webbplatser | |
Teknisk | |
Marknadsföring | |
Samhälle och kultur |
semantisk webb | |
---|---|
Grunderna | |
Underavsnitt |
|
Ansökningar |
|
Relaterade ämnen | |
Standarder |
|
http | |
---|---|
Allmänna begrepp |
|
Metoder | |
Titlar |
|
Statuskoder |