TrueLicense简介

简介: 原文 TrueLicense是一个开源的证书管理引擎,官网 使用场景:当项目交付给客户之后用签名来保证客户不能随意使用项目 默认校验了开始结束时间,可扩展增加mac地址校验等。 其中还有ftp的校验没有尝试,本文详细介绍的是本地校验 license授权机制的原理: 生成密钥对,方法有很多。

原文
TrueLicense是一个开源的证书管理引擎,官网
使用场景:当项目交付给客户之后用签名来保证客户不能随意使用项目
默认校验了开始结束时间,可扩展增加mac地址校验等。
其中还有ftp的校验没有尝试,本文详细介绍的是本地校验

license授权机制的原理:

  1. 生成密钥对,方法有很多。
  2. 授权者保留私钥,使用私钥对包含授权信息(如使用截止日期,MAC地址等)的license进行数字签名。
  3. 公钥给使用者(放在验证的代码中使用),用于验证license是否符合使用条件。

使用keytool生成密钥对

以下命令在dos命令行执行,注意当前执行目录,最后生成的密钥对即在该目录下:

  1. 首先要用KeyTool工具来生成私匙库:(-alias别名 –validity 3650表示10年有效)
    keytool -genkey -alias privatekey -keystore privateKeys.store -validity 3650
  2. 然后把私匙库内的公匙导出到一个文件当中:
    keytool -export -alias privatekey -file certfile.cer -keystore privateKeys.store
  3. 然后再把这个证书文件导入到公匙库:
    keytool -import -alias publiccert -file certfile.cer -keystore publicCerts.store
    最后生成文件privateKeys.store、publicCerts.store拷贝出来备用。

使用LicenseCreate来生成需要的数字签名

配置文件说明:
PRIVATEALIAS:对应生成的私匙库名称别名alias privatekey
KEYPWD:该密码生成密钥对的密码,生成密钥对时录入的密码
STOREPWD:该密码是在使用keytool生成密钥对时设置的密钥库的访问密码
SUBJECT:生成的签名主题
licPath:生成的签名文件存放路径
priPath:使用的私匙库文件路径
剩下的为签名文件中的内容配置
其中consumerType和ConsumerAmount不明确如何使用

扩展签名文件中的自定义字段

   //在CreateLicense#createLicenseContent方法中
   // Extra中可以存储扩展的字段,校验时读取该信息即可
   content.setExtra(new Object()); 

使用LicenseVerify来验证签名

配置文件说明:
PUBLICALIAS:对应生成的公匙库别名alias publiccert
STOREPWD:该密码生成密钥对的密码,生成密钥对时录入的密码
SUBJECT:校验的签名主题
licPath:校验的签名文件存放路径
pubPath:使用的公匙库文件路径

扩展字段校验
修改cn.melina.license.VerifyLicense中verify方法

    public boolean verify() {
        /************** 证书使用者端执行 ******************/
        boolean result = true;
        LicenseManager licenseManager = LicenseManagerHolder
                .getLicenseManager(initLicenseParams());
        // 安装证书
        try {
            licenseManager.install(new File(licPath));
        } catch (Exception e) {
            e.printStackTrace();
            return false;
        }
        // 验证证书
        try {
            //使用LicenseContent来接收默认校验的返回值,返回值为签名内容,进行二次校验
            LicenseContent licenseContent = licenseManager.verify();
            //扩展验证,非扩展验证可从licenseContent中获取
            Map<String,String> content = (Map<String, String>) licenseContent.getExtra();
            String targetMac = content.get("mac");
            //此处用于存储最大用户数
            String maxUserCount = content.get("maxUserCount");
            result = validateMacAddress(targetMac);
        } catch (Exception e) {
            e.printStackTrace();
            result = false;
        }
        return result;
    }


 

来自为知笔记(Wiz)


     

     

     

    本文转载自:http://blog.csdn.net/luckymelina/article/details/22870665

    目录
    相关文章
    |
    Prometheus 监控 前端开发
    prometheus|云原生|grafana-9.4.3版本的主题更改
    prometheus|云原生|grafana-9.4.3版本的主题更改
    1123 0
    hutool验证是否为中文字、英文字母、数字和下划线
    hutool验证是否为中文字、英文字母、数字和下划线
    |
    SQL XML Java
    【mybatis】第二篇:@Select注解中加入字段判断
    【mybatis】第二篇:@Select注解中加入字段判断
    |
    Java 数据安全/隐私保护 开发者
    SpringBoot整合TrueLicense生成和验证License证书
    TrueLicense生成和验证License证书
    2988 1
    |
    12月前
    |
    JSON 前端开发 Java
    Spring MVC——传递参数
    本文介绍了在Spring框架中如何传递参数的方法,包括传递单个参数、多个参数、参数重命名、传递数组和集合以及JSON数据。对于单个参数,可以直接在方法中声明;多个参数无需关注传递顺序,只需确保参数名对应。使用`@RequestParam`注解可实现参数重命名,而传递数组和集合时需注意数据类型的转换。最后,通过`@RequestBody`注解可以处理JSON格式的数据,实现复杂对象的传递。
    700 1
    Spring MVC——传递参数
    |
    12月前
    |
    存储 缓存 安全
    https访问提示不安全,证书密钥验证上如何解决
    【10月更文挑战第4天】访问提示不安全,证书密钥验证上如何解决
    1385 2
    |
    IDE 编译器 开发工具
    Cython 模块之间的相互导入,组织你的 Cython 代码
    Cython 模块之间的相互导入,组织你的 Cython 代码
    191 0
    |
    监控 Java 测试技术
    代码更新不停机:Spring Boot应用实现零停机更新的新质生产力
    【8月更文挑战第14天】在快节奏的软件开发与运维环境中,应用的持续部署与更新成为了提升竞争力的关键。传统的停机更新方式不仅影响用户体验,还可能造成业务中断和数据丢失。因此,实现Spring Boot应用的零停机更新成为了现代软件开发团队追求的目标。本文将深入探讨如何通过一系列技术和策略,在不影响服务可用性的前提下,实现Spring Boot应用的平滑升级。
    1074 2
    |
    JavaScript 前端开发 Java
    SpringBoot 引入 smart-doc 接口文档管理插件,以及统一接口返回,最后推送到 Torna,进行统一管理
    本文介绍了如何在SpringBoot项目中整合smart-doc接口文档管理插件,实现接口文档的生成和统一管理,并展示了如何将文档推送到Torna接口文档管理系统进行进一步的集中管理。
    1169 0
    SpringBoot 引入 smart-doc 接口文档管理插件,以及统一接口返回,最后推送到 Torna,进行统一管理
    |
    存储 Java Spring
    SpringBoot异步任务获取HttpServletRequest
    这样的操作对于保持异步操作中的请求上下文十分有用,特别是当你需要在日志记录、权限检查或者其他需要请求信息的场景中。确保上下文的正确传递和管理对于构建可靠的,异步处理能力很强的Spring Boot应用至关重要。
    792 3