- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
WindowsAPI和CRuntime对安全性的影响【浮生若梦】
Windows API和C Runtime对安全性的影响
CopyMemory
VOID CopyMemory(PVOID Destination, CONST VOID *Source, DWORD Length);
Destination 要复制内存块的目的地址。
Source 要复制内存块的源地址。
Length 指定要复制内存块的大小,单位为字节。
返回值 该函数为VOID型,没有返回值。
头文件 winbase.h.
注意一点CopyMemory和MoveMemory不过是RtlMoveMemory的一个别名而已。
示例代码段
char szname[50]=阵雨;
char szfriend[]=polelf,oo;
CopyMemory(szname+4,szfriend,10);
OutputDebugString(szname); //输出结果为阵雨polelf,oo
安全性评价
第一个参数Destination必须足以容纳count个字节的Source组合大小,否则就可能发生缓冲区溢出。这样,当发生违规访问时,应用程序就可能会遭到拒绝服务攻击,或者更坏,可能会使攻击者将可执行代码注入到您的进程中。如果Destination是基于堆栈的缓冲区,则尤为如此。要注意的是,最后一个参数Length是要复制到Destination的字节数,而不是Destination的大小。
以下代码示例演示了安全使用CopyMemory() 的方法:
void test(char *pbData, unsigned int cbData)
{
char buf[BUFFER_SIZE];
CopyMemory(buf, pbData, min(cbData,BUFFER_SIZE));
}
CreateProcess
CreateProcessAsUser
CreateProcessWithLogonW
安全性评价
第一个参数 lpApplicationName 可以为 NULL。在这种情况下,可执行程序的名称必须是 lpCommandLine 中第一个用空格分隔的字符串。但是,如果可执行程序的名称或路径名中有空格,则存在一定的风险,因为如果空格处理不当,就可能会运行恶意的可执行程序。以下示例是危险的,因为该进程将试图运行“Program.exe”(如果该程序存在),而不是“foo.exe”。
CreateProcess(NULL, C:\Program Files\foo, ...)
如果恶意用户要在系统中创建名为“Program.exe”的特洛伊程序,那么任何使用“Program Files”目录不正确地调用 CreateProcess 的程序都将启动特洛伊程序,而不是要调用的应用程序。
注意不要为 lpApplicationName 传递 NULL,以避免函数根据其运行时参数来分析并确定可执行文件路径名。如果 lpApplicationName 一定要为 NULL,则用引号将lpCommandLine 中的可执行路径引起,如下例所示。
CreateProcess(NULL, \C:\Program Files\foo.exe\ -L -S, ...)
WIN32API函数CreateProcess用来创建一个新的进程和它的主线程,这个新进程运行指定的HYPERLINK /view/159830.htm可执行文件。
BOOL CreateProcess
(LPCTSTRlpApplicationName,
LPTSTRlpCommandLine,
LPSECURITY_ATTRIBUTES lpProcessAttributes。
LPSECURITY_ATTRIBUTES lpThreadAttributes,
BOOL bInheritHandles,
DWORD dwCreationFlags,
LPVOID lpEnvironment,
LPCTSTR lpCurrentDirectory,
LPSTARTUPINFO lpStartupInfo,
LPPROCESS_INFORMATION lpProcessInformation );
参数
lpApplicationName: 指向一个NULL结尾的、用来指定可执行模块的字符串。 这个字符串可以是可执行模块的绝对路径,也可以是相对路径,在后一种情况下,函数使用当前驱动器和目录建立可执行模块的路径。 这个参数可以被设为NULL,在这种情况下,可执行模块的名字必须处于 lpCommandLine 参数的最前面并由空格符与后面的
您可能关注的文档
- WBP安装应用常见问题.doc
- WAYSFOCUS明星管理员教程(修正版)V20110621.doc
- WC9焊接工艺评定书.doc
- WCDMA业务与盈利模式分析.doc
- WCDMA网络优化资料.doc
- WebService大讲堂之Axis2用POJO实现0配置的WebService.doc
- Web实习报告1.doc
- Web客户端编程实验报告.doc
- Werkfz四位特邀摄影师此次带来了他们使用EOS50D的体会和经验.doc
- westernblot条带分析.doc
- Windows8的安装过程与特点.doc
- windowsServer2003基础应用实训.doc
- WindowsServer2003用户和组实验报告.docx
- windowsserver2003网络管理与应用实验报告燕山大学.doc
- windowsserver2008系统下HP服务器收集硬件日志方法(SurveyIMLADU).doc
- Windowsserver2012体验之可降级的功能级别.docx
- WindowsXP操作系统-实验.doc
- WindowsXP操作系统安装教程.doc
- WindowsXP操作系统查看IP地址的教程(德阳昌新科技).docx
- WindowsXP操作系统实验.doc
文档评论(0)