license文件生成原理
- 现在很多J2EE应用都采用一个license文件来授权系统的使用,特别是在系统购买的早期,会提供有限制的license文件对系统进行限制,比如试用版有譬如IP、日期、最大用户数量的限制等。
- 而license控制的方法又有很多,目前比较流行,只要设计的好就很难破解的方法就是采用一对密匙(私匙加密公匙解密)来生成License文件中的Sinature签名内容,再通过Base64或Hex来进行编码。比如原BEA公司现在是Oracle公司的WebLogic就采用的是这种方法来设置License文件。
- 这里只进行一个比较简单的实现:
- 一共三个类:
- A.KeyGenerater类生成公钥私钥对
- B.Signaturer类使用私钥进行签名
- C.SignProvider类用公钥验证
- 公钥和私钥使用Base64加密Base64这个类很多地方都可以查到。
- KeyGenerater类:
- public class KeyGenerater {
- private byte[] priKey;
- private byte[] pubKey;
- public void generater() {
- try {
- KeyPairGenerator keygen = KeyPairGenerator .getInstance("RSA");
- SecureRandom secrand = new SecureRandom();
- secrand.setSeed("www.川江号子.cn".getBytes()); // 初始化随机产生器
- keygen.initialize(1024, secrand);
- KeyPair keys = keygen.genKeyPair();
- PublicKey pubkey = keys.getPublic();
- PrivateKey prikey = keys.getPrivate()
- pubKey = Base64.encodeToByte(pubkey.getEncoded());
- priKey = Base64.encodeToByte(prikey.getEncoded());
- System.out.println("pubKey = " + new String(pubKey));
- System.out.println("priKey = " + new String(priKey));
- } catch (java.lang.Exception e) {
- System.out.println("生成密钥对失败");
- e.printStackTrace();
- }
- }
- public byte[] getPriKey() {
- return priKey;
- }
- public byte[] getPubKey() {
- return pubKey;
- }
- }
- Signaturer 类:
- public class Signaturer {
- public static byte[] sign(byte[] priKeyText, String plainText) {
- try {
- PKCS8EncodedKeySpec priPKCS8 = new PKCS8EncodedKeySpec(Base64.decode(priKeyText));
- KeyFactory keyf = KeyFactory.getInstance("RSA");
- PrivateKey prikey = keyf.generatePrivate(priPKCS8);
- // 用私钥对信息生成数字签名
- Signature signet = java.security.Signature.getInstance("MD5withRSA");
- signet.initSign(prikey);
- signet.update(plainText.getBytes());
- byte[] signed = Base64.encodeToByte(signet.sign());
- return signed;
- } catch (java.lang.Exception e) {
- System.out.println("签名失败");
- e.printStackTrace();
- }
- return null;
- }
- }
- SignProvider 类:
- public class SignProvider {
- private SignProvider() {
- }
- public static boolean verify(byte[] pubKeyText, String plainText,
- byte[] signText) {
- try {
- // 解密由base64编码的公钥,并构造X509EncodedKeySpec对象
- X509EncodedKeySpec bobPubKeySpec = new X509EncodedKeySpec(Base64.decode(pubKeyText));
- // RSA对称加密算法
- KeyFactory keyFactory = KeyFactory.getInstance("RSA");
- // 取公钥匙对象
- PublicKey pubKey = keyFactory.generatePublic(bobPubKeySpec);
- // 解密由base64编码的数字签名
- byte[] signed = Base64.decode(signText);
- Signature signatureChecker = Signature.getInstance("MD5withRSA");
- signatureChecker.initVerify(pubKey);
- signatureChecker.update(plainText.getBytes());
- // 验证签名是否正常
- if (signatureChecker.verify(signed))
- return true;
- else
- return false;
- } catch (Throwable e) {
- System.out.println("校验签名失败");
- e.printStackTrace();
- return false;
- }
- }
- }
license文件生成原理的更多相关文章
- 用php生成一个excel文件(原理)
1.我们用php来生成一个excel文档来讲述其原理: excel2007里面的文档目录组成部分为: 2.我们使用ZipArchive()方法来生成一个简易的excel文件. 使用方法: 3.代码如下 ...
- Java提高篇——JVM加载class文件的原理机制
在面试java工程师的时候,这道题经常被问到,故需特别注意. 1.JVM 简介 JVM 是我们Javaer 的最基本功底了,刚开始学Java 的时候,一般都是从“Hello World ”开始的,然后 ...
- 软硬链接、文件删除原理、linux中的三种时间、chkconfig优化
第1章 软硬链接 1.1 硬链接 1.1.1 含义 多个文件拥有相同的inode号码 硬链接即文件的多个入口 1.1.2 作用 防止你误删除文件 1.1.3 如何创建硬链接 ln 命令,前面是源文件 ...
- phpcms模板生成原理
phpcms模板生成原理2009-09-25 16:14PHPCMS是功能强大的网站管理系统.以后有时间,俺要将其管理.使用.再开发等等都理顺出来.这一篇短文先介绍PHPCMS的模板机制. 所谓网站模 ...
- 【Unity游戏开发】tolua之wrap文件的原理与使用
本文内容转载自:https://www.cnblogs.com/blueberryzzz/p/9672342.html .非常感谢原作者慷慨地授权转载,比心!@blueberryzzz 是位大神,欢迎 ...
- tolua之wrap文件的原理与使用
什么是wrap文件 每个wrap文件都是对一个c#类的包装,在lua中,通过对wrap类中的函数调用,间接的对c#实例进行操作. wrap类文件生成和使用的总体流程 生成一个wrap文件的流程 这部分 ...
- 【转载】tolua之wrap文件的原理与使用
什么是wrap文件 每个wrap文件都是对一个c#类的包装,在lua中,通过对wrap类中的函数调用,间接的对c#实例进行操作. wrap类文件生成和使用的总体流程 生成一个wrap文件的流程 这部分 ...
- JVM加载class文件的原理机制(转)
JVM加载class文件的原理机制 1.Java中的所有类,必须被装载到jvm中才能运行,这个装载工作是由jvm中的类装载器完成的,类装载器所做的工作实质是把类文件从硬盘读取到内存中 2.java中的 ...
- FastDFS分布式文件系统设计原理
转载自http://blog.chinaunix.net/uid-20196318-id-4058561.html FastDFS是一个开源的轻量级分布式文件系统,由跟踪服务器(tracker ser ...
随机推荐
- 监听UITabBarItem来拦截是否要跳转
情景是这样的: 我需要在用户点击"我的"的时候, 判断是否已经登录, 如果没有, 就不进入该界面, 而是跳转到用户登录界面, 所以这里我需要进行UITabBarItem点击事件的拦 ...
- Swift - 41 - swift1.2新特性(2)
swift 和 OC 的桥接 //: Playground - noun: a place where people can play import UIKit var PI = "3.14 ...
- PHP防注入转义功能
PHP addslashes() 函数 $str = addslashes('Shanghai is the "biggest" city in China.'); echo($s ...
- 在Eclipse中编译maven项目出的问题
在Eclipse中编译Maven项目,运行 jetty:run 指令的时候会出错,在 JRE选项卡中加入: -Dorg.mortbay.util.URI.charset=GBK-Xms512m -Xm ...
- C++朝花夕拾【更新】
C++拾遗 更新一些平时遇到的小细节: 1.关于类的无参构造函数和带有全部默认参考值的构造函数的区别 书上说的是带有全部默认值的构造函数就是无参构造函数,私以为不以为然,来看下边这个例子: #incl ...
- Yandex 2013Q(Atoms: There and Back Again-贪心+模拟+List)
Atoms: There and Back Again Time limit 2 seconds Memory limit 256Mb Input stdin Output stdout Legend ...
- 外国高手画神级的linux 内核图,够详细!
- onchar
void CMfcView::OnChar(UINT nChar, UINT nRepCnt, UINT nFlags)//Windows响应函数 { // TODO: Add your messag ...
- PHPCMS V9 简单的二次开发
更多二次开发技巧,查看phpcms系统帮助 ,前台模板解析后的缓存 caches\caches_template\default 前台控制类index.php,前台标签类*_tag.class.php ...
- 大整数算法[11] Karatsuba乘法
★ 引子 前面两篇介绍了 Comba 乘法,最后提到当输入的规模很大时,所需的计算时间会急剧增长,因为 Comba 乘法的时间复杂度仍然是 O(n^2).想要打破乘法中 O(n^2) ...