《電子技術應用》
您所在的位置:首頁 > 其他 > 業(yè)界動態(tài) > S7Comm-Plus協(xié)議分析之數(shù)據(jù)區(qū)訪問

S7Comm-Plus協(xié)議分析之數(shù)據(jù)區(qū)訪問

2021-04-22
來源: 關鍵基礎設施安全應急響應中心

  概述:西門子PLC使用私有協(xié)議進行通信,端口為102。西門子PLC協(xié)議有3個版本,S7Comm協(xié)議,早期S7CommPlus協(xié)議和最新的S7CommPlus協(xié)議。S7-200、S7-300、S7-400系列的PLC采用早期的西門子私有協(xié)議S7comm進行通信,S7-1200系列v3.0版本之前的通信協(xié)議采用早期S7Comm-Plus協(xié)議,S7-1200系列v4.0版本、S7-1500系列采用了最新的S7Comm-Plus協(xié)議,最新的S7Comm-Plus協(xié)議引入了會話ID來防止重放攻擊,且對關鍵流量有加密處理,該部分的內容從2017年以來就有多名研究員進行了闡述,網(wǎng)絡上相關的文章也比較多。但對S7Comm-Plus協(xié)議在工控環(huán)境下使用最多的業(yè)務流量分析較為缺乏,本文以工控常見業(yè)務場景為例,分析Wincc V7.4作為上位機對PLC數(shù)據(jù)區(qū)的訪問操作,現(xiàn)實場景中工控流量占比最大的也是上位機的SCADA環(huán)境對下位機PLC數(shù)據(jù)區(qū)的一些讀寫操作,而非組態(tài)軟件對PLC的啟停、下裝上載操作,只有在調試運維過程中才會使用組態(tài)軟件。

  1

  環(huán)境配置

  整個協(xié)議分析的基本環(huán)境配置如下:Win7 x64虛擬機:

  PLC:S7-1200,6ES7214-1AG40-0XB0

  Firmware: V4.2.3

  Software:Wincc V7.4

  S7Comm-Plus Wiresharkdissector plugin: V0.0.8

  配置環(huán)境搭建的框架圖如下所示,通過交換機連接SCADA上位機與S7-1214C的PLC,wireshark安裝在連接鏡像端口的PC機中,wireshark中導入S7Comm-Plus的解析插件。

  微信圖片_20210422160729.jpg

  2

  對數(shù)據(jù)區(qū)的讀變量操作

  本文所述的數(shù)據(jù)區(qū)特指S7系列PLC中的DB塊、M區(qū)(I區(qū)、Q區(qū)與M區(qū)類似)。Wincc對PLC的讀變量操作,首先需要組態(tài)Wincc V7.4在畫面中建立輸出控件,關聯(lián)上PLC的對應地址變量,運行系統(tǒng)后在控件中就可讀取對應變量的值,如下所示:

 微信圖片_20210422160744.jpg

  組態(tài)讀取MD92地址處的變量值,讀取變量的操作碼Opcode為0X31,F(xiàn)unction為CreateObject(0x04ca),尋找第7個Attribute屬性中ID Number字段SubscriptionReferenceList。

 微信圖片_20210422160758.jpg

  展開SubscriptionReferenceList的詳細描述,在SubscriptionList下包含了具體的訪問區(qū)域與詳細地址信息,Accessbase-area區(qū)域顯示M區(qū)(0x52),Blob startoffset為92,表示M區(qū)中的訪問地址,讀取字節(jié)數(shù)Blob bytecount為2,表示讀取兩個字節(jié)長度。

  微信圖片_20210422160811.jpg

  組態(tài)讀取DB59999.DBW6地址處的變量值(wincc對于DB塊進行讀取操作必須不加入優(yōu)化,DB塊中的變量必須有確定分配的地址),讀取變量的操作碼Opcode為0X31,F(xiàn)unction為CreateObject(0x04ca),尋找第7個Attribute屬性中ID Number字段SubscriptionReferenceList。

微信圖片_20210422160827.jpg  

  展開SubscriptionReferenceList的詳細描述,在SubscriptionList下包含了具體的訪問區(qū)域與詳細地址信息,Accessbase-areaa區(qū)域經(jīng)過算法解析后得到0x8a0eea5f,表示DB59999(原始數(shù)據(jù)幀中字節(jié)為0x88 d0 bb d4 5f),Blob startoffset為6,表示DB5999中的訪問地址,讀取字節(jié)數(shù)Blob bytecount為2,表示讀取兩個字節(jié)長度。

  微信圖片_20210422160859.jpg

  備注:VLQ相關編碼算法可參考S7Comm-plus wireshark插件的源碼,源碼地址https://sourceforge.net/p/s7commwireshark/code/HEAD/tree/trunk/src/

  3

  對數(shù)據(jù)區(qū)的寫變量操作

  Wincc對PLC的寫值操作一般會在畫面中建立輸入控件,關聯(lián)上PLC的對應地址變量,在控件中寫值,按enter鍵后寫入成功,如下所示:

  微信圖片_20210422160916.jpg

  在MD92寫入變量過程中抓取到請求數(shù)據(jù)幀

 微信圖片_20210422160930.jpg

  寫入變量的操作碼Opcode為0X31,F(xiàn)unction為SetMultiVariables(0x0542),Access base-areaa字段顯示為M區(qū)(0x52),寫入地址Blob startoffset為92,寫入字節(jié)數(shù)Blob bytecount為4,寫入的值為value:0x0001046a。

  微信圖片_20210422160938.jpg

  在DB59999.DBW6地址處寫入變量過程中抓取到請求數(shù)據(jù)幀,(Wincc寫DB塊必須保證DB塊不優(yōu)化,有自己的實際地址)

 微信圖片_20210422160950.jpg

  寫入變量的操作碼Opcode為0X31,F(xiàn)unction為SetMultiVariables(0x0542),Access base-areaa字段顯示為DB59999(0x8a0eea5f),寫入地址Blob startoffset為6,寫入字節(jié)數(shù)Blob bytecount為2,寫入的值為value:0x8235。

  微信圖片_20210422160959.jpg

  4

  流量中關鍵點提取

  從以上的分析中可以總結如下表格,不論是工業(yè)防火墻還是審計系統(tǒng),均需要將關鍵字段識別并加入至白名單中,在S7Comm-plus協(xié)議的流量中,識別表格中的關鍵信息就能命中各種業(yè)務操作,比如讀M區(qū)變量、寫Q區(qū)變量等。但是想和實際工藝場景結合,比如命中流量中對污水處理加藥間加藥量閥門的操作需要做進一步的工作。

 微信截圖_20210422161017.png

  5

  總結

  本文以Wincc V7.4作為上位機,調用S7Comm-plus的驅動訪問S7-1200系列PLC,具體訪問了PLC的DB塊、M區(qū)等,在訪問過程中通過wireshark抓取對應報文,并做了簡單分析,并通過表格形式總結出S7Comm-plus訪問西門子系列PLC常用數(shù)據(jù)區(qū)的關鍵字段,在工業(yè)安全產(chǎn)品中要解析或者捕獲流量是需要命中這些字段,通過這些字段關聯(lián)到對應的操作區(qū)域。但如果想再次區(qū)分流量中對M區(qū)的哪個地址寫入了什么數(shù)據(jù)還需要深入解析后續(xù)的value字段。如若需要和工藝流程聯(lián)動,還需要將工程點表和安全產(chǎn)品中的命中規(guī)則聯(lián)動和融合,這樣才能更接近工業(yè)現(xiàn)場。


本站內容除特別聲明的原創(chuàng)文章之外,轉載內容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創(chuàng)文章及圖片等內容無法一一聯(lián)系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經(jīng)濟損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
主站蜘蛛池模板: 欧美国产日韩911在线观看| 精品无码一区二区三区爱欲九九 | 老司机午夜视频在线观看| 国产日产欧洲无码视频| 97久人人做人人妻人人玩精品| 好男人资源在线观看好| 中文字幕影片免费在线观看| 日韩一区精品视频一区二区| 国产大片91精品免费观看男同| 69国产精品视频免费| 天天操天天摸天天射| 一级毛片免费不卡直观看| 搡女人真爽免费视频大全软件| 久久国产精品久久久久久| 最新69堂国产成人精品视频| 亚洲婷婷第一狠人综合精品| 波多野结衣电影免费在线观看 | 99ee6热久久免费精品6| 天天躁夜夜踩狠狠踩2022| 一边摸一边爽一边叫床免费视频| 拨牐拨牐x8免费| 久久久久88色偷偷| 日本免费精品视频| 久久婷婷丁香五月综合五| 日韩精品无码免费一区二区三区| 亚洲一区二区免费视频| 欧美人与动欧交视频| 亚洲国产精品一区二区久久| 欧美日韩乱国产| 亚洲欧美日韩一区在线观看| 沉伦柳淑云漫画3d| 亚洲精品视频网| 波多野结衣久久| 亚洲精品欧美综合| 波多野结衣未删减在线| 亚洲网站在线播放| 激情射精爆插热吻无码视频| 人人妻人人澡人人爽超污| 特级按摩一级毛片| 亚洲精品理论电影在线观看| 波多野结衣午夜|