[发明专利]一种Java类依赖关系的静态识别方法有效

专利信息
申请号: 201611121526.0 申请日: 2016-12-08
公开(公告)号: CN106528179B 公开(公告)日: 2019-06-21
发明(设计)人: 王帅;杨燕;徐良;田申 申请(专利权)人: 中国科学院软件研究所
主分类号: G06F8/30 分类号: G06F8/30;G06F8/41
代理公司: 北京科迪生专利代理有限责任公司 11251 代理人: 杨学明;顾炜
地址: 100190 *** 国省代码: 北京;11
权利要求书: 查看更多 说明书: 查看更多
摘要: 发明公开了一种Java类依赖关系的静态识别方法,包括:1)对基于Java开发的Web应用的代码文件展开静态分析,构建代码中方法、变量和属性之间的依赖关系图;2)基于依赖关系图,自动识别Web应用中存在读写共享的持久化属性。本发明为自动检测Web应用是否可以集群部署提供了静态分析方法,可以覆盖待检测Web应用中所有可能的执行路径,并且不会引入任何代码污染。
搜索关键词: 一种 java 依赖 关系 静态 识别 方法
【主权项】:
1.一种Java类依赖关系的静态识别方法,其特征在于包括以下步骤:步骤1:分析用户指定的目标Web应用的代码,从中识别目标Web应用的入口方法,并将识别得到的入口方法置入待分析方法集合中;步骤2:依次分析待分析方法集合中的每个入口方法,建立入口方法内部定义的变量、引用的属性和被调用的方法间的依赖关系,得到入口方法内部的依赖关系图;并利用相同的步骤对入口方法调用的其他方法进行分析;分析完成后,将所有被分析的被调用方法置如已分析方法集合中;步骤3:依次分析已分析方法集合中的每个被调用方法,对于被调用方法的每次调用,建立方法调用时传入的实际参数和被调用方法定义的形式参数间的依赖关系,从而得到完整的依赖关系图;步骤4:遍历步骤3得到的依赖关系图,从中搜索持久化结点,并将其对应的元素置于持久化元素集合中;持久化元素指在Java中被声明为静态的属性、变量或方法,但在依赖关系图中被非静态的属性、变量或方法依赖的元素;步骤5:依次以步骤4得到的持久化元素集合中的元素为起点,对步骤3得到的依赖关系图进行遍历,位于2个持久化元素之间的属性即被识别为持久化属性,将识别得到的持久化属性置于持久化属性集合中,并最终输出;所述步骤3得到完整的依赖关系图具体包括以下步骤:(1)从已分析方法集合Sa中取出一个方法M;(2)获取M的调用集合Sc;(3)从调用集合Sc中取出一次调用指令C;(4)建立调用指令C中传入的实际参数和方法M定义的形式参数间的依赖关系,对于调用指令C中的每个实际参数A,找出其对应的形式参数P;如果A是对象的静态属性,则添加依赖关系P静态依赖于A,否则添加依赖关系P依赖于A;(5)返回步骤(3)继续处理Sc,直到集合Sc为空;(6)返回步骤(1)继续处理Sa,直到集合Sa为空。
下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国科学院软件研究所,未经中国科学院软件研究所许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/patent/201611121526.0/,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top