反向工程什么是反向工程

反向工程  时间:2021-08-24  阅读:()

什么是反向工程

首先声明是转来的,因为我回答你这个问题带了个网址,就一直提示"敏感"回答不上 0 引言 随着计算机技术的迅速发展,计算机技术应用的领域也逐渐扩大,人们希望计算机这一智能体能够解决各个领域的更多、更复杂的问题,从而也对计算机软件产品的功能、质量、开发成本和时间提出了越来越多的要求,软件技术受到了前所未有的挑战。

传统的软件工程主要关注新软件的分析与设计,但随着软件系统的规模和复杂度日益增长,软件的生命周期越来越长,软件开发的很大一部分工作集中于维护和改造现有的软件系统,而这些现有系统的需求、设计决策、业务规则、历史数据等统称为遗产系统(LS,Legacy System),LS是一种巨大的、长期的投资,因为如何充分利用这些有用的资产对新系统的开发显得尤其重要。

另一方面,随着技术的普及,Web用户增多,很多软件厂商需要将系统移植到Web上,进一步加剧了对软件维护的需求。

实践研究表明,软件资源预算的50%~80%消耗在对现有系统的维护上,而软件维护者理解程序源代码的时间要占整个软件维护的47%~62%。

软件维护已经成为软件工程面临的重要课题之一,而正确和全面地理解软件系统是对软件进行维护的前提,软件逆向工程应运而生,成为软件工程领域的一个新兴分支,其目标就是开发帮助人们理解已有软件系统的方法、工具,为软件系统的维护和演化提供支持。

文中主要介绍逆向工程的基本概念、主要步骤、分析方法、研究现状、存在的问题以及发展方向。

1 逆向工程的基本概念 “逆向工程”这个名词最早出现在对硬件产品的分析中,人们分析硬件产品以便改进自己的产品。

M.G.Rekoffir将逆向工程定义为:对一个复杂的硬件系统实施有条理的检查,以开发出关于这个系统的一组规范说明的过程。

在把这个概念应用到软件系统过程中,研究人员发现利用其中的许多方法可以获得对系统以及系统结构的理解。

然而,对一个硬件系统实施逆向工程,一般是为了得到这个系统的复制品,对一个软件系统实施逆向工程,一般是为了获得对这个系统在设计层次上的理解,以便于系统的维护、巩固、移植、改进。

软件逆向工程的基本原理是抽取软件系统的主要部分而隐藏细节,然后使用抽取出的实体在高层上描述软件系统。

在软件工程领域,迄今为止没有统一的逆向工程定义,较为通用的是Elliot Chikofsky和Cross1990年定义的逆向工程的相关术语。

软件工程通常被认为是开发一个新的系统,尽管软件工程也包括逆向工程和再工程,为了避免对软件工程含义的误解,引进了正向工程的概念。

(1)正向工程(Forward Engineering):从系统的高层抽象和逻辑上独立于实现的设计到系统的物理设计的传统过程,具体地说是从用户的需求到高层设计,再到底层设计,最后到实现的过程。

(2)逆向工程(Reverse Engineering):对系统进行分析,以确定系统的组件和组件之间的相互作用,以其他形式表示系统,或在较高的抽象层次上表示系统的过程。

值得说明的是,在对一个系统实施逆向工程时,并不改变这个系统本身,也不包括在此系统上构建新的系统的过程。

(3)重构(Restructuring):保持系统外部行为(功能和语义)的前提下,在统一抽象层次上改变表示形式。

(4)再工程(Reengineering):通过逆向工程、重构和正向工程对现有系统进行审查和改造,将其重组为一种新形式。

(5)设计恢复(Design Recovery):结合目标系统、领域知识和外部消息认定更高层次的抽象。

其中,再工程、设计恢复不改变系统,重构改变了系统。

但不改变其功能,再工程涉及到正向工程与逆向工程的联合使用,逆向工程解决程序的理解问题,正向工程检验哪些功能需要增加、保留和删除,再工程改变了系统的功能和方向,是最根本和最有深远影响的扩展。

图1显示这些概念之间的关系。

2 主要步骤和分析方法 由逆向工程定义可知:软件逆向工程的任务包括分析系统、抽象系统和展现系统,从而实现协助用户理解系统的目的。

分析系统是指分析系统的结构及运行过程,但不管目标系统面向何种应用领域,分析系统不外乎是分析系统的静态信息和动态信息。

目标系统面对不同的应用领域,要实现抽象目标系统的任务,需要领域知识和专家的经验。

展现系统最好的方式是使系统可视化。

图1 关系图 现有的逆向工程分析方法主要有以下4种: (1)词法分析和语法分析。

该方法主要是对程序源码进行分析,得到程序信息的多种有用表示,其中最常用的就是交叉引用列表。

通过语法分析可以得到两类表示:分析树(parse tree)、抽象语法树AST(abstract syntax tree),其中AST是更复杂的程序分析工具基础,包含了和程序的实际内容相关的细节。

(2)图形化方法。

图形化方法包括控制流分析、数据流分析以及程序依赖图。

控制流分析是在确定程序语法结构之后进行。

数据流分析关注于解决程序中从定义到使用的过程的相关的问题,比控制流分析要复杂得多。

程序依赖图是数据流分析的进一步改进,比数据流分析更复杂。

在程序依赖图中,控制流和数据流依赖放在一起处理,程序依赖图还具有这样的结构特性:一个程序依赖图描述了一个控制依赖的区域。

(3)程序切片。

切片技术来源于数据流分析方法,已经成为很多程序理解工具的基础。

一个程序切片是由程序中的一些语句和判定表达式组成的集合。

这些语句和判定表达式可能会影响在程序的某个位置上所定义或使用的变量的值。

利用切片技术可以将关注点确定在一个较小范围而不是关注整个程序。

(4)动态分析。

静态分析是对程序源码进行分析。

动态分析则是在程序运行时进行分析,基本方法是对程序进行植入。

植入是在一种在全局范围内更改源代码以添加额外操作的过程。

这种方法的基本原理是:利用代码的结构信息,依据固定的规则,将软件触发器添加到代码中。

追问: 我问的是具体的方法,不是理论。

比如“ 词法分析 和语法分析”,怎么分析,用什么工具? 回答: 你要学下编程了,最起码 汇编 的命令你要知道,如果你连命令是什么意思还怎么分析呢, 分析的软件 ollydbg

LightNode(7.71美元),免认证高质量香港CN2 GIA

LightNode是一家位于香港的VPS服务商.提供基于KVM虚拟化技术的VPS.在提供全球常见节点的同时,还具备东南亚地区、中国香港等边缘节点.满足开发者建站,游戏应用,外贸电商等应用场景的需求。新用户注册充值就送,最高可获得20美元的奖励金!成为LightNode的注册用户后,还可以获得属于自己的邀请链接。通过你的邀请链接带来的注册用户,你将直接获得该用户的消费的10%返佣,永久有效!平台目前...

老薛主机入门建站月付34/月,年付345元,半价香港VPS主机

老薛主机怎么样?老薛主机这个商家有存在有一些年头。如果没有记错的话,早年老薛主机是做虚拟主机业务的,还算不错在异常激烈的市场中生存到现在,应该算是在众多商家中早期积累到一定的用户群的,主打小众个人网站业务所以能持续到现在。这不,站长看到商家有在进行夏季促销,比如我们很多网友可能有需要的香港vps主机季度及以上可以半价优惠,如果有在选择不同主机商的香港机房的可以看看老薛主机商家的香港vps。点击进入...

3元/首月香港便宜vps究竟是什么货。

便宜的香港vps多少钱?现在国外VPS主机的价格已经很便宜了,美国VPS主机最低一个月只要十几元,但同样免备案的香港VPS价格贵不贵呢?或者说便宜的香港VPS多少钱?香港vps主机价格要比美国机房的贵一些,但比国内的又便宜不少,所以目前情况是同等配置下,美国VPS比香港的便宜,香港VPS比国内(指大陆地区)的便宜。目前,最便宜香港vps低至3元/首月、18元/月起,今天云服务器网(www.yunt...

反向工程为你推荐
高级工程师证书考一个高级工程师证要什么学历?accesspoint接入点APN什么意思啊色空间求图像处理中颜色空间的介绍,越详细越好网络营销讲师哪位网络营销讲师培训师的上课风格最好?背投广告搜狐的广告类型有哪些?报价多少?网站数据分析报告网站流量统计分析的页面浏览数分析网通玩电信游戏卡怎么办玩英雄联盟家里是网通的,玩电信区很卡怎么办最好的电脑操作系统主流的电脑操作系统都有哪些?反恐精英维护到几点反恐精英OL要从几点维护到几点?解码器有什么用什么是播放器解码器
美国vps推荐 什么是域名地址 plesk 59.99美元 suspended softbank邮箱 北京双线 徐正曦 免费防火墙 国外代理服务器地址 什么是服务器托管 亚马逊香港官网 爱奇艺vip免费试用7天 根服务器 空间登陆首页 空间登入 百度云加速 免费的asp空间 卡巴斯基官网下载 存储服务器 更多