论文非常完整不可错过 一 系统開发平台介绍 语言描述 Windows 3D编程(英文影印版) 作者: 赵勇 赵勇,2007年于美国芝加哥大学获博士学位毕业后任职美国微软公司,2009年获微软杰出员工奖2009年入选美国名人录,2010年入选美国科学与工程名人录于2010年加入电子科技大学,主要从事云计算和大规模数据处理方面的研究 [同作者作品]
Windows程序设计(第5版.珍藏版) 云计算--资源调度管理 微软的软件测试之道(微软员工作人手一册实用力作,张亚勤博士写序推荐) 目录 第i部分 基础知识 第1章 起步 第2章 unicode简介 第3章 窗口与消息 第4章 文本输出 第5章 绘图基础 第6章 键盘 第7章 鼠标 第8章 计时器 第9章 子窗口控件 第10章 菜單和其他资源 第11章
对话框 第12章 剪贴板 第ii部分 关于图的那些事儿 第13章 使用打印机 第14章 位图和位块传输 第15章 设备无关位图 第16章 调銫板管理器 第17章 文本和字体 第18章 图元文件 第iii部分 高级主题 第19章 多文档界面 第20章 多任务和多线程 第21章 动态链接库 第22章 声音和音樂 第23章 尝试互联网 序言
微软中国研发集团首席技术官、微软亚洲工程院院长张宏江 微软公司自1983年11月宣布开发Windows产品,到2009年推出嘚最新一代个人计算机操作系统Windows
7已经整整走过了26个年头。Windows在世界范围内为众多领域提供了一个软件开发和应用的最普及的技术平台各種各样的软件开发语言和工具不断扩展和更新。比起早期的Windows编程来说现在创建应用程序显然容易了许多,利用个人计算机编程所能发挥嘚作用和能力远远超出任何人可以想象的 最新的Window
7,无论从界面、内核实现或是功能都可以说发生了无数的变化但依然保持了Windows程序嘚基本架构。对于Windows的基本架构和原理的深刻理解会帮助汀行业和软件开发领域的精英们充分利用Windows平台所提供的开发环境、开发语言和开發工具,起到举一反三、事半功倍的作用由美国Windows程序设计和技术写作专家CharlesPetzold先生所编写的这本((Windows程序设计》被称为是该领域中的经典著作之┅。虽然本书第5版本是在1998年出版的但今天读起来仍感到内容广泛、论述简明、例程丰富、收益匪浅。
除了不变的精华——Windows程序的架構之外本书还涵盖了编写Windows应用程序所必须了解的许多基本常识和技巧:最基本的字符编码和Unicode、底层键盘和鼠标的处理、Windows消息类型和处理過程、丰富多彩的图形显示接口(GDI)、用于共享代码的动态链接库(DLL)、支持多任务(multitasking)和多线程(multithreading)的实现、多媒体应用程序和网络应用程序的实现。无論对于哪种应用程序作者都解释了实现思路并提供了详尽的代码。作者提供的代码中许多例程都堪称经典可以成为编写同类程序的标准模板。
本书已成为广大开发人员学习Windows程序设计的必读书从第1版到第5版的不断完善中,它不仅引领着无数程序员走入Windows开发阵营更伴随着他们从菜鸟成长为高级程序构架师。本书之所谓经典就在于每一次阅读,都能给予读者新的启示程序新手可以从中学到编写Windows程序的基本技能和技巧:中级程序员可以了解程序设计的历史和渊源,做到调用各种函数时知其然更知其所以然;高级程序员则可以领悟到編程的高级理念通晓Windows系统自身设计方式的优劣,将其应用到各种实际问题上通过学习本书,读者必定可以在原有的基础上对Windows原理有進一步的认识和了解,全面掌握Windows编程的精华提高编程效率,编写出更高性能的Windows应用程序
同样值得一提的是这本经典大作的翻译者們。他们并不是经验丰富的专业翻译人员而是一群在微软公司工作过多年、对Windows技术相当熟悉,并深悟本书精髓的工程师们和技术主管们他们受清华大学出版社和微软出版社的委托对全书进行翻译。虽然这项任务是他们的业余项目但是他们怀着为中国软件产业作贡献的熱情,本着对技术负责、对读者负责的态度采用了微软公司成功的软件产品开发的管理模式和监督机制,以保证全书翻译准确、内容和格式的统一、中文语言的流畅凭借着技术方面的优势,他们对主要章节做了技术评述对英文原版书中的错误做了订正,对本书配套光盤中的所有程序都在Windows
7企业版上使用Visual Studio 2008调试通过 我为这本《Windows程序设计》经典大作能高质量地翻译成中文并在中国出版而高兴,我为这群對中国软件事业奉献爱心、不断追求高标准、团结进取协调一致的微软员工而自豪我对微软公司的拳头产品Windows能不断创新、并促进中国软件产业长足发展而充满希望和信息。 张宏江
译者: 健莲科技 丛书名: 其他 出版社:中国电力出版社 ISBN: 上架时间: 出版日期:2002 年8月 页码:462 版次:1-1 内容简介 书籍 计算机书籍 Transact—SQL是结构化查询语言(SQL)的增强版本与许多ANSI SQL标准兼容,Transact-SQL代码已成为SQL
Server的核心本书全面介绍了Transact—SQL,全书囲21章按照由浅入深的顺序,详细介绍了Transact-SQL基本概念和主要应用本书示例清晰,说理透彻实是不可多得之佳选。 本书可供各个层次嘚读者使用 目录 封面 -15 封底 -14 扉页 -13 版权 -12 译者序 -11 前言 -10 原书序 -9 目录 -6 第1章 作者: Abraham
(国内教师请联系麦格劳-希尔教育出版公司教师服务中心(北京),联系方式见书后插页———编者注)。在美国可以打***800ˉ338ˉ3987McGrawˉHill关于本书的网页/engcs/compsci/silberschatz-bridge/平台上的逆向工程;逆向未公开的文件格式和网络協议;逆向工程的合法性问题;拷贝保护和数字版权管理技术的逆向工程;防止别人对你的代码实施逆向工程的各种技术;恶意程序的逆姠工程;反编译器的基本原理以及它对逆向过程的影响。
本书适合软件逆向工程的从业人员以及软件开发者们阅读
译者序回到顶部↑ 记得第一次做与逆向有关的工作是2000年,当时由于项目的需要做过一个钩子(hook)程序,用于截获一个第三方控件发出的消息但是當时还不知道什么是逆向工程。第一次看到“逆向工程”这个词是在2001年的《机械工程学报》上的一篇文章中主要是讲用三坐标测量仪测量产品中各个部件的三维尺寸并在计算机中快速建模、进而反推其设计思想和基本设计原则。第一次使用逆向工程工具也是在2001年当时从網上下载了Numega
SoftICE,具体哪个版本已经记不清了在家里的旧电脑上折腾了好几天,直到系统崩溃才罢手.
之后呢,只是零零星星地看过一些相关的资料因此,当初电子工业出版社和我联系此书的翻译时我有些犹豫——近600页的逆向工程“巨”著,而且该书无论从深度还是廣度上都较其他有关逆向工程的书更胜一筹但褚华博士和王玉英博士的“加盟”,让我心里踏实了许多她俩做过系统的逆向工程和程序理解的研究工作,也发表过不少相关的研究论文
逆向工程这一术语最早来源于机械工程领域(我的老本行)。随着软件业的发展逆向工程被引入软件工程领域。对于软件逆向工程IEEE软件工程技术委员会行政秘书。 陈贵敏 2007年5月于西安电子科技大学...
前言回到顶部↑ 欢迎你阅读《逆向:逆向工程揭密》一书本书是在我参与了多年的软件开发项目之后写的,这些项目由于各种各样的原因需要反复地对第三方代码进行逆向工程起初,我觉得这是一个非常单调乏味的过程只是在没有替代方法来获取信息的凊况下才不得已使用它。后来一霎那间我破除了某个思维障碍,我发现自己迅速地“驰骋”于无正式文献记录的机器码中快速地破译叻代码的涵义并得到我想要的有关代码功能和用途的***。这时候我逐渐明白这是一种威力强大的技术,因为这意味着不管我有什么样嘚有关要处理软件的问题我都可以非常容易地找到***,即使我没有看过任何相关的文献资料或者正在处理的程序的源代码本书就是偠为每一个对软件有深刻理解的读者能够这样做提供相关的知识和技术。.
其思想很简单:我们应当对底层软件有深入的理解还要学***那些能够让我们轻松进入任何程序的二进制码并获取信息的技术。不知道系统为什么会以它那样的工作方式运转而且其他人也不知道***的话怎么办?没问题——你完全可以自己深入研究并找到***这听起来有点恐怖和不现实,是吗一点儿也不,我写这本书的目的僦是向你讲解并示范平常就可以用于解决各种各样问题的逆向工程技术
不过我总是急于求成。也许你以前没有接触过软件逆向工程嘚概念我在这里先简要介绍一下。 逆向工程和底层软件
在开始进入本书所讨论的各部分内容之前我们应当正式地介绍一下该書的主题:逆向工程。逆向工程是指将工程制品(比如汽车、喷气发动机或者软件程序)以揭示其最底层的细节(如其设计和架构)的方式进行解构的过程这与研究自然现象的科学研究有些类似,区别就在于一般没有人会把科学研究看做逆向工程这仅仅是因为没有人确切地知道自然算不算是工程制品。
对软件而言逆向工程归结起来就是拿一个既没有源代码又没有准确文献资料的现成程序,尝试恢複出它的设计和实现细节在某些情况下,可以找到程序的源代码但是找不到最初的开发人员了。本书所讨论的就是通常所说的二进制逆向工程二进制逆向工程技术的目标是从没有源代码的程序中提取有价值的信息。在有些情况下可以从程序的二进制代码中恢复出准确嘚源代码(或者接近高级表示的代码)这会大大简化逆向工作,因为阅读用高级语言写的代码要比阅读低级汇编语言代码容易得多在其他情况下,我们最终得到的只是用晦涩难懂的汇编语言程序清单本书将讲述这一过程以及程序为什么这样运行,同时还将详细描述如哬在各种不同的环境中破解程序代码
我决定将这本书取名为“逆向(Reversing)”,这一叫法被许多在线社区用来描述逆向工程因为你可鉯把逆向看做是逆向工程的别名,故我将在本书中交换使用这两种叫法
大多数人在尝试想像从可执行二进制程序中提取有意义的信息的时候会变得有些焦虑,因此我把这本书的首要任务定为证明这种害怕是没有必要的。二进制逆向工程如果行得通的话它通常能解決用其他方法解决起来极其困难的问题,而且如果方法得当的话它也没有你想像的那么复杂
本书主要讨论逆向工程,但事实上书中所讲述的内容要比逆向工程多得多在软件行业内,逆向工程被频繁地应用于各种场合本书的主要目标之一就是在讲授逆向工程的同时研究这些领域。 下面简要地列出了本书要讨论的一些主题: IA-32兼容处理器的汇编语言以及如何阅读编译器生成的汇编语言代码; 操作系统内幕以及如何对操作系统实施逆向工程;
.NET平台上的逆向工程包括.NET开发平台的简介及.NET平台汇编语言:MSIL(Microsoft中间语言); 數据逆向工程:如何破译未公开的文件格式或者网络协议; 逆向工程的合法性问题:什么情况下是合法的,什么情况下是非法的 拷贝保护和数字版权管理技术; 破解人员是如何应用逆向工程使拷贝保护技术失效的;
防止人们对代码实施逆向工程的技术并認真尝试评价这些技术的有效性;.. 目前恶意程序的基本原理以及如何应用逆向工程研究并清除这样的程序; 一个真实恶意程序的現场剖析和展示,以及揭示了攻击者是怎样通过程序通信获得被感染系统的控制权的; . 反编译器背后的理论和原则以及它们对各种低级语言代码进行反编译的有效性。 本书的组织
本书共分四部分第1部分提供了学习后边部分所需的基础知识,其他三个部分分別讲述了不同的逆向工程情景并展示了真实的案例研究。每一部分的详细描述如下
第1部分—逆向101:本书是从讨论理解底层软件所需的所有基础知识开始的。你必定能想像到这几章不可能包含所有相关的知识,你只需将这些内容看作是对以前学过的材料重新整理洳果本书前三章讲述的所有内容或者大部分内容对你来说都是全新的,那么这本书不适合你这几章的主要内容有:介绍了逆向工程及其各种应用(第1章),底层软件的概念(第2章)并以Microsoft
Windows为重点介绍了操作系统内部结构(第3章)。总的来说如果你精通这些内容以及底层軟件,你基本上可以跳过这几章第4章讨论了各种类型的常用逆向工程工具,并为各种情况推荐了适合的专用工具这些工具的大部分都茬本书展示的逆向工程实例过程中使用过。
第2部分——应用逆向:本书的第2部分演示了在真正的软件上实施的逆向工程项目这部分嘚每一章分别讨论一种不同类型的逆向工程应用。第5章讨论了最常见的情境——对操作系统或第三方代码库进行逆向工程以便更好地利鼡它的内部服务和API。第6章展示了如何应用数据逆向工程技术破解无正式文档记录的专用文件格式第7章展示了漏洞研究人员如何使用逆向笁程技术在二进制代码可执行程序中寻找漏洞。这部分的最后一章第8章讨论了恶意软件,如病毒和蠕虫并简要介绍了这一内容。这一嶂还展示了对真正的恶意程序进行逆向工程的实例过程这实际上就是恶意软件研究人员为了研究恶意程序、估计它们带来的危险、并研究如何清除它们所必须经历的过程。
第3部分——盗版和拷贝保护:这一部分主要讨论与安全相关的代码的逆向工程如拷贝保护和数芓版权管理(Digital Rights
Management,DRM)技术第9章简要介绍了盗版和拷贝保护并讨论了拷贝保护技术的基本原则。第10章讲述了反逆向工程技术如在拷贝保护囷DRM技术中常常采用的技术,并评价它们的有效性第11章讨论了“破解者”是怎样使用逆向工程破解拷贝保护机制并窃取拷贝保护内容的。
第4部分——反汇编之外:本书的最后部分所讲述的内容已经超出了可执行程序的简单反汇编第12章讨论了在Microsoft .NET开发平台上开发的虚拟机程序的逆向工程过程。这一章简单介绍了.NET平台及其低级的汇编语言MSIL(Microsoft 中间语言Microsoft Intermediate
Language)。第13章论讨论了有关反编译的更理论化的主题并说明叻反编译器是怎样工作的以及反编译本地汇编语言代码为什么那么具有挑战性。 附录:本书共包含三个附录可以作为破解Intel IA-32汇编语言程序的有价值的参考资料。这几个附录远远超出了简单的汇编语言参考向导讲述了公共代码段(common code
fragments)和常用编译器对几种典型的代码序列表现出来的编译器习性(complier idioms),并介绍了识别和破解它们的方法 谁应当阅读此书
本书所揭示的技术能够让各行各业的人受益。软件开发人员想要提高他们对软件底层知识的理解:如操作系统、汇编语言、编译等等,这本书无疑会让他们受益匪浅更重要的是,该書能够让所有对开发技术感兴趣的人们快速而高效地研究和考察现有代码不管是操作系统代码、软件库代码还是软件组件代码。除了这些技术以外本书还提供了诸如安全、版权控制等许多主题的精彩讲述。即使对逆向工程不是很感兴趣只是在书中找到一处或多处感兴趣的内容,你就可能从中获益
就预修知识而言,本书涉及到一些相当高级的技术材料我已经试着尽可能让它们在内容上保持独立。所需的大多数基础知识都包含在本书的第1部分中当然,要想真正从本书中获益你还得有一定的软件开发知识和经验,这也是很重要嘚如果你一点专业的软件开发经验都没有,但是现在正在学习这方面的知识那也为时不晚。相反地如果你没有正规地学习过计算机,只做过几年的程序设计那你也可能从本书中获益。
最后对于那些已经具有底层软件和逆向工程经验的高级读者而言,他们希望學习一些有趣的高级技术和如何从现有代码中提取非常详细的信息本书也会对他们有所帮助。 工具和平台
实施逆向工程需要各種各样的工具本书通篇介绍和讨论了大量这样的工具,而且我有意地在大部分范例中使用免费工具这样读者就可以照着范例实践而不需要在工具上花费数千美元了。需要指出的是在某些情况下,大型的逆向工程项目会从这些昂贵的工具中受益匪浅我试着为每个相关嘚工具提供尽量多的信息,并展示每个工具对逆向过程的影响项目是否值得花钱去买工具,最终的决定权还在读者手里
逆向工程通常是平台相关的,它会受到具体的操作系统和所用的硬件平台的影响本书中使用的主要操作系统是Microsoft Windows,而且我有很好的理由来说明为什麼选择Microsoft
WindowsWindows是最流行的逆向工程环境,这不仅仅是因为它是最流行的操作系统例如,受人欢迎的Windows替代品——开放源码的Linux准确地讲它与逆姠的立场相去甚远,因为整个操作系统以及在其上运行的大部分软件的源代码都是开放的逆向开发源码的产品是没有意义的——直接读源代码就好了,或者还有更好的办法——咨询原开发者没有什么秘密可言。 本书网站上有什么
你可以访问本书的网站/go/eeilam上面有書中所有的示例程序。在网站上我还增加了链向本书讨论过的各种文章、产品以及在线资源的链接 从哪里开始学习?
本书是按照从开始到结尾顺序阅读的方式写作的当然,有些人可能更愿意挑选感兴趣的章节阅读对他们来说这样获益更多。就从哪里开始而言不考虑你的背景,我建议你先读一下第1章以确保你了解本书所涉及的所有基本的与逆向工程相关的资料。如果你没有很好的逆向工程囷底层软件经验的话我强烈建议你按照本书的“自然”顺序阅读,最起码前两部分要这样做
如果你经验丰富,并觉得自己精通软件开发和操作系统的话或许你可以直接跳到第4章开始学习逆向工程工具。...