[发明专利]一种Linux系统脚本程序运行时验证与管控方法有效

专利信息
申请号: 202010829845.7 申请日: 2020-08-18
公开(公告)号: CN111914250B 公开(公告)日: 2022-05-17
发明(设计)人: 年艳川;曾毅 申请(专利权)人: 中科方德软件有限公司
主分类号: G06F21/51 分类号: G06F21/51
代理公司: 北京市海问律师事务所 11792 代理人: 王磊;沈骁
地址: 100190 北京*** 国省代码: 北京;11
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 一种 linux 系统 脚本 程序 运行 验证 方法
【权利要求书】:

1.一种Linux系统脚本程序运行时验证与管控方法,其特征在于:包括在内核中定义存储脚本文件解释器路径的全局变量和接口函数,还在内核中增加一个配置文件和开机服务,并在execve系统调用中增加HOOK点;系统启动时将脚本文件解释器的路径加载到内核中;运行脚本文件前,首先验证脚本文件的度量值,并以此管控脚本文件的运行过程;

在内核中定义接口函数,接收从用户态传递过来的脚本文件解释器的路径,并保存在内核全局变量中;

增加一个配置文件,保存脚本文件解释器的名称;增加一个开机服务,系统启动时读取配置文件中保存的脚本文件解释器的名称,解析成脚本文件解释器的路径,通过内核接口函数写入到内核全局变量中;

在execve系统调用中增加HOOK点,用以检查execve加载的可执行程序是否为脚本文件解释器,并验证脚本文件的度量值,从而管控脚本文件的执行过程。

2.根据权利要求1所述的一种Linux系统脚本程序运行时验证与管控方法,其特征在于:在内核中定义全局变量,保存系统支持的脚本文件解释器的路径。

3.根据权利要求1所述的一种Linux系统脚本程序运行时验证与管控方法,其特征在于:所述开机服务的具体运行步骤为:

S101:判断所述保存脚本文件解释器名称的配置文件是否存在,如果存在,则进入步骤S102;如果不存在,则进入步骤S106;

S102:读取所述保存脚本文件解释器名称的配置文件中的一行数据,然后进入步骤S103;

S103:判断读取的数据是否为空,如果不为空,表示读取了一种类型的脚本文件解释器,则进入步骤S104;如果为空,表示所述保存脚本文件解释器名称的配置文件已经解析完毕,则进入步骤S106;

S104:查找系统中是否存在该种类型的脚本文件解释器的可执行文件,如果不存在,则返回步骤S102;如果存在,则进入步骤S105;

S105:通过内核接口函数将该种类型的脚本文件解释器的路径写入内核中,然后返回步骤S102;

S106:结束。

4.根据权利要求1所述的一种Linux系统脚本程序运行时验证与管控方法,其特征在于:所述脚本文件运行时验证和管控的具体步骤包括:

S201:验证execve系统调用加载的可执行文件的度量值是否正确,如果正确,则进入步骤S202;如果不正确,则进入步骤S205;

S202:检索所述保存脚本文件解释器路径的内核变量,判断execve系统调用加载的可执行文件是否是脚本文件解释器,如果是,则进入步骤S203;如果不是,则进入步骤S206;

S203:从execve系统调用的参数列表中解析出脚本文件的路径,然后进入步骤S204;

S204:验证脚本文件的度量值是否正确,如果不正确,则进入步骤S205;如果正确,则进入步骤S206;

S205:验证失败,提示度量值不正确,然后退出execve系统调用;

S206:验证成功,继续执行原始的execve系统调用代码。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

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

本文链接:http://www.vipzhuanli.com/pat/books/202010829845.7/1.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

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

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

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

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

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

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

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

钻瓜专利网在线咨询

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

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