[发明专利]一种生成可执行文件的方法和装置在审
申请号: | 202210459898.3 | 申请日: | 2022-04-28 |
公开(公告)号: | CN114691149A | 公开(公告)日: | 2022-07-01 |
发明(设计)人: | 高阔 | 申请(专利权)人: | 京东科技控股股份有限公司 |
主分类号: | G06F8/41 | 分类号: | G06F8/41;G06F9/445 |
代理公司: | 中原信达知识产权代理有限责任公司 11219 | 代理人: | 王安娜;赵迪 |
地址: | 100176 北京市北京经济*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 生成 可执行文件 方法 装置 | ||
本发明公开了一种生成可执行文件的方法和装置,涉及计算机技术领域。该方法的一具体实施方式包括:将源码文件编译成源码字节码文件;对所述源码字节码文件和库文件中的字节码文件进行遍历,判断是否存在目标指令;若是,则将所述目标指令替换成内部获取指令;其中,所述内部获取指令用于对用户信息进行缓存,并直接返回缓存中的用户信息;将替换后的源码字节码文件和替换后的库文件编译成可执行文件。该实施方式能够解决源代码修改量大的技术问题。
技术领域
本发明涉及计算机技术领域,尤其涉及一种生成可执行文件的方法和装置。
背景技术
目前,侵犯用户隐私的行为主要包括以下几种情况:
(1)用户同意隐私协议前获取任何用户信息的行为,用户信息包括但不限于:设备唯一标识(比如AndroidID)、网络信息(比如WiFi信息)、国际移动设备识别码(IMEI)、Mac地址、系统版本等;
(2)频繁调用系统方法获取用户信息的行为;
(3)应用在后台获取应用列表等用户信息的行为;
(4)明文传输敏感字段的行为,敏感字段包括但不限于:IMEI、Mac地址、定位经纬度等。
为了解决频繁调用系统方法的问题,可以接入BaseInfo SDK,但是在接入Baseinfo SDK时,面临着以下技术问题:
(1)如果采用人工方式修改源代码,会存在大量重复性工作;(2)如果没有第三方SDK的源代码,则无法进行修改。
发明内容
有鉴于此,本发明实施例提供一种生成可执行文件的方法和装置,以解决源代码修改量大的技术问题。
为实现上述目的,根据本发明实施例的一个方面,提供了一种生成可执行文件的方法,包括:
将源码文件编译成源码字节码文件;
对所述源码字节码文件和库文件中的字节码文件进行遍历,判断是否存在目标指令;若是,则将所述目标指令替换成内部获取指令;其中,所述内部获取指令用于对用户信息进行缓存,并直接返回缓存中的用户信息;
将替换后的源码字节码文件和替换后的库文件编译成可执行文件。
可选地,对所述源码字节码文件和库文件中的字节码文件进行遍历,判断是否存在目标指令;若是,则将所述目标指令替换成内部获取指令,包括:
对所述源码字节码文件和库文件中的字节码文件进行遍历,判断是否存在目标指令;
若是,则判断所述目标指令的类型为方法或者属性;若所述目标指令的类型为方法,则通过调用visitMethodInsn方法返回目标指令;若所述目标指令的类型为属性,则通过调用visitFieldInsn方法返回目标指令;
将所述目标指令替换成内部获取指令。
可选地,对所述源码字节码文件和库文件中的字节码文件进行遍历之前,还包括:
创建ClassVisitor类和MethodVisitor类;
其中,所述ClassVisitor类用于遍历源码字节码文件和库文件中的字节码文件,判断是否存在目标指令;所述MethodVisitor类包括visitMethodInsn方法和visitFieldInsn方法,用于返回目标指令。
可选地,将所述目标指令替换成内部获取指令,包括:
将内部获取指令编译成以字节码表示的内部获取指令;
将所述目标指令替换成所述以字节码表示的内部获取指令。
可选地,所述库文件为.jar文件或者.aar文件。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于京东科技控股股份有限公司,未经京东科技控股股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202210459898.3/2.html,转载请声明来源钻瓜专利网。