CN108460252A - 一种软件产品license信息设置方法 - Google Patents

一种软件产品license信息设置方法 Download PDF

Info

Publication number
CN108460252A
CN108460252A CN201711388547.3A CN201711388547A CN108460252A CN 108460252 A CN108460252 A CN 108460252A CN 201711388547 A CN201711388547 A CN 201711388547A CN 108460252 A CN108460252 A CN 108460252A
Authority
CN
China
Prior art keywords
software product
hardware device
check value
value
disk
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN201711388547.3A
Other languages
English (en)
Inventor
金振成
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
UIT STORAGE TECHNOLOGY (SHENZHEN) Co Ltd
Original Assignee
UIT STORAGE TECHNOLOGY (SHENZHEN) Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by UIT STORAGE TECHNOLOGY (SHENZHEN) Co Ltd filed Critical UIT STORAGE TECHNOLOGY (SHENZHEN) Co Ltd
Priority to CN201711388547.3A priority Critical patent/CN108460252A/zh
Publication of CN108460252A publication Critical patent/CN108460252A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/10Protecting distributed programs or content, e.g. vending or licensing of copyrighted material ; Digital rights management [DRM]
    • G06F21/12Protecting executable software
    • G06F21/121Restricting unauthorised execution of programs
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/10Protecting distributed programs or content, e.g. vending or licensing of copyrighted material ; Digital rights management [DRM]
    • G06F21/107License processing; Key processing
    • G06F21/1077Recurrent authorisation

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Computer Security & Cryptography (AREA)
  • Theoretical Computer Science (AREA)
  • Multimedia (AREA)
  • Technology Law (AREA)
  • Computer Hardware Design (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Storage Device Security (AREA)

Abstract

本申请提供了一种软件产品license信息设置方法,在硬件设备上安装软件产品时,获取硬件设备的系统盘的SN号;使用该SN号按照预设算法生成该软件产品针对该硬件设备的校验值,并将该校验值作为license信息存储到该硬件设备的裸盘中;该方法包括:当在该硬件设备上运行该软件产品时,获取该硬件设备的系统盘的SN号,并使用所述SN号按照预设算法生成该软件产品针对该硬件设备的校验值;确定当前计算出的校验值与所述裸盘中的校验值是否相同,如果是,运行该软件产品;否则,提示该软件产品的license异常。该方案能够避免软件产品被复制使用的问题。

Description

一种软件产品license信息设置方法
技术领域
本发明涉及通信技术领域,特别涉及一种软件产品软件使用许可(license)信息设置方法。
背景技术
有很多服务器是不连接外网的,因此,没有方法通过公有网络检测license。
传统license设计,都是有个license配置文件,检测主板mac地址绑定硬件,以及检测系统当前时间判断是否过期。
但是主板的网卡mac地址是可以修改的,产品的系统时间也可以修改的,这样可以规避license限制,而不能使软件产品的使用权限被保护。
发明内容
有鉴于此,本申请提供一种软件产品license信息设置方法,能够避免软件产品被复制使用的问题。
为解决上述技术问题,本申请的技术方案是这样实现的:
一种软件产品软件使用许可license信息设置方法,在硬件设备上安装软件产品时,获取硬件设备的系统盘的序列号SN号;使用该SN号按照预设算法生成该软件产品针对该硬件设备的校验值,并将该校验值作为license信息存储到该硬件设备的裸盘中;该方法包括:
当在该硬件设备上运行该软件产品时,获取该硬件设备的系统盘的SN号,并使用所述SN号按照预设算法生成该软件产品针对该硬件设备的校验值;
确定当前计算出的校验值与所述裸盘中的校验值是否相同,如果是,运行该软件产品;否则,提示该软件产品的license异常。
由上面的技术方案可知,本申请中利用硬件设备的系统盘的SN号唯一且无法修改的特性,按照预设算法预先生成校验值,存储到裸盘中,每次使用该软件产品时,获取使用该软件产品的系统盘的SN号,并使用同样的方法生成校验值,与存储的校验值比较,一致才能使用该软件产品。该技术方案不再以配置文件形式记录license信息,能够避免软件产品被复制使用的问题,即增加了软件产品使用的安全性。
附图说明
图1为本申请实施例中软件产品license信息设置流程示意图;
图2为本申请实施例中实现控制软件产品运行时间的流程示意图。
具体实施方式
为了使本发明的目的、技术方案及优点更加清楚明白,下面结合附图并举实施例,对本发明的技术方案进行详细说明。
本申请实施例中提供一种软件产品license信息设置方法,利用硬件设备的系统盘的序列号(SN)号唯一且无法修改的特性,按照预设算法预先生成校验值,存储到裸盘中,每次使用该软件产品时,获取使用该软件产品的系统盘的SN号,并使用同样的方法生成校验值,与存储的校验值比较,一致才能使用该软件产品。该技术方案不再以配置文件形式记录license信息,能够避免软件产品被复制使用的问题,即增加了软件产品使用的安全性。
由于使用软件产品之前需要将软件产品安装在对应的硬件设备上,本申请具体实现时,在安装软件产品时,生成该软件产品的license,具体过程如下:
在硬件设备上安装软件产品时,获取硬件设备的系统盘的SN号。
本申请实施例中,在获取硬件设备的系统盘的SN号时,可以通过磁盘健康检测程序(smartctl)工具获取,如获取的SN号为MK0271YGHKBBRA。
使用该SN号按照预设算法生成该软件产品针对该硬件设备的校验值,并将该校验值作为license信息存储到该硬件设备的裸盘中。
本实施例中使用该SN号按照预设算法生成该软件产品针对该硬件设备的校验值有两种方式,具体为:
第一种:
通过消息摘要算法第五版(MD5)算法,生成所述系统盘的SN号的MD5值;
针对MD5值的每个字符换算为二进制并取反;将每个取反后的二进制数,并按对应字符在MD5值中的顺序组成新的字符串,作为该软件产品针对该硬件设备的校验值。
第二种:
通过MD5算法,生成所述系统盘的SN号的MD5值;
针对MD5值的每个字符换算为二进制并取反;将每个取反后的二进制数转换为16进制数,并按对应字符在MD5值中的顺序组成新的字符串,作为该软件产品针对该硬件设备的校验值。
两种方式的区别为将二进制按位取反后,是否将二进制数再转换为16进制数。
以第二种实现方式举例:
第一步,将SN号MK0271YGHKBBRA进行md5运算,生成md5值b24c7a652d30499a3c4445f421eede59,这里计算出的MD5值不可逆,可以记为sn_md5。
第二步,进一步将sn_md5,即b24c7a652d30499a3c4445f421eede59的每个字符换算为二进制后,按位取反。如sn_md5一共32个字符,第一个字符b对应二进制1011,取反后对应二进制0100,换算成16进制就是4,第二个字符2,对应二进制0010,取反后1101,换算成16进制就是d,如最后一个字符9对应二进制1001,取反后0110,换算成16进制为6;生成新的字符串sn_md5_xor:4dxxxxxxxxx….xxx6,中间的字符对应的16进制数不再一一举例。
下面结合附图,详细说明本申请实施例中软件产品license信息设置过程。
参见图1,图1为本申请实施例中软件产品license信息设置流程示意图。具体步骤为:
步骤101,当在该硬件设备上运行该软件产品时,获取该硬件设备的系统盘的SN号。
步骤102,使用所述SN号按照预设算法生成该软件产品针对该硬件设备的校验值。
步骤103,确定当前计算出的校验值与所述裸盘中的校验值是否相同,如果是,执行步骤104;否则,执行步骤105。
步骤104,运行该软件产品,结束本流程。
步骤105,提示该软件产品的license异常。
本申请具体实现时,预先生成的license信息包括上文提到的校验值,用于防止软件产品被复制使用;还包括软件产品的运行时间限制值,以及当前该软件产品运行总时间。
在该硬件设备的系统盘选择一个不被使用的分区,并指定开始存储license信息位置开始存储所述license信息。
给出一种具体实现,但不限于该种实现方式:在系统盘尾部专门分配一个分区/dev/sdan,不格式化文件系统,从sdan指定的某位置pos扇区位置,开始记录license信息
在存储运行时间限制值时,将该时间限制值使用预设加密算法加密,将加密后的运行时间限制值作为license信息存储到所述裸盘中。
其中,使用的预设加密算法如base64。
运行时间限制值limit_time_days可以根据购买该软件产品的使用情况进行具体限制,如500天。
具体加密实现为:echo"500"|base64即使用base64加密算法生成加密数据NTAwCg==。
并且每次在使用软件产品时,需统计并记录该软件产品的总运行时间current_run_days。
则存储的license信息为:sn_md5_xor+limit_time_days+current_run_days。
下面结合附图,详细说明本申请实施例控制软件产品运行时间的过程。
参见图2,图2为本申请实施例中实现控制软件产品运行时间的流程示意图。具体步骤为:
步骤201,正在运行软件产品时,统计该软件产品的总运行时间。
每次运行软件产品时,将运行时间累加作为总运行时间,即周期性更新总运行时间。
步骤202,使用所述预设加密算法对应的预设解密算法解密所述加密后的运行时间限制值。
获取存储的加密后的运行时间限制值,使用对应的预设解密算法解密,获取运行时间限制值。
如echo"NTAwCg=="|base64–d,解压后数据,500。使用解密base64算法解密NTAwCg==获得运行时间限制值500。
步骤203,周期性确定当前软件产品的总运行时间是否大于运行时间限制值,如果是,执行步骤204;否则,执行步骤205。
步骤204,停止所述软件产品的运行,并提示该软件产品的license过期。结束本流程。
步骤205,继续运行该软件产品。
本申请具体实现时,校验license信息,或控制运行时间等,均由软件产品自行执行,仅将license信息存储到裸盘上即可。
综上所述,本申请通过利用硬件设备的系统盘的SN号唯一且无法修改的特性,按照预设算法预先生成校验值,存储到裸盘中,每次使用该软件产品时,获取使用该软件产品的系统盘的SN号,并使用同样的方法生成校验值,与存储的校验值比较,一致才能使用该软件产品。该技术方案不再以配置文件形式记录license信息,能够避免软件产品被复制使用的问题,即增加了软件产品使用的安全性。
并且通过将运行时间限制加密,并统计使用软件产品的时间,来严格控制软件产品运行的时间。
以上所述仅为本发明的较佳实施例而已,并不用以限制本发明,凡在本发明的精神和原则之内,所做的任何修改、等同替换、改进等,均应包含在本发明保护的范围之内。

Claims (7)

1.一种软件产品软件使用许可license信息设置方法,其特征在于,在硬件设备上安装软件产品时,获取硬件设备的系统盘的序列号SN号;使用该SN号按照预设算法生成该软件产品针对该硬件设备的校验值,并将该校验值作为license信息存储到该硬件设备的裸盘中;该方法包括:
当在该硬件设备上运行该软件产品时,获取该硬件设备的系统盘的SN号,并使用所述SN号按照预设算法生成该软件产品针对该硬件设备的校验值;
确定当前计算出的校验值与所述裸盘中的校验值是否相同,如果是,运行该软件产品;否则,提示该软件产品的license异常。
2.根据权利要求1所述的方法,其特征在于,所述使用该SN号按照预设算法生成该软件产品针对该硬件设备的校验值,包括:
通过消息摘要算法第五版MD5算法,生成所述系统盘的SN号的MD5值;
针对MD5值的每个字符换算为二进制并取反;将每个取反后的二进制数,并按对应字符在MD5值中的顺序组成新的字符串,作为该软件产品针对该硬件设备的校验值。
3.根据权利要求1所述的方法,其特征在于,所述使用该SN号按照预设算法生成该软件产品针对该硬件设备的校验值,包括:
通过MD5算法,生成所述系统盘的SN号的MD5值;
针对MD5值的每个字符换算为二进制并取反;将每个取反后的二进制数转换为16进制数,并按对应字符在MD5值中的顺序组成新的字符串,作为该软件产品针对该硬件设备的校验值。
4.根据权利要求1所述的方法,其特征在于,所述获取硬件设备的系统盘的SN号时,通过磁盘健康检测程序smartctl工具获取。
5.根据权利要求1所述的方法,其特征在于,所述方法进一步包括:
配置该软件产品在该硬件设备上的运行时间限制值;
将该时间限制值使用预设加密算法加密,将加密后的运行时间限制值作为license信息存储到所述裸盘中。
6.根据权利要求5所述的方法,其特征在于,所述方法进一步包括:
正在运行所述软件产品时,统计该软件产品的总运行时间;
周期性使用所述预设加密算法对应的预设解密算法解密所述加密后的运行时间限制值,并确定当前软件产品的总运行时间是否大于运行时间限制值,如果是,停止所述软件产品的运行,并提示该软件产品的license过期;否则,继续运行该软件产品。
7.根据权利要求1-6任意一项所述的方法,其特征在于,
将license信息存储到裸盘中,包括:
在该硬件设备的系统盘选择一个不被使用的分区,并指定开始存储license信息位置开始存储所述license信息。
CN201711388547.3A 2017-12-21 2017-12-21 一种软件产品license信息设置方法 Pending CN108460252A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201711388547.3A CN108460252A (zh) 2017-12-21 2017-12-21 一种软件产品license信息设置方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201711388547.3A CN108460252A (zh) 2017-12-21 2017-12-21 一种软件产品license信息设置方法

Publications (1)

Publication Number Publication Date
CN108460252A true CN108460252A (zh) 2018-08-28

Family

ID=63220343

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201711388547.3A Pending CN108460252A (zh) 2017-12-21 2017-12-21 一种软件产品license信息设置方法

Country Status (1)

Country Link
CN (1) CN108460252A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110825639A (zh) * 2019-11-08 2020-02-21 西安雷风电子科技有限公司 一种防篡改时间的软件License验证方法

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6134659A (en) * 1998-01-07 2000-10-17 Sprong; Katherine A. Controlled usage software
CN101968834A (zh) * 2009-07-28 2011-02-09 上海移为通信技术有限公司 电子产品的防抄板加密方法和装置
CN102236761A (zh) * 2010-04-27 2011-11-09 张云梯 一种软件防盗版中注册码生成方法
CN103268435A (zh) * 2013-04-25 2013-08-28 福建伊时代信息科技股份有限公司 内网许可生成方法及系统、内网许可保护方法及系统
CN106789006A (zh) * 2016-11-28 2017-05-31 范睿心 一种解密方法及系统

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6134659A (en) * 1998-01-07 2000-10-17 Sprong; Katherine A. Controlled usage software
CN101968834A (zh) * 2009-07-28 2011-02-09 上海移为通信技术有限公司 电子产品的防抄板加密方法和装置
CN102236761A (zh) * 2010-04-27 2011-11-09 张云梯 一种软件防盗版中注册码生成方法
CN103268435A (zh) * 2013-04-25 2013-08-28 福建伊时代信息科技股份有限公司 内网许可生成方法及系统、内网许可保护方法及系统
CN106789006A (zh) * 2016-11-28 2017-05-31 范睿心 一种解密方法及系统

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110825639A (zh) * 2019-11-08 2020-02-21 西安雷风电子科技有限公司 一种防篡改时间的软件License验证方法
CN110825639B (zh) * 2019-11-08 2023-01-31 西安雷风电子科技有限公司 一种防篡改时间的软件License验证方法

Similar Documents

Publication Publication Date Title
US8225105B2 (en) Method and apparatus for verifying integrity of computer system vital data components
CN101231622B (zh) 基于闪存的数据存储方法和设备、及数据读取方法和设备
EP3316160A1 (en) Authentication method and apparatus for reinforced software
CN107145802A (zh) 一种bios完整性度量方法、基板管理控制器和系统
US20170373853A1 (en) Managing user profiles securely in a user environment
CN109284585B (zh) 一种脚本加密方法、脚本解密运行方法和相关装置
CN110995720B (zh) 加密方法、装置、主机端及加密芯片
CN111783078A (zh) Android平台安全芯片控制系统
CN110659153A (zh) 纠错码存储器安全性
CN110659506A (zh) 基于密钥刷新对存储器进行重放保护
CN109753770A (zh) 确定烧录数据的方法及装置、烧录方法及装置、电子设备
EP2568655B1 (en) Method for authenticating a storage device, machine-readable storage medium, and host device
CN108460252A (zh) 一种软件产品license信息设置方法
CN108427889A (zh) 文件处理方法及装置
CN106203100A (zh) 一种完整性校验方法和装置
CN109189333B (zh) 一种硬盘适配的方法、装置及系统
CN107391970B (zh) Flash应用程序中的函数访问控制方法及装置
CN114172720A (zh) 一种密文攻击流量的检测方法及相关装置
JP2011123229A (ja) プログラムコード暗号化装置及びプログラム
US11310218B2 (en) Password streaming
CN109889372B (zh) 获取配置信息的方法、装置、设备及存储介质
CN108259490B (zh) 一种客户端校验方法及装置
CN108345803B (zh) 一种可信存储设备的数据存取方法及装置
CN114095175B (zh) 一种可灰度校验的数据保密方法、装置及存储介质
US10425233B2 (en) Method for automatically verifying a target computer file with respect to a reference computer file

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
CB02 Change of applicant information
CB02 Change of applicant information

Address after: 518057 Shenzhen Software Park, No. 9, 501, 502, Science and Technology Middle Road, Nanshan District, Shenzhen City, Guangdong Province

Applicant after: Shenzhen Innovation Technology Co., Ltd.

Address before: 518057 Shenzhen Software Park, No. 9, 501, 502, Science and Technology Middle Road, Nanshan District, Shenzhen City, Guangdong Province

Applicant before: UIT Storage Technology (Shenzhen) Co., Ltd.

RJ01 Rejection of invention patent application after publication
RJ01 Rejection of invention patent application after publication

Application publication date: 20180828