0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

分享一種西門子PLC的網絡仿真器搭建方法

工程師鄧生 ? 來源:FreeBuf ? 作者:thx0405 ? 2022-09-08 17:29 ? 次閱讀

一、前言

在手上沒有真實的西門子PLC設備情況的情況下,PLC本地仿真器可以為我們進行開關量和簡單模擬量的程序仿真。但工控安全人員想在沒有真實PLC的條件下獲取S7通訊數(shù)據(jù)報文的時候,或者想測試第三方上位軟件與西門子PLC通訊的時候,這種本地的PLC仿真器就無法勝任了,本文分享一種西門子PLC的網絡仿真器搭建方法。

二、搭建方法

這里我們準備兩個虛擬機,操作系統(tǒng)都為win7 64位專業(yè)版:1、操作機(準備Snap7 Client Demo工具及組態(tài)王軟件,采用192.168.11.2IP地址)2、靶機(安裝了step7 v5.5及plcsim v5.4 sp5,采用192.168.11.1IP地址)。

在靶機中打開SIMATIC Manager軟件,新建項目test2,如下圖:

b4834e72-2f57-11ed-ba43-dac502259ad0.jpg

在新建項目test2點擊插入新對象,并選擇SIMATIC 300站點,如下圖:

b496d406-2f57-11ed-ba43-dac502259ad0.jpg

分別點擊SIMATIC300(1)>硬件,進入硬件配置界面,如下圖:

b4b22d5a-2f57-11ed-ba43-dac502259ad0.jpg

在HW Config界面下選擇SIMATIC 300,并選擇RACK-300下的Rail,如下圖:

b4d0fc1c-2f57-11ed-ba43-dac502259ad0.jpg

在UR(0)對話框中的序號槽1中點擊右鍵分別插入對象PS 307 2A,如下圖:

b4dd1998-2f57-11ed-ba43-dac502259ad0.jpg

在UR(0)對話框中的序號槽2中點擊右鍵分別插入對象CPU 314C-2PN/DP V3.3,,并新建子網設置ip地址為本PC級的IP地址,如下圖:

b4f0ebf8-2f57-11ed-ba43-dac502259ad0.jpg

啟動虛擬PLC,點擊開始>所有程序>Siemens Automation>SIMATIC>STEP 7>S7-PLCSIM,如下圖:

b50f4c56-2f57-11ed-ba43-dac502259ad0.jpg

進入S7-PLCSIM界面,選擇PLCSIM(TCP/IP),如下圖:

b51a47b4-2f57-11ed-ba43-dac502259ad0.jpg

回到HW Config對話框,選擇下載到模塊,如下圖:

b53678ee-2f57-11ed-ba43-dac502259ad0.jpg

b556d22e-2f57-11ed-ba43-dac502259ad0.jpg

待下載完成,PLCSIM會顯示PLC的地址為之前設置的IP地址,如下圖:

b56f579a-2f57-11ed-ba43-dac502259ad0.jpg

啟動NetToPLCSIM,點擊bin>NetToPLCSim.exe,進入如下圖:

b57e261c-2f57-11ed-ba43-dac502259ad0.jpg

點擊add,彈出station對話框,在Network IP Address及Plcsim IP Address中選擇IP地址為之前設置的ip地址,進入如下圖:

b5b113f6-2f57-11ed-ba43-dac502259ad0.jpg

點擊Start Server,PLC#001進入運行狀態(tài),表示PLC網絡仿真器搭建成功進入如下圖:

b5bd2628-2f57-11ed-ba43-dac502259ad0.jpg

三、攻擊測試

在操作機中打開Snap7 Client Demo工具,填寫仿真PLC的IP地址如:192.168.11.1,點擊Connect,如下圖:

b5d0bc38-2f57-11ed-ba43-dac502259ad0.jpg

再在control下點擊stop按鈕即停止PLC的命令,如下圖:

b5ec96f6-2f57-11ed-ba43-dac502259ad0.jpg

查看靶機中仿真PLC的狀態(tài)從run變?yōu)閟top,同時可以用wireshark抓取其數(shù)據(jù)流量如下圖:

b60614dc-2f57-11ed-ba43-dac502259ad0.jpg

b6197f22-2f57-11ed-ba43-dac502259ad0.jpg

b62bf83c-2f57-11ed-ba43-dac502259ad0.jpg

也可以在python中構建STOP包進行測試,如下圖:

b6401542-2f57-11ed-ba43-dac502259ad0.jpg

四、第三方上位軟件通訊測試

在靶機(192.168.11.1)的仿真PLC建立了這樣一段簡單圖形圖代碼,一個簡單的設備啟??刂七壿嫵绦颍?M0.0、%M0.1是指PLC的M類型的寄存器,0.0、0.1是M寄存器的某兩個偏移地址,對應中間變量。%Q0.0是PLC的Q類型的寄存器,0.0是Q寄存器的某個偏移地址。在這個控制程序中,%M0.0(變量名為start)對應是監(jiān)控畫面上的啟動按鈕,進行對設備的啟動操作,%M0.1(變量名為stop)對應是監(jiān)控畫面上的停止按鈕,進行對設備的停止操作。%Q0.0(變量名為out),對應PLC的輸出,即將控制信號輸出給設備。如下圖:

b657b86e-2f57-11ed-ba43-dac502259ad0.jpg

程序下載到仿真PLC后,對梯形圖代碼進行在線監(jiān)控,這時輸出為0,如下

b66d6722-2f57-11ed-ba43-dac502259ad0.jpg

在操作機(192.168.11.2)中定義仿真PLC的IP地址及寄存器的地址,如下圖:

b683107c-2f57-11ed-ba43-dac502259ad0.jpg

b694146c-2f57-11ed-ba43-dac502259ad0.jpg

定義監(jiān)控畫面如下:

b6a293c0-2f57-11ed-ba43-dac502259ad0.jpg

按下start按鈕,圓形顯示變?yōu)榫G色,證明我們按鈕發(fā)出的指令,仿真PLC收到啟動信號,將輸出置為1,并將仿真PLC輸出的結果反饋到監(jiān)控畫面,同時我們監(jiān)控靶機中仿真PLC的程序,我們發(fā)現(xiàn)仿真PLC輸出也是為1,證明操作機中組態(tài)王上位機與靶機中的虛擬機通訊成功,如下圖

b6b3440e-2f57-11ed-ba43-dac502259ad0.jpg

b6c89098-2f57-11ed-ba43-dac502259ad0.jpg

同時我們可以獲取操作機的組態(tài)王(192。168.11.2)與靶機PLC仿真器(192168.11.1)的通訊報文,各類功能碼的數(shù)據(jù)報文,根據(jù)具體的操作。

b6d79f48-2f57-11ed-ba43-dac502259ad0.jpg

五、總結

本文通過研究西門子PLC的網絡仿真搭建方法,為工控安全人員研究西門子s7協(xié)議提供一個便捷、實惠的渠道,無需花費大量的資金采購真實的PLC設備,同時也可為PLC工程師提供一種測試第三方上位軟件與西門子通訊的方法,更為重要的是,這種西門子PLC的網絡仿真搭建方法,可以勝任多人在局域網絡中對西門子PLC的安全研究工作(例如實訓平臺),只需啟動更多的靶機和操作機即可。




審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • plc
    plc
    +關注

    關注

    5015

    文章

    13355

    瀏覽量

    464578
  • 仿真器
    +關注

    關注

    14

    文章

    1019

    瀏覽量

    83859
  • 虛擬機
    +關注

    關注

    1

    文章

    919

    瀏覽量

    28334

原文標題:西門子PLC的網絡仿真搭建方法探討

文章出處:【微信號:西北工匠PLC學習基地,微信公眾號:西北工匠PLC學習基地】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    西門子plc200編程實例詳解

    西門子PLC S7-200是款廣泛應用于工業(yè)自動化領域的可編程邏輯控制,其強大的功能和靈活的編程方式使得它能夠滿足各種復雜的控制需求。
    的頭像 發(fā)表于 10-22 14:38 ?890次閱讀

    西門子PLC的復位操作

    西門子PLC(Programmable Logic Controller,可編程邏輯控制)是一種廣泛應用于工業(yè)自動化領域的控制設備。在實際應用過程中,有時需要對
    的頭像 發(fā)表于 08-16 17:46 ?3752次閱讀

    西門子plc溫度模塊怎么編程

    )是一種廣泛應用于工業(yè)自動化領域的控制。溫度模塊是PLC系統(tǒng)中用于測量和控制溫度的設備,可以實時監(jiān)測和調節(jié)溫度,保證生產過程的穩(wěn)定性和安全性。 二、硬件選擇 選擇合適的PLC型號
    的頭像 發(fā)表于 07-25 09:43 ?1603次閱讀

    西門子PLC與NPN、PNP傳感接線方式,超全講解!

    特點 西門子PLC一種廣泛應用于工業(yè)自動化控制的設備,具有以下特點: 1.穩(wěn)定性高:西門子PLC采用先進的微處理
    的頭像 發(fā)表于 07-12 14:43 ?937次閱讀
    <b class='flag-5'>西門子</b><b class='flag-5'>PLC</b>與NPN、PNP傳感<b class='flag-5'>器</b>接線方式,超全講解!

    西門子PLC開放式TCP通信原理

    隨著工業(yè)自動化技術的不斷發(fā)展,西門子PLC(可編程邏輯控制)作為工業(yè)自動化領域的核心設備,其通信功能日益受到重視。開放式TCP通信作為西門子PLC
    的頭像 發(fā)表于 06-19 16:00 ?2084次閱讀

    西門子PLC與ABB變頻通訊怎么實現(xiàn)

    在現(xiàn)代工業(yè)自動化領域中,西門子PLC(Programmable Logic Controller,可編程邏輯控制)與ABB變頻之間的通訊是實現(xiàn)高效、穩(wěn)定控制的關鍵環(huán)節(jié)。
    的頭像 發(fā)表于 06-19 15:29 ?3389次閱讀

    西門子PLC與IO模塊如何通訊

    在現(xiàn)代工業(yè)自動化控制系統(tǒng)中,西門子PLC(Programmable Logic Controller)以其卓越的性能和穩(wěn)定性贏得了廣泛應用。而在西門子PLC系統(tǒng)中,IO模塊(Input
    的頭像 發(fā)表于 06-19 10:46 ?2140次閱讀

    西門子PLC中OB塊的功能詳解

    西門子PLC(Programmable Logic Controller)作為工業(yè)自動化領域的核心設備,其內部功能強大、應用廣泛。在西門子PLC中,OB塊(Organization B
    的頭像 發(fā)表于 06-15 11:27 ?5097次閱讀

    西門子PLC的作用和工作原理

    在工業(yè)自動化領域中,可編程邏輯控制(Programmable Logic Controller,簡稱PLC)扮演著至關重要的角色。西門子PLC,作為
    的頭像 發(fā)表于 06-15 11:26 ?2431次閱讀

    西門子PLC的發(fā)展歷史

    西門子,作為全球知名的工業(yè)自動化和數(shù)字化企業(yè),其PLC(可編程邏輯控制)產品的發(fā)展歷程是工業(yè)自動化領域的重要篇章。從早期的二進制控制到如今的智能化、
    的頭像 發(fā)表于 06-15 11:26 ?2126次閱讀

    西門子PLC與伺服控制如何通訊

    在工業(yè)自動化領域中,西門子PLC(Programmable Logic Controller,可編程邏輯控制)與伺服控制之間的通訊是實現(xiàn)高效、精確控制的關鍵環(huán)節(jié)。本文旨在詳細闡述
    的頭像 發(fā)表于 06-14 15:49 ?2543次閱讀

    西門子PLC總線故障怎么解決

    在工業(yè)自動化領域,西門子PLC(Programmable Logic Controller,可編程邏輯控制)以其高可靠性、強穩(wěn)定性和豐富的功能而備受青睞。然而,在實際應用中,PLC
    的頭像 發(fā)表于 06-13 18:18 ?2534次閱讀

    工業(yè)智能網關通過串口/網口實現(xiàn)西門子PLC實時通信

    在工業(yè)物聯(lián)網場景中,西門子PLC是常見的生產設備,常常作為下位機,實現(xiàn)與組態(tài)上位機的實時通信,主要分為兩通信方式,一種是以太網通信,一種
    的頭像 發(fā)表于 06-13 10:46 ?593次閱讀
    工業(yè)智能網關通過串口/網口實現(xiàn)<b class='flag-5'>西門子</b><b class='flag-5'>PLC</b>實時通信

    西門子plc的多軸控制能力介紹

    西門子PLC(Programmable Logic Controller,可編程邏輯控制)是一種廣泛應用于工業(yè)自動化領域的控制設備。它可以根據(jù)不同的控制需求,實現(xiàn)對各種機械設備的精確
    的頭像 發(fā)表于 06-12 11:14 ?1376次閱讀

    西門子plc模塊型號詳解

    西門子PLC(Programmable Logic Controller,可編程邏輯控制)是工業(yè)自動化領域中非常重要的一種設備,其模塊化的設計使得其應用范圍非常廣泛。本文將詳細介紹
    的頭像 發(fā)表于 06-11 16:18 ?6382次閱讀