淺談http和https協議與nodeJs的應用

来源:http://www.cnblogs.com/undefined-w/archive/2017/10/26/7727864.html
-Advertisement-
Play Games

HTTP協議的主要特點:1.支持客戶/伺服器模式。2.簡單快速:客戶向伺服器請求服務時,只需傳送請求方法和路徑。請求方法常用的有GET、HEAD、POST。3.靈活:HTTP允許傳輸任意類型的數據對象。正在傳輸的類型由Content-Type加以標記。4.限制每次連接只處理一個請求。伺服器處理完客戶 ...


HTTP協議的主要特點:
1.支持客戶/伺服器模式。
2.簡單快速:客戶向伺服器請求服務時,只需傳送請求方法和路徑。請求方法常用的有GET、HEAD、POST。
3.靈活:HTTP允許傳輸任意類型的數據對象。正在傳輸的類型由Content-Type加以標記。
4.限制每次連接只處理一個請求。伺服器處理完客戶的請求,並收到客戶的應答後,即斷開連接。採用這種方式可以節省傳輸時間。
5.HTTP協議是無狀態協議。無狀態是指協議對於事務處理沒有記憶能力。缺少狀態意味著如果後續處理需要前面的信息,則它必須重傳,這樣可能導致每次連接傳送的數據量增大。另一方面,在伺服器不需要先前信息時它的應答就較快。

 



HTTP協議之URL
HTTP URL (URL是一種特殊類型的URI,包含了用於查找某個資源的足夠的信息)的格式如下:
http://host[":"port][abs_path]
http表示要通過HTTP協議來定位網路資源;host表示合法的Internet主機功能變數名稱或者IP地址;port指定一個埠號,為空則使用預設埠80;abs_path指定請求資源的URI;如果URL中沒有給出abs_path,那麼當它作為請求URI時,必須以“/”的形式給出,通常瀏覽器會自動幫我們完成。

例如:

輸入:www.cnblogs.com/undefined-w
瀏覽器自動轉換成:http://www.cnblogs.com/undefined-w/

 因此在nodejs中構建路由時,一般主頁對應的是  “/”

nodejs中的核心模塊URL有url.parse()方法可以解析url,有三個參數,第一個參數為url,為必須參數,第二個參數預設為false,為true時會將querystring解析成對象的形式,第三個參數是沒有http時的配置,用法如下:

const url = require("url");
const urlObject = url.parse("http://www.cnblogs.com/undefined-w/",true);
console.log(urlObject);


HTTP請求由三部分組成,分別是:請求行、消息報頭、請求正文

HTTP響應也是由三個部分組成,分別是:狀態行、消息報頭、響應正文

具體介紹下nodejs可能用到的狀態行和消息報頭


狀態行格式如下:
HTTP-Version   Status-Code   Reason-Phrase CRLF
其中,HTTP-Version表示伺服器HTTP協議的版本;Status-Code表示伺服器發回的響應狀態代碼(常用的有200,304,404,500;200表示請求成功,304表示從緩存中載入,404表示路徑錯誤未找到,500內部伺服器錯誤);Reason-Phrase表示狀態

HTTP消息報頭包括普通報頭、請求報頭、響應報頭、實體報頭。
每一個報頭域格式 : 名字+“:”+空格+值,名字是不區分大小的。

實體報頭
請求和響應消息都可以傳送一個實體。一個實體由 實體報頭域和實體正文 組成,實體報頭定義了關於實體正文和請求所標識的資源的元信息。
常用的實體報頭
1、Content-Encoding實體報頭域被用作媒體類型的修飾符,它的值指示了已經被應用到實體正文的附加內容的編碼,因而要獲得Content-Type報頭域中所引用的媒體類型,必須採用相應的解碼機制。

Content-Encoding這樣用於記錄文檔的壓縮方法,eg:Content-Encoding:gzip

2、Content-Language實體報頭域描述了資源所用的自然語言。沒有設置該域則認為實體內容將提供給所有的語言閱讀者

3、Content-Length實體報頭域用於指明實體正文的長度,以位元組方式存儲的十進位數字來表示。

4、Content-Type實體報頭域用語指明發送給接收者的實體正文的媒體類型。

Content-Type:text/html;charset=ISO-8859-1

Content-Type:text/html;charset=GB2312

Content-Type:image/jpg (圖片格式)

5、Last-Modified實體報頭域用於指示資源的最後修改日期和時間。

6、Expires實體報頭域給出響應過期的日期和時間。為了讓代理伺服器或瀏覽器在一段時間以後更新緩存中的頁面,我們可以使用Expires實體報頭域指定頁面過期的時間。

 一個簡單的示例:

 1 const http = require('http');//引入http模塊
 2 const host = '127.0.0.1';//ip地址(迴環地址)
 3 const port = '1234';//
 4 //創建服務
 5 const server = http.createServer((req,res)=>{
 6 
 7     // res.statusCode = 200;
 8     // res.setHeader("Content-Type","text/plain")//輸出為純文本格式
 9     // res.setHeader("Content-Type","text/html;charset=utf8")//charset表示字元,不然漢字會輸出亂碼
10     res.writeHead(200,{//以上的簡寫
11         "Content-Type":"text/html;charset=utf8"
12     })
13     res.end('示例');
14 }).listen(port)


HTTP 協議的主要不足:
1、通信使用明文( 不加密) , 內容可能會被竊聽
2、不驗證通信方的身份, 因此有可能遭遇偽裝
3、無法證明報文的完整性, 所以有可能已遭篡改

通過使用HTTPS協議可以解決前兩個不足:
HTTPS協議是由SSL+HTTP協議構建的可進行加密傳輸、身份認證的網路協議
SSL 不僅提供加密處理,而且還使用了一種被稱為證書的手段,可用於確定方。證書由值得信任的第三方機構頒發,用以證明伺服器和客戶端是實際存在的。

HTTPS和HTTP的區別:
1、https協議需要到ca申請證書,一般免費證書很少,需要交費。
2、http是超文本傳輸協議,信息是明文傳輸,https 則是具有安全性的ssl加密傳輸協議。
3、http和https使用的是完全不同的連接方式用的預設埠也不一樣,前者是80,後者是443。
4、http的連接很簡單,是無狀態的,
https協議是由SSL+HTTP協議構建的可進行加密傳輸、身份認證的網路協議 要比http協議安全。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 有很多朋友有的因為興趣,有的因為生計而走向了.Net中,有很多朋友想學,但是又不知道怎麼學,學什麼,怎麼系統的學,為此我以我微薄之力總結歸納寫了一篇.Net web開發技術棧,以此幫助那些想學,卻不知從何起的朋友。 本文整理了當前企業web開發中的管理系統,商城等系統的常用開發技術棧。 C#常見運算 ...
  • .net中常會用到動態載入DLL,而DLL中可能包含各種參數、方法、窗體,如何來調用動態載入這些參數、方法、窗體呢? 在C#中,我們要使用反射,首先要搞清楚以下命名空間中幾個類的關係: System.Reflection命名空間 (1) AppDomain:應用程式域,可以將其理解為一組程式集的邏輯 ...
  • 首先討論下,有多少實際工作經驗叫老程式員呢?我這裡定義5年吧,畢竟我才在公司開發了5年多點.(真真實實的開發了5年多,極少出差,一坐一天的開發.畢業前兩年沒從事開發,不算) 我寫的博客關於具體的技術,實現的詳細說明或代碼的方式寫出來的極少.因為我擅長的只是.net,桌面開發方向,新入行的程式員web ...
  • 首先給Grid添加BindingSource,類型為BindingForForm2。或者設置Grid的DataSource為IEnumerable<BindingForForm2>。 BindingForForm2類型如下。 public class BindingForForm2 { public ...
  • 今天複習到了ADO.NET,就把他們的知識梳理總結出來 ADO.NET 是一組向 .NET 程式員公開數據訪問服務的類。提供了對各種關係數據、XML 和應用程式數據的訪問。 所有的數據訪問類位於System.Data.dll中。System.Data包含了DataSet以及其他的支持類;System ...
  • 判斷是否是同一人的方法——equals() 不能直接用per1==per2,這不是對象內容的比較而是存放對象地址的值得比較 在Person類中提供一個比較的方法compare()返回boolean值 註意this關鍵字指的是當前對象。 並且在類的內部即使是私有的屬性,也不需要使用共有的方法來調用。 ...
  • 原文地址:https://codex.wordpress.org/Rewrite_API Rewrite API(重寫規則API) Description(描述) WordPress allows theme and plugin developers to programmatically spe ...
  • Akka-http routing DSL在Route運算中拋出的異常是由內向外浮出的:當內層Route未能捕獲異常時,外一層Route會接著嘗試捕捉,依次向外擴展。Akka-http提供了ExceptionHandler類來處理Route運算產生的異常: 簡單來說ExceptionHandler類 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...