.NET 一款替代cmd.exe的交互式命令渗透工具

01阅读须知

此文所提供的信息只为网络安全人员对自己所负责的网站、服务器等(包括但不限于)进行检测或维护参考,未经授权请勿利用文章中的技术资料对任何计算机系统进行入侵操作。利用此文所提供的信息而造成的直接或间接后果和损失,均由使用者本人负责。本文所提供的工具仅用于学习,禁止用于其他方面

02基本介绍

Sharp4PSCommand.exe 是一款支持交互式命令的工具,可以在实际应用中替代传统的 cmd.exe。

03使用方法

该工具允许用户通过命令行直接执行 Windows 命令,提升了命令行操作的灵活性和便捷性。其基本用法示例为 Sharp4PSCommand.exe "tasklist",该命令可以显示当前运行的任务列表。

图片

04原理解析

Sharp4PSCommand.exe 的核心在于对 Windows 文件和资源的操作,尤其是对 PE格式的修改和证书的处理。以下是工具实现中的几个重要功能

public static void alterFile(string path, string pos = "108", string chars = "l")
{
    try
    {
        using (FileStream stream = new FileStream(path, FileMode.Open, FileAccess.ReadWrite))
        {
            int offset = Convert.ToInt32(pos);
            for (int i = 0; i < chars.Length; i++)
            {
                stream.Position = (long)(offset + i);
                stream.WriteByte(Convert.ToByte(chars[i]));
            }
        }
    }
    catch (Exception ex)
    {
        Console.WriteLine(ex.Message + "\n");
    }
}

打开指定文件,并在给定的位置写入字符。通过调整文件的字节,可以实现对 PE 文件的篡改,进而影响其执行行为。另外UnsignFile方法用于移除可执行文件的数字签名。具体实现如下

public static void UnsignFile(string file)
{
    using (FileStream fs = new FileStream(file, FileMode.Open, FileAccess.ReadWrite))
    {
        UtilPS.ImageRemoveCertificate(fs.SafeFileHandle.DangerousGetHandle(), 0);
        fs.Close();
    }
}

打开文件并调用 ImageRemoveCertificate 方法,移除指定文件的签名,使其在某些安全检查中更易于通过。

另外,工具使用了 P/Invoke 来调用 Windows API,以实现对资源的更新和证书的移除。

[DllImport("Imagehlp.dll")]
public static extern bool ImageRemoveCertificate(IntPtr handle, int index);

[DllImport("kernel32.dll", SetLastError = true)]
public static extern IntPtr BeginUpdateResource(string pFileName, [MarshalAs(UnmanagedType.Bool)] bool bDeleteExistingResources);

[DllImport("kernel32.dll", SetLastError = true)]
public static extern bool EndUpdateResource(IntPtr hUpdate, bool fDiscard);

综上,Sharp4PSCommand.exe 是一款功能强大的工具,通过对 Windows PE 文件的操作,提供了交互式命令行体验。

05.NET安全知识库

图片

图片

星球文化20+个专题栏目涵盖了点、线、面、体等知识面!其中主题包括.NET Tricks、漏洞分析、内存马、代码审计、预编译、反序列化、webshell免杀、命令执行、C#工具库等等。

图片

图片

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

dot.Net安全矩阵

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值