在上篇文章中,我們?cè)赑SNet包中創(chuàng)建了Test-TCPPort函數(shù)用于探測(cè)指定IP的指定端口是否開放,檢測(cè)端口之后大多數(shù)人想到的可能就是需要通過PowerShell收發(fā)TCP消息包了,這篇文章里將會(huì)描述如何在PSNet包中創(chuàng)建針對(duì)TCP消息包的函數(shù)Receive-和TCPMessageSend-TCPMessage。為了承接上篇中我們創(chuàng)建的PSNet工具集的思路,在確定了函數(shù)的命名之后,創(chuàng)建上述兩個(gè)函數(shù)對(duì)應(yīng)的.ps1文件放置在$env:PSSpace/PSNet/TCPOp/中。
接下來(lái)在$env:PSSpace/PSNet/PSNet.psm1中添加以下兩條語(yǔ)句用于在工具集中引入上述兩個(gè)函數(shù)文件:
復(fù)制代碼 代碼如下:
. $env:PSSpace/PSNet/TCPOp/Receive-TCPMessage.ps1
. $env:PSSpace/PSNet/TCPOp/Send-TCPMessage.ps1
然后分別在創(chuàng)建的.ps1文件中添加以下代碼:
復(fù)制代碼 代碼如下:
=====文件名:Receive-TCPMessage.ps1=====
Function Receive-TCPMessage
{
param ( [ValidateNotNullOrEmpty()]
[int] $Port )
try
{
$EndPoint = New-Object System.Net.IPEndPoint([System.Net.IPAddress]::Loopback,$Port)
$Socket = New-Object System.Net.Sockets.TCPListener($EndPoint)
$Socket.Start()
$Socket = $Socket.AcceptTCPClient()
$EncodedText = New-Object System.Text.ASCIIEncoding
$Stream = $Socket.GetStream()
$Buffer = New-Object System.Byte[] $Socket.ReceiveBufferSize
while( $Bytes = $Stream.Read($Buffer,0,$Buffer.Length) )
{
$Stream.Write($Buffer,0,$Bytes)
Write-Output $EncodedText.GetString($Buffer,0,$Bytes)
}
$Socket.Close()
$Socket.Stop()
}
catch{}
}
復(fù)制代碼 代碼如下:
=====文件名:Send-TCPMessage.ps1=====
Function Send-TCPMessage
{
param ( [ValidateNotNullOrEmpty()]
[string] $EndPoint,
[int] $Port,
[string] $Message )
$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()
}
將代碼保存到指定目錄的對(duì)應(yīng)文件后,分別啟動(dòng)兩個(gè)PowerShell進(jìn)程,分別導(dǎo)入PSNet Module:
復(fù)制代碼 代碼如下:
Import-Module $env:PSSpace\PSNet
或者在啟動(dòng)PowerShell時(shí)指定參數(shù),或者將下列語(yǔ)句創(chuàng)建批處理腳本啟動(dòng)加載指定Module的PowerShell進(jìn)程。
復(fù)制代碼 代碼如下:
start %windir%\System32\WindowsPowerShell\v1.0\powershell.exe -noExit -Command "Import-Module ‘%PSSpace%\PSNet' "
首先在其中一個(gè)PowerShell窗口中,指定端口用Receive-TCPMessage函數(shù)在制定端口監(jiān)聽,等待接受數(shù)據(jù)
復(fù)制代碼 代碼如下:
Receive-TCPMessage 8080
在另外一個(gè)窗口中向上面的端口發(fā)送數(shù)據(jù):
復(fù)制代碼 代碼如下:
Send-TCPMessage 127.0.0.1 8080 “This a Message Send from PSNet!”
會(huì)發(fā)現(xiàn)這個(gè)進(jìn)程發(fā)送消息后,前一個(gè)進(jìn)程能收到相應(yīng)的消息,消息中如果有空格需要用雙引號(hào)包括確保PowerShell解釋引擎知道這是一個(gè)完整的參數(shù)。這兩個(gè)小函數(shù)雖然功能簡(jiǎn)單,而且其中的消息使用ASCII的方式發(fā)送的,這是為了給大家演示發(fā)送和接收的效果,在真正的實(shí)際環(huán)境中還是有問題的,但是這兩個(gè)函數(shù)將會(huì)在后續(xù)的功能中起到很重要的作用,使用PowerShell發(fā)送TCP和接收TCP報(bào)文將會(huì)用到,也將會(huì)在后續(xù)的文章中進(jìn)行改進(jìn)。
您可能感興趣的文章:- PowerShell小技巧之發(fā)送TCP請(qǐng)求
- PowerShell小技巧之嘗試ssh登錄
- PowerShell腳本開發(fā)之收發(fā)UDP消息包
- PowerShell腳本開發(fā)嘗試登錄SQL Server
- PowerShell腳本開發(fā)之批量掃描IP和端口
- PowerShell腳本開發(fā)之嘗試登錄ftp