在上篇文章中,我們在PSNet包中創建了Test-TCPPort函數用于探測指定IP的指定端口是否開放,檢測端口之后大多數人想到的可能就是需要通過PowerShell收發TCP消息包了,這篇文章里將會描述如何在PSNet包中創建針對TCP消息包的函數Receive-和TCPMessageSend-TCPMessage。為了承接上篇中我們創建的PSNet工具集的思路,在確定了函數的命名之后,創建上述兩個函數對應的.ps1文件放置在$env:PSSpace/PSNet/TCPOp/中。
接下來在$env:PSSpace/PSNet/PSNet.psm1中添加以下兩條語句用于在工具集中引入上述兩個函數文件:
然后分別在創建的.ps1文件中添加以下代碼:
$IP = [System.Net.Dns]::GetHostAddresses($EndPoint)
$Address = [System.Net.IPAddress]::Parse($IP)
$Socket = New-Object System.Net.Sockets.TCPClient($Address,$Port)
$Stream = $Socket.GetStream()
$Writer = New-Object System.IO.StreamWriter($Stream)
$Writer.AutoFlush = $true
$Writer.NewLine = $true
$Writer.Write($Message)
$Socket.Close()
}
將代碼保存到指定目錄的對應文件后,分別啟動兩個PowerShell進程,分別導入PSNet Module:
或者在啟動PowerShell時指定參數,或者將下列語句創建批處理腳本啟動加載指定Module的PowerShell進程。
首先在其中一個PowerShell窗口中,指定端口用Receive-TCPMessage函數在制定端口監聽,等待接受數據
在另外一個窗口中向上面的端口發送數據:
會發現這個進程發送消息后,前一個進程能收到相應的消息,消息中如果有空格需要用雙引號包括確保PowerShell解釋引擎知道這是一個完整的參數。這兩個小函數雖然功能簡單,而且其中的消息使用ASCII的方式發送的,這是為了給大家演示發送和接收的效果,在真正的實際環境中還是有問題的,但是這兩個函數將會在后續的功能中起到很重要的作用,使用PowerShell發送TCP和接收TCP報文將會用到,也將會在后續的文章中進行改進。
新聞熱點
疑難解答
圖片精選