C#实现远程线程插入

能否使用C#实现远程线程插入吗?

使用严格的C#,不借助任何其它技术。远程线程插入是不能在.NET平台上实现的。然而在shellcode技术和远程线程插入之代码插入的基础上。完全可以实现基于.NET平台的混合型远程线程插入。

最终效果是这样的:用于将线程插入到其它进程的可执行程序是.NET程序(混合几百字节的机器码),用于被插入到其它进程的DLL或EXE也是纯.NET实现的。

可被插入的对象是所有有权限进程WriteProcessMemory操作的本机进程。

C#实现远程线程插入需要的技术:.NET进程寄宿远程线程插入之代码插入

所谓的C#实现远程线程插入,其核心就是将一个.NET程序集寄宿到一个本机上的任意目标进程中并以线程方式运行。CLR环境其根本就是一个COM服务器。我们写的.NET程序集都是在这个COM服务器的支持下运行的。如果想让一个.NET程序集在任意的本机进程中运行。那么首先那个进程需要具有.NET环境时环境。因为我们在远程线程插入时就需要用到。 NET环境时环境。没有这个环境,我们的.NET程序集就没有办法被加载执行。如果本机进程是WIN32的,没有.NET运行时环境怎么办呢?我们需要给它一个,代码如下:

 
 
 
  1. DWORD __stdcall clrfunclocal(){  
  2. ICLRRuntimeHost * pClrHost;  
  3. CorBindToRuntimeEx
    (NULL,NULL,0,CLSID_CLRRuntimeHost,IID_ICLRRuntimeHost,(PVOID*)&pClrHost);  
  4. pClrHost->Start();  
  5. DWORD retVal=0;  
  6. hr=pClrHost-> ExecuteInDefaultAppDomain
    (s_asmpath),s_class,s_method,NULL,&retVal);  

以上代码的最后一句是用于在默认程序域内执行一个.NET程序集。这段代码是用C++写的。

如果是自己写了一个WIN32程序,因为某种原因需要加载一个.NET程序集并执行它的功能。你就可以像以上那样写。但我们是做远程线程插入,那么如何在被插入的进程中执行上数代码呢?高手已经明白了。就是将这些代码编译成像SHELLCODE一样的裸的可执行代码。然后使用远程线程插入的代码插入就可以 CLR环境加载到其它进程中并使其执行我们想要的.NET程序集里的代码。

如果你已经有办法将上述代码编译成裸的可执行本机代码了。你就可以将这些本机代码作为资源加到你的C#项目中。备用。

在C#中执行远程线程插入和在C++中是一样的。

【编辑推荐】

  1. 概述C#实现文件下载
  2. C#搞定网站验证码的方法
  3. 浅谈C# String对象
  4. C#命名空间学习笔记
  5. 浅析C#调用ActiveX控件
免责声明:文章内容不代表本站立场,仅供读者参考。产品相关技术问题请发送工单。 本文链接:https://www.idc.net/help/404966/

为您推荐

开源数据收集引擎 Logstash 讲解和示例讲解

一、概述 Logstash 是一个开源的数据收集和日志处理工具,它是 Elastic Stack(ELK Stack)的一部分,用于从各种数据源中采集、转换和传输数据,以帮助分析和可视化大规模数据。Logstash 通常与 Elasticsearch 和 Ki...

八个开源免费单点登录(SSO)系统

单点登录(SSO)是一个登录服务层,通过一次登录访问多个应用。使用SSO服务可以提高多系统使用的用户体验和安全性,用户不必记忆多个密码、不必多次登录浪费时间。 下面推荐一些市场上最好的开源SSO系统,可作为商业SSO替代。 1.Authelia https://github.com/authelia/authelia ...

浅谈HBase数据结构和系统架构

Part 01 LSM树模型 常见的的关系型数据库,如MySQL、SQL Server、Oracle等,使用B+ Tree作为数据存储与索引的基本结构,非叶子节点只存放索引数据,叶子节点存放所有数据和指向相邻节点的指针,具有高效的范围查询和稳定的查找效率,以及具有较小的读放大和空间放大。采用磁盘随机读写方式,且以磁盘数...

微软Radius平台重构现代应用程序部署

微软的 Azure 孵化团队日前推出一个叫 Radius 的新应用平台。Radius 平台可用于在 Kubernetes、公共云和边缘环境中运行各种现代应用程序。 Radius 是一个开源项目,最初支持的应用程序运行时包括Kubernetes、Azure和AWS,以后还会支持诸如谷歌云平台等云环境。 Mark Russ...

Ext JS3.0正式版发布

Ext JS3.0在经历数次RC版之后,extjs.com终于发布3.0的正式版。总体而言,较2.0改进不大,依然还是原理的组件模型,具体更新及改进如下: ◆提供了参照DWR后与后台的通讯包Direct,支持具有明显的REST风格的CRUD服务 ◆一系列的新的组件和例子,包括有图表(Charting, By YUI F...
返回顶部