《電子技術應用》
您所在的位置:首頁 > 其他 > 業界動態 > S7Comm-Plus協議分析之數據區訪問

S7Comm-Plus協議分析之數據區訪問

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

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

  1

  環境配置

  整個協議分析的基本環境配置如下:Win7 x64虛擬機:

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

  Firmware: V4.2.3

  Software:Wincc V7.4

  S7Comm-Plus Wiresharkdissector plugin: V0.0.8

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

  微信圖片_20210422160729.jpg

  2

  對數據區的讀變量操作

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

 微信圖片_20210422160744.jpg

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

 微信圖片_20210422160758.jpg

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

  微信圖片_20210422160811.jpg

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

微信圖片_20210422160827.jpg  

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

  微信圖片_20210422160859.jpg

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

  3

  對數據區的寫變量操作

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

  微信圖片_20210422160916.jpg

  在MD92寫入變量過程中抓取到請求數據幀

 微信圖片_20210422160930.jpg

  寫入變量的操作碼Opcode為0X31,Function為SetMultiVariables(0x0542),Access base-areaa字段顯示為M區(0x52),寫入地址Blob startoffset為92,寫入字節數Blob bytecount為4,寫入的值為value:0x0001046a。

  微信圖片_20210422160938.jpg

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

 微信圖片_20210422160950.jpg

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

  微信圖片_20210422160959.jpg

  4

  流量中關鍵點提取

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

 微信截圖_20210422161017.png

  5

  總結

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


本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
玖玖玖国产精品| 国产美女精品视频| 欧美亚洲一区在线| 亚洲视频中文| 一本久道久久综合婷婷鲸鱼| 亚洲日本在线视频观看| 亚洲第一视频| 亚洲电影自拍| 亚洲第一黄色| 亚洲国产精品美女| 亚洲福利视频免费观看| 欧美中文在线观看国产| 久久av红桃一区二区小说| 欧美一区二粉嫩精品国产一线天| 亚洲综合电影| 亚洲欧美色婷婷| 午夜精品理论片| 欧美一区二区三区啪啪| 欧美一区二区| 亚洲国产精品va在线看黑人| 久久精品青青大伊人av| 久久精品一区二区三区中文字幕| 久久狠狠久久综合桃花| 亚洲电影欧美电影有声小说| 亚洲电影免费观看高清完整版在线 | 亚洲欧洲精品一区二区三区波多野1战4| 精品88久久久久88久久久| 亚洲高清视频一区二区| 亚洲日本成人| 正在播放日韩| 性欧美1819sex性高清| 久久精品国产综合精品| 亚洲人成网在线播放| 一区二区久久久久久| 亚洲欧美乱综合| 久久久久久亚洲精品不卡4k岛国| 美女精品在线观看| 欧美日韩亚洲成人| 国产毛片一区| 亚洲国产成人av| 一区二区精品国产| 亚欧成人在线| 亚洲精品一区二区在线观看| 亚洲网友自拍| 久久精彩视频| 欧美精品色综合| 国产精品视频网址| 黄色工厂这里只有精品| 亚洲美女av在线播放| 亚洲欧美日韩高清| 亚洲啪啪91| 午夜视频在线观看一区二区三区| 久久免费99精品久久久久久| 欧美区一区二区三区| 国产精品色一区二区三区| 伊人久久综合| 亚洲香蕉伊综合在人在线视看| 久久精品道一区二区三区| 一区二区三区毛片| 久久久久久久久久看片| 欧美日本精品一区二区三区| 国产美女高潮久久白浆| 亚洲精品免费在线| 久久国产88| 亚洲自拍偷拍视频| 玖玖玖国产精品| 国产精品久久久一区二区| 亚洲大胆视频| 香蕉久久夜色精品| 一片黄亚洲嫩模| 另类av一区二区| 国产精品夜色7777狼人 | 亚洲人成在线观看一区二区| 亚洲男人第一网站| 99一区二区| 久久夜色精品国产亚洲aⅴ| 国产精品草草| 亚洲精品1234| 久久国产一区二区三区| 亚洲一本视频| 欧美国产视频一区二区| 国产亚洲成av人在线观看导航| 日韩一级大片| 亚洲欧洲另类| 久久久久久久网| 国产精品区二区三区日本| 亚洲经典视频在线观看| 久久国产欧美| 欧美一区二区三区另类| 欧美日韩一区二区在线观看 | 亚洲黄色影院| 久久国产精品一区二区三区四区| 欧美日在线观看| 亚洲国产日韩欧美在线动漫| 欧美一区二区三区另类| 香蕉久久夜色精品| 欧美日韩一区二区三区| 亚洲激情电影在线| 亚洲激情视频在线| 噜噜噜91成人网| 国际精品欧美精品| 欧美亚洲一区二区三区| 亚洲欧美日韩天堂| 欧美三级视频| 亚洲精品在线二区| 亚洲看片网站| 男女激情久久| 在线国产欧美| 91久久久久久久久久久久久| 久久综合综合久久综合| 国语自产精品视频在线看一大j8| 亚洲综合国产| 欧美亚洲一区二区在线观看| 国产精品亚洲美女av网站| 亚洲一区二区在线| 亚洲欧美日韩一区在线| 国产精品久久久久久影视| 中文精品视频一区二区在线观看| 9久草视频在线视频精品| 欧美伦理91| 99精品欧美| 亚洲——在线| 国产精品久久久爽爽爽麻豆色哟哟| 一区二区高清| 午夜国产不卡在线观看视频| 国产精品乱码| 亚洲女同精品视频| 久久成人精品无人区| 国产色产综合产在线视频| 欧美一区二视频| 久久网站免费| 在线观看日韩av电影| 亚洲人体偷拍| 欧美精品一区二区精品网| 亚洲日本国产| 亚洲一区在线播放| 国产精品一二一区| 久久国产一区二区三区| 欧美成黄导航| 夜夜嗨av色一区二区不卡| 亚洲欧美日韩在线不卡| 国产日韩在线一区二区三区| 久久国产一二区| 欧美激情综合五月色丁香小说| 日韩视频中文| 欧美一级播放| 在线观看一区视频| 99精品免费| 国产精品毛片在线| 欧美在线3区| 欧美激情亚洲国产| 一区二区三区日韩| 久久九九精品| 亚洲国产日韩欧美在线图片| 亚洲一区二区三区激情| 国产日韩欧美在线一区| 亚洲国产精品t66y| 欧美日韩一区视频| 欧美一区二区成人6969| 欧美成人69| 亚洲在线播放| 欧美freesex交免费视频| 艳女tv在线观看国产一区| 久久精品综合| 日韩亚洲欧美一区| 久久精品午夜| 亚洲伦伦在线| 久久精品伊人| 一二三区精品| 久久亚洲二区| 一区二区三区久久久| 久久影院午夜片一区| av成人免费| 免费在线欧美黄色| 亚洲欧美春色| 欧美老女人xx| 欧美伊人久久| 欧美色图五月天| 久久激情视频久久| 欧美调教vk| 91久久久久久| 国产欧美一区二区三区在线看蜜臀| 亚洲免费观看| 韩国精品在线观看| 亚洲一区二区三区在线| 一区二区三区在线视频播放| 亚洲欧美激情一区| 91久久久一线二线三线品牌| 久久av老司机精品网站导航| 亚洲精品偷拍| 久久久久综合| 亚洲一本视频| 欧美了一区在线观看| 亚洲国产精品一区二区尤物区 | 国产欧美日韩亚州综合| 99热免费精品| 一区二区三区在线视频免费观看| 午夜久久久久久| 日韩午夜激情av| 欧美成人午夜免费视在线看片|