当前位置: 首页 > 编程笔记 >

PowerShell脚本开发之收发TCP消息包

陈斌
2023-03-14
本文向大家介绍PowerShell脚本开发之收发TCP消息包,包括了PowerShell脚本开发之收发TCP消息包的使用技巧和注意事项,需要的朋友参考一下

在上篇文章中,我们在PSNet包中创建了Test-TCPPort函数用于探测指定IP的指定端口是否开放,检测端口之后大多数人想到的可能就是需要通过PowerShell收发TCP消息包了,这篇文章里将会描述如何在PSNet包中创建针对TCP消息包的函数Receive-和TCPMessageSend-TCPMessage。为了承接上篇中我们创建的PSNet工具集的思路,在确定了函数的命名之后,创建上述两个函数对应的.ps1文件放置在$env:PSSpace/PSNet/TCPOp/中。

接下来在$env:PSSpace/PSNet/PSNet.psm1中添加以下两条语句用于在工具集中引入上述两个函数文件:


. $env:PSSpace/PSNet/TCPOp/Receive-TCPMessage.ps1 

. $env:PSSpace/PSNet/TCPOp/Send-TCPMessage.ps1

然后分别在创建的.ps1文件中添加以下代码:


 =====文件名: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{}

}


        =====文件名: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() }

将代码保存到指定目录的对应文件后,分别启动两个PowerShell进程,分别导入PSNet Module:


Import-Module $env:PSSpace\PSNet

或者在启动PowerShell时指定参数,或者将下列语句创建批处理脚本启动加载指定Module的PowerShell进程。


start %windir%\System32\WindowsPowerShell\v1.0\powershell.exe -noExit -Command "Import-Module ‘%PSSpace%\PSNet' "

首先在其中一个PowerShell窗口中,指定端口用Receive-TCPMessage函数在制定端口监听,等待接受数据


Receive-TCPMessage 8080

在另外一个窗口中向上面的端口发送数据:


Send-TCPMessage 127.0.0.1 8080 “This a Message Send from PSNet!”

会发现这个进程发送消息后,前一个进程能收到相应的消息,消息中如果有空格需要用双引号包括确保PowerShell解释引擎知道这是一个完整的参数。这两个小函数虽然功能简单,而且其中的消息使用ASCII的方式发送的,这是为了给大家演示发送和接收的效果,在真正的实际环境中还是有问题的,但是这两个函数将会在后续的功能中起到很重要的作用,使用PowerShell发送TCP和接收TCP报文将会用到,也将会在后续的文章中进行改进。

 类似资料:
  • 本文向大家介绍PowerShell脚本开发之收发UDP消息包,包括了PowerShell脚本开发之收发UDP消息包的使用技巧和注意事项,需要的朋友参考一下 在上篇文章中,在PSNet工具集中创建了Send-TCPMessage和Receive-TCPMessage两个函数实现了通过PowerShell收发TCP消息包的功能,有了TCP包的发送和接收,自然少不了UDP消息包的发送和接收,本文将会介绍

  • 本文向大家介绍PowerShell脚本开发之尝试登录ftp,包括了PowerShell脚本开发之尝试登录ftp的使用技巧和注意事项,需要的朋友参考一下 上一篇文章介绍了通过PowerShell批量扫描IP段和端口,在PSNet程序集中添加了Invoke-ScanIPPort函数,这里尽管扫描到了指定IP端中监听的端口,但是未对端口和相应的程序进行对应,正如我们所知一些常用的应用程序使用的默认端口是

  • 本文向大家介绍C#微信开发之接收 / 返回文本消息,包括了C#微信开发之接收 / 返回文本消息的使用技巧和注意事项,需要的朋友参考一下 接收 / 返回文本消息 ①接收/返回文本消息原理说明 当普通微信用户向公众账号发消息时,微信服务器将POST消息的XML数据包到开发者填写的URL上,着手开发之前先行阅读微信公众平台接收普通消息微信开发文档,对微信的这种消息处理机制有一定了解之后再着手开发(微信开

  • 本文向大家介绍PowerShell脚本开发之批量扫描IP和端口,包括了PowerShell脚本开发之批量扫描IP和端口的使用技巧和注意事项,需要的朋友参考一下 前面的文章中曾经发布了对指定IP进行批量端口扫描的方法和脚本,过PowerShell收发TCP和UDP消息包的方法以及通过PowerShell尝试登录SQLServer服务的方法,这构成了PSNet程序集用于通过PowerShell对网络状

  • 本文向大家介绍PowerShell脚本开发尝试登录SQL Server,包括了PowerShell脚本开发尝试登录SQL Server的使用技巧和注意事项,需要的朋友参考一下 前三篇文章中创建了PSNet程序集,其中包含了对指定IP进行端口扫描,收发TCP消息包和收发UDP消息包的相关功能,作为这是最基本的对网络情况的最基本检测,后续的文章将会对此程序集进行不断的扩充使其包含更全面的功能。但是光有

  • 本文向大家介绍PowerShell小技巧之发送TCP请求,包括了PowerShell小技巧之发送TCP请求的使用技巧和注意事项,需要的朋友参考一下 很多时候我们需要通过Socket发送特定的TCP请求给服务器的特定端口来实现探测服务器的指定端口所开启的服务。很多语言都有相应的方法实现上述需求,当然,PowerShell也不例外,比如我们要发送一个简单的http请求到指定的web服务器: GET /