您好,登錄后才能下訂單哦!
這篇文章主要介紹“php中tcp粘包和拆包實例介紹”,在日常操作中,相信很多人在php中tcp粘包和拆包實例介紹問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”php中tcp粘包和拆包實例介紹”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
tcp
長鏈接模式下,使用固定消息頭長度的方式進行消息 拆包
,解決 粘包
問題。
將消息頭的前N個字節固定為 消息長度位
,結合業務場景, 2bytes
或 4bytes
,讀取消息時先讀取 消息長度位
,即可按具體的 消息長度
讀取 消息內容
。
pack/unpack
可以 打包數值至二進制
/ 解包二進制至數值
,具體的模式可以參考pack/unpack 詳細用法,這里我們選用固定頭長度為 2bytes
來表示 消息體長度
,最大能表示 2^16 - 1
長度的消息體,不夠你就上 4bytes
好了。
<?php // msg protocol // | ---- dataLen ---- | data | // | - fixed 2bytes - | // 模擬客戶端連續發送2條消息 $foo = "hello world"; $bar = "i am sqrt_cat"; $package = ""; // 使用 n 打包 固定2bytes $fooLenn = pack("n", strlen($foo)); $package = $fooLenn . $foo; $barLenn = pack("n", strlen($bar)); $package .= $barLenn . $bar;
// send // 傳輸 $package 由 $foo $bar 兩條消息組成 模擬粘包場景 // receive
<?php // 解析第1條消息 取前 2bytes 按 n 解包 $fooLen = unpack("n", substr($package, 0, 2))[1]; // 使用包消息體長度定義讀取消息體 // 從第 3byte 開始讀 前 2bytes表示長度 $foo = substr($package, 2, $fooLen); echo $foo . PHP_EOL; // 解析第2條消息 取前 2bytes 按 n 解包 // 0 ~ (2 + fooLen) - 1 字節序為 fooLen . foo // (2 + fooLen) ~ (2 + fooLen) + 2 - 1 為 barLen $barLen = unpack("n", substr($package, (2 + $fooLen), 2))[1]; $bar = substr($package, (2 + $fooLen) + 2, $barLen); echo $bar . PHP_EOL;
日常工作中經常遇到的 tcp
場景可能是 短連接單個消息
的模式,客戶端發送一條消息后便關閉連接,服務端循環讀取到 EOF
即可得到一條完整的消息。但如果是 短連接多個消息
或 長鏈接模式
下,就可能會發生粘包,客戶端不關閉服務端無法通過 EOL
確定消息讀取完畢的問題。這就需要定義協議和拆包。
到此,關于“php中tcp粘包和拆包實例介紹”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。