逆向工程

✍ dations ◷ 2025-07-16 01:55:33 #逆向工程
逆向工程(Reverse engineering),又称反向工程,是一种技术过程,即对一项目标产品进行逆向分析及研究,从而演绎并得出该产品的处理流程、组织结构、功能性能规格等设计要素,以制作出功能相近,但又不完全一样的产品。逆向工程源于商业及军事领域中的硬件分析。其主要目的是,在无法轻易获得必要的生产信息下,直接从成品的分析,推导产品的设计原理。逆向工程可能会被误认为是对知识产权的严重侵害,但是在实际应用上,反而可能会保护知识产权所有者。例如在集成电路领域,如果怀疑某公司侵犯知识产权,可以用逆向工程技术来寻找证据。需要逆向工程的原因如下:随着计算机辅助设计的流行,逆向工程变成了一种能根据现有的物理部件通过CAD、CAM、CAE或其他软件构筑3D虚拟模型的方法。逆向工程的过程采用了通过测量实际物体的尺寸并将其制作成3D模型的方法,真实的对象可以通过如CMMs,激光扫描仪,结构光源转换仪或者X射线断层成像这些3D扫描技术进行尺寸测量。这些测量数据通常被认作是点云,缺乏拓扑信息并且同时通常会被制作成更有用格式例如多边形网格,NURBS曲线或者CAD模型。由于点云本身并不像3D软件里的模型那样直观,所以如同3-matic(英语:Materialise NV)、Imageware、PolyWorks(德语:PolyWorks)、Rapidform(法语:Rapidform)或者杰魔公司等这些软件都提供了将点云变成能可视图像,或者被其他应用软件如3D CAD、CAM、CAE识别的格式的功能。反向工程同时会被需要将真实的几何体应用在虚拟的数字开发环境中的商业活动中应用,比如将自己产品或者竞争者的三维数据数字化。通过这种手段可以分析出产品的运作方式,部件构成,估计预算和识别潜在的侵权行为等。价值工程也是商业中应用的类似手段。不过价值工程的目的是通过反构造和分析产品来找到节省开销的办法。由于“逆向工程”一词用在软件工程(简称“软工”)领域中的具体含义模糊不清,Chikofsky和Cross为此写了篇文章,以阐清及区分“逆向工程”与各种相近的概念。据文章所述,逆向工程是一种分析目标系统的过程,其目的是识别出系统的各个组件以及它们之间的关系,并以其它的形式或在较高的抽象层次上,重建系统的表征(Representations)。 软件逆向工程也可被视作“开发周期的逆行”。 在此定义下,对一项软件程序进行逆向工程,类似于逆行传统瀑布模型中的开发步骤,即把实现阶段的输出(即软件程序)还原回在设计阶段所做的构思。软件逆向工程仅仅是一种检测或分析的过程,它并不会更改目标系统(否则就成了软件再工程)。软件防篡改技术被用于遏制对专有软件进行逆向工程及再工程。实际应用中出现了两类逆向工程。第一种,软件的源代码可用,但是更高层次的部分几乎没有描述文档或者描述文档不再适用或者丢失。第二种,软件没有可用的源代码,任何能找到它的源代码的努力都被称为逆向工程。大部分人都熟悉这个词的第二种用法。软件的逆向工程可以使用净室技术来避免侵犯著作权。软工中的黑盒测试与逆向工程有很多共同点,但黑箱测试人员常供以API以作测试,并且测试的目的就是通过外部攻击,找出程序漏洞和未归档的特性。逆向工程的其他目的包括:安全审查、 解除复制保护(又称破解)、绕过消费类电子产品中常设有的访问限制、定制嵌入式系统(例如引擎管理系统)、产品内部修补或更新、给功能不全的廉价硬件(例如某些显卡芯片组)添加额外功能,或仅为满足好奇心。对最终程序的二进制代码所进行的逆向工程被称为“代码反向工程”,或简称RCE(Reverse Code Engineering)。例如,我们可以用Jad对Java平台的二进制码进行反编译。一个著名的逆向工程案例是,首个由非IBM公司所实现的IBM个人电脑中的BIOS,这开创了IBM PC兼容机产业,使得IBM PC兼容机成为多年来的主流计算机硬件平台。一个以软件逆向工程为乐的团体例子是CORE(Challenge Of Reverse Engineering,意为“挑战逆向工程”)。在美国,软件逆向工程只要遵守著作权法的合理使用规定,都是受保护的。成功的软件逆向工程项目有:软件逆向工程有多种实现方法,主要有三:许多UML工具涉及到导入源代码生成UML图,即“逆向工程”。分析智能卡的逆向工程具有侵入性和破坏性,智能卡被层层刮掉用电子显微镜拍照。这种技术可以完整地揭示出智能卡的硬件和软件部分。主要的问题就是,把所有的东西按正确的顺序放好以找出每一个部件是如何工作的。工程师们用打乱内存位置的方法隐藏密码和操作,例如busscrambling。有时甚至可以在智能卡运行的时候用探针直接测量电压,设计师则用感应器来检测和防止。破坏支付业务中使用的智能卡很困难,只有大芯片制造商使用那些专业的设备。况且,和其他安全机制例如阴影帐户相比,这种方法回报太低。逆向工程经常被用在军事上,用来复制从战场上由常规部队或情报活动获得的别国之技术、设备、信息或其零件。二战和冷战中经常被用到。二战以来的著名例子有:在美国及其他许多国家,制品或制法都受商业秘密保护,只要合理地获取制品或制法就可以对其进行逆向工程。专利需要把你的发明公开发表,因此专利不需要逆向工程就可进行研究。逆向工程的一种动力就是确认竞争者的产品是否侵权专利或侵犯著作权。为了互用性(例如,支持未公开的文件格式或硬件外围),而对软件或硬件系统进行的逆向工程被认为是合法的,虽然专利持有者经常反对并试图打压以任何目的对他们产品进行的逆向工程。为了获取一个有著作权的计算机程序中隐含的思想和功能元素且有合法的理由要获取,当只有拆解这一种方法时,根据法律判定,拆解是对有著作权作品的合理使用。

相关

  • 全钒氧化还原液流电池全钒氧化还原液流电池,或钒液流电池(Vanadium Redox Battery,缩写:VRB),是一种可充电的液流电池,它采用不同氧化态的钒离子来储存化学势能。 钒氧化还原电池利用钒以四种不同氧化态
  • 淀粉样变类淀粉沉积症(英语:Amyloidosis),又称类淀粉堆积症或淀粉样变,是指类淀粉蛋白(一种异常蛋白质)沉积在组织引起的一类疾病。类淀粉沉积症的病征视乎淀粉样蛋白沉积的所在地而有所不
  • 希腊数字希腊数字是一套使用希腊字母表示的记数系统,也称为爱奥尼亚数字、米利都数字、亚历山大数字、字母数字。在现代希腊,它们仍被使用在序数词上,并且很大程度上同西方使用罗马数字
  • OWL网络本体语言(英语:Web Ontology Language,OWL)旨在提供一种可用于描述网络文档和应用之中所固有的那些类及其之间关系的语言。OWL网络本体语言当前已经获得万维网联盟认可的,用
  • 心血运动论《心血运动论》(拉丁语:Exercitatio Anatomica de Motu Cordis et Sanguinis in Animalibus),全称《关于动物心脏与血液运动的解剖研究》,是英国生理学家、胚胎学家威廉·哈维于1
  • 神兽属陆氏神兽(学名:Shenshou lui)是一种生活在约1亿6000万年前的小型哺乳动物,其化石发现于辽宁省建昌县的髫髻山组地层。该动物体重约300克。有2对门齿、3对前臼齿、4对臼齿,多个尖
  • 莱曼·史匹哲小莱曼·史庄·斯皮策(英语:Lyman Strong Spitzer, Jr.,1914年6月26日-1997年3月31日),美国理论物理学家、天文学家。他是太空望远镜概念的提出者,NASA以他的名字命名斯皮策太空望
  • 富兰克林县富兰克林县(Franklin County, Georgia)是位于美国乔治亚州东北部的一个县,东北邻南卡罗莱纳州。面积690平方公里。根据美国2000年人口普查,共有人口20,285人。县治卡恩斯维尔(Car
  • 奥尔吉耶德·辛克维奇奥尔吉耶德·塞西尔·监凯维奇,CBE(英语:Olgierd Cecil Zienkiewicz,也译作奥尔吉耶德·辛克维奇;1921年5月18日-2009年1月2日),英国籍波兰裔学者,工程力学与计算力学专家,被视为有限
  • 乙丙橡胶乙丙橡胶,有机化合物制品,是橡胶制品工业中一项极为重要的原材料,有多种良好的理化特性。乙丙橡胶又可分为二元乙丙、三元乙丙橡胶、改性乙丙和热塑性乙丙。而三元乙丙橡胶(EPD