Node.js之使用Buffer類處理二進位數據

来源:http://www.cnblogs.com/yuanchenghao/archive/2017/08/23/7420086.html
-Advertisement-
Play Games

Node.js之使用Buffer類處理二進位數據 Buffer類可以在處理TCP流或文件流時處理二進位數據,該類用來創建一個專門存放二進位數據的緩存區。 1. 創建Buffer對象 1.1 直接創建: bur = new BUffer(123) //123 為bur緩存區長度 1.2 初始化緩存區內 ...


Node.js之使用Buffer類處理二進位數據

Buffer類可以在處理TCP流或文件流時處理二進位數據,該類用來創建一個專門存放二進位數據的緩存區。

1. 創建Buffer對象

1.1 直接創建:

    bur = new BUffer(123) //123 為bur緩存區長度

1.2 初始化緩存區內容可以用fill屬性:

    bur.fill(value,[offset],[end])
    //value:為必填參數,數值為需要寫入的數值
    第二個參數為數據寫入的起始位置,預設為0
    第三個參數為數據寫入的終止位置,預設為最尾端

1.3 填充數據可以直接填入數組

    bur = new Buffer(array)

1.4 Buffer類還可以用字元串填充:

    bur = new Buffer(str,[encoding])
    //第一個參數為必填參數,為字元串
    第二個參數為指定文字編碼格式,預設為utf8
    還可以為:
編碼 說明 編碼 說明
ascii ASCII字元串說明 base64 經過BASE64編碼後的字元串
utf8 UTF-8字元串 binary 二進位數據(不推薦使用)
utf16le UTF-16LE字元串 hex 使用16進位數值表示的字元串
ucs2 UCS2字元串

2. 字元串的長度與緩存區的長度

字元串的長度與緩存區的長度是不同的,字元串定義後,不能改變,但在緩存區可以改變一些值,例如:

[root@kuber3 ~]# node
> str = '我是誰'
'我是誰'
> bur = new Buffer(str)
<Buffer e6 88 91 e6 98 af e8 b0 81>
> str.length
3
> bur.length
9
> str[1] ='yuan'
'yuan'
> str
'我是誰'



> str = '我是誰'
'我是誰'
> fur = new Buffer(str)
<Buffer e6 88 91 e6 98 af e8 b0 81>
> fur[0] = 0
0
> fur
<Buffer 00 88 91 e6 98 af e8 b0 81>
> 

利用slice對象可以選出指定為對象,但在緩存中slice出的對象即是元數據。緩存區中的真實值,隨意一旦改變,緩存區中的值也會變:

> buf = new Buffer('我愛你')
<Buffer e6 88 91 e7 88 b1 e4 bd a0>
> subBuf = buf.slice(1,3)
<Buffer 88 91>
> subBuf[0] = 0
0
> subBuf
<Buffer 00 91>
> buf
<Buffer e6 00 91 e7 88 b1 e4 bd a0>
> 

3. Buffer對象與字元串對象之間的相互轉換

3.1 Buffer對象的toString可以將Buffer對象那個轉換為字元串,

    buf。toString([encoding],[start],[end])
    //第一個參數用於指定Buffer對象保存的文字編碼格式
    第二個與第三個為被轉換數據的起始地址和終止地址

3。2 Buffer對象的write方法

如果需要向已創建的Buffer對象中寫入字元串,這時可以使用write方法:

    buf.write(string,[offfset],[length],[encodind])
    //第一個參數為必填參數:為需要寫入的字元串
    第二個與第三個參數為字元串的寫入位置 offset+1~offset+length
    第四個參數為寫入字元串使用的編碼格式

###3.3 StringDecoder 對象
其作用與toString相同,但需要引入string_decoder模塊

var StringDecoder = require('string_decoder').StringDecoder
var decoder = new StringDecoder([encoding])
    //c參數為制定轉換字元串時所用的編碼格式,預設為utf8

利用StringDecoder.write可以將Buffer對象中數據轉換成字元串

decoder.write(buffer)

4. Buffer對象與數值對象之間的相互轉換 讀寫Buffer對象中的數據所有方法

方法名 數據類型
buf.readUInt8(offset,[noAssert]) 8位無符號整數
buf.writeUInt8(value,offset,[noAssert])
buf.readUInt16LE(offset,[noAssert]) 16位無符號整數(Little Endian)
buf.writeUInt16LE(value,offset,[noAssert])
buf.readUInt16BE(offset,[noAssert]) 16位無符號整數(Big Endian)
buf.writeUInt16BE(value,offset,[noAssert])
buf.readUInt32LE(offset,[noAssert]) 32位無符號整數(Little Endian)
buf.writeUInt32LE(value,offset,[noAssert])
buf.readUInt32BE(offset,[noAssert]) 32位無符號整數(Big Endian)
buf.writeUInt32BE(value,offset,[noAssert])
buf.readInt8(offset,[noAssert]) 8位有符號整數
buf.writeInt8(value,offset,[noAssert])
buf.readInt16LE(offset,[noAssert]) 16位有符號整數(Little Endian)
buf.writeInt16LE(value,offset,[noAssert])
buf.readInt16BE(offset,[noAssert]) 16位有符號整數(Big Endian)
buf.writeInt16BE(value,offset,[noAssert])
buf.readInt32LE(offset,[noAssert]) 32位有符號整數(Little Endian)
buf.writeInt32LE(value,offset,[noAssert])
buf.readInt32BE(offset,[noAssert]) 32位有符號整數(Big Endian)
buf.writeInt32BE(value,offset,[noAssert])
buf.readFloatLE(offset,[noAssert]) 單精度浮點數(Little Endian)
buf.writeFloatLE(value,offset,[noAssert])
buf.readFloatBE(offset,[noAssert]) 單精度浮點數(Big Endian)
buf.writeFloatBE(value,offset,[noAssert])
buf.readDoubleLE(offset,[noAssert]) 倍精度浮點數(Little Endian)
buf.writeDoubleLE(value,offset,[noAssert])
buf.readDoubleBE(offset,[noAssert]) 倍精度浮點數(Big Endian)
buf.writeDoubleBE(value,offset,[noAssert])

其中read方法中第一個參數[offset]表示獲取數據的起始位,單位為位元組;第二個參數[noAssert]為一布爾值,表示是否對offset值進行驗證,false:如果offset參數超出緩存區長度,則拋出異常,為true時,不拋出異常

其中write方法第一個參數value為需要寫入的整數,第二個參數offset指定數據起始寫入的位置;第三個參數為布爾型,false:如果offset參數值超出緩存區的長度,會拋出異常,為true不會拋出異常

5. BUffer對象與JSON對象之間的相互轉換

在NOde.js中,可以使用JSON.stringify方法將Buffer對象中保存的數據轉換為一個字元串,也可以使用JSON.parse方法將一個經過轉換後的字元串還原為一個數組
eg:

[root@kuber3 ~]# node
> buf = new Buffer('我愛你')
<Buffer e6 88 91 e7 88 b1 e4 bd a0>
> json= JSON.stringify(buf)
'{"type":"Buffer","data":[230,136,145,231,136,177,228,189,160]}'
> copy = new Buffer(JSON.parse(json))
<Buffer e6 88 91 e7 88 b1 e4 bd a0>
> copy.toString();
'我愛你'
> 

6. 複製緩存數據

將一個BUffer對象保存到兩一個Bufer對象中可利用copy方法:

buf.copy(targetBuffer,[targetStart],[sourceStart],[sourceEnd])
//第一個參數:必選,指定複製目標Buffer對象
第二個參數:指定目標Buffer對象中從第幾個位元組開始寫入,預設為0
第三個參數:指定複製源Buffer對象中獲取數據的起始位置,預設為0
第四個參數:指定從複製源Buffer對象中獲取數據的結束位置,預設為複製源Buffer的長度

7. Buffer類的方法

7.1 isBuffer方法 判斷是否為一個Buffer對象

Buffer.isBuffer(obj)

7.2 byteLength方法 計算一個指定字元串的位元組數

Buffer.byteLength(string,[encoding])
//d第一個參數:必選,指定需要計算位元組數的位元組符
第二個參數:按什麼編碼來計算位元組數,預設為utf8

7.3 concat方法 將幾個Buffer對象結合創建一個新的Buffer對象

Buffer。concatenate(list,【totalLength】)
//第一個參數:必選 為一個存放多個Buffer對象的數組
第二個參數:指定被創建的Buffer對象的總長度

7.4 isEncoding方法 用於檢測一個字元串是否為一個有效的編碼格式字元串

Buffer.isEncoding(encoding)

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

-Advertisement-
Play Games
更多相關文章
  • 一、<meta>標簽的定義和用法 <meta> 元素可提供有關頁面的元信息(meta-information),位於文檔的頭部<head>和</head>之間,不包含任何內容。<meta> 標簽的屬性定義了與文檔相關聯的名稱/值對。 二、<meta>標簽的屬性 1.必要屬性 2.可選屬性 conte ...
  • JSON創建鍵值對(key是中文或者數字)方式詳解 先準備好一個空的json對象 1. 最原始的方法 2. 使用json[key]的方式(這邊key即使是中文也沒事) 3.使用json['key']的方式 "JSON取值方式(key為數字或者字元串)詳解" ...
  • node的非同步io雖然好用,但是控制非同步流程確實一個比較麻煩的事情,比如在爬蟲中控制併發數量,避免併發過大導致網站宕機或被加入黑名單。因此需要一個工具來控制併發,這個工具可以自己寫或者使用async(官方文檔點擊這裡)。代碼基於node 8.x,如版本過低可能會出現錯誤。 說明 async本身有七十 ...
  • 接觸 npm 也有一個多月的時間了,一直只是將他作為當著 webstorm + node.js 環境中的一個插件來用(甚至說把她當著命令來用)。畢竟大部分的時間,他是輸入的命令行中的一部分(別笑,小新人真的會存在這個問題)。這幾天決定好好整理一下關於 npm ,收藏在這了。 1、安裝 現在 npm ...
  • 前端(轉換): var param = XXXXXXXXXXXXXXXXXX; param = decodeURIComponent(param,true); param = encodeURI(param, "UTF-8"); $.post('<%=request.getContextPath() ...
  • 這篇博文有關css的權重問題,我個人認為這是css知識中很重要的一個知識點。因為在開發的過程能中我們會經常遇到這種問題,特別是如果你使用框架的時候,有些框架的某些標簽有一些預設的樣式。所以我們可以通過增加權重的方式來使我們所寫的樣式有效。既然說到權重那就必然要說起權重的等級以及權重值。 css的權重 ...
  • 1、jQuery基礎 Jquery它是一個庫(框架),要想使用它,必須先引入! jquery-1.8.3.js:一般用於學習階段。 jquery-1.8.3.min.js:用於項目使用階段 官網下載後,複製到當前WEB項目的js文件夾下,如下: 引入代碼:<script type="text/jav ...
  • [1]圖形變換 [2]矩陣變換 [3]全局陰影 [4]全局透明 [5]圖形合成 [6]裁剪區域 [7]圖像繪製 [8]使用圖像數據 [9]模式 [10]非零環繞 [11]交互 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...