Java加密和licence控制的设计

加密|控制|设计

 

1.版权声明

    本文是关于如何通过序列号来加载加密的class文件的阐述。   本文所提及的Resin hessian是Caucho公司的注册产品名称, 其版权规caucho所有。本文可以转载, 但是必须注明作者的Blog地址:http://blog.csdn.net/oldjavaman

2. 本文的适用对象

    作为技术人员,本文的技术细节涉及到Java语言的基础知识, 您在阅读前应该了解Java动态装载Class的机制,以及常规的Java加密的相关知识, 同时本文假定您已经具有开发web的基本能力, 了解jsp和servlet的运作过程。

3.怎样阅读

你可以在下面地址下载到本文所用到的Jar文件和加密工具http://www.collegesoft.com.cn/download/licenceClient_1.0.3.jar加密工具的下载:http://www.collegesoft.com.cn/download/encryption.exe关于序列号的生成部分, 鉴于保护公司产品的考虑就不再公开发布了, 有兴趣的同仁可以用mail和我交流。  

4. 概述

4.1. 加密Java源码的原因

  Java源代码经过编译以后在JVM中执行。由于JVM界面是完全透明的,Java类文件能够很容易通过反编译器重新转换成源代码。因此,所有的算法、类文件等都可以以源代码的形式被公开,使得软件不能受到保护,为了保护产权,一般可以有以下几种方法:   (1)"模糊"类文件,把文件的名称和方法换成000OOoo的方式,当然只要你有足够的耐心, 将这些编码转换成自己可以看懂的代码, 并非难事。   (2)流行的加密工具对源文件进行加密,比如PGP(Pretty Good Privacy)或GPG(GNU Privacy Guard)。这时,最终用户在运行应用之前必须先进行解密。但解密之后,最终用户就有了一份不加密的类文件,这和事先不进行加密没有什么差别。   (3)加密类文件,在运行中JVM用定制的类装载器(Class Loader)解密类文件。Java运行时装入字节码的机制隐含地意味着可以对字节码进行修改。JVM每次装入类文件时都需要一个称为ClassLoader的对象,这个对象负责把新的类装入正在运行的JVM。JVM给ClassLoader一个包含了待装入类(例如java.lang.Object)名字的字符串,然后由ClassLoader负责找到类文件,装入原始数据,并把它转换成一个Class对象。   用户下载的是加密过的类文件,在加密类文件装入之时进行解密,因此可以看成是一种即时解密器。由于解密后的字节码文件永远不会保存到文件系统,所以窃密者很难得到解密后的代码。    由于把原始字节码转换成Class对象的过程完全由系统负责,所以创建定制ClassLoader对象其实并不困难,只需先获得原始数据,接着就可以进行包含解密在内的任何转换。 

4.2. Java密码体系和Java密码扩展

   Java密码体系(JCA)和Java密码扩展(JCE)的设计目的是为Java提供与实现无关的加密函数API。它们都用factory方法来创建类的例程,然后把实际的加密函数委托给提供者指定的底层引擎,引擎中为类提供了服务提供者接口在Java中实现数据的加密/解密,是使用其内置的JCE(Java加密扩展)来实现的。Java密码体系结构支持供应商的互操作,同时支持硬件和软件实现。

4.3. 本文采用的方式

我们采用的是第三种方式, 将class文件加密作为产品的发行版本,但是为了让这个加密的方式可以在不同的项目里面使用, 又将这个解密的处理做成webservice的方式来进行.

5. 基本设计思想

这个过程可以划分成5个部分:

1)      将加密的class文件传递到webService里面.2)      由webService来查看Licence是里面, 是否有合法的信息, 譬如产品名称, 版本, 授权用户,已经过期时间等, 有此决定是否继续执行第3个步骤3)      如果一切验证通过, 将由webService返回一个解密的文件4)      由本地的webService来装载这个class对象, 5)      构造成一个class的instance   

6.那个文件应该被加密

   在以前, 尝试将自己的API进行加密, 但是作为API本身在公司内部发行, 这就要求我们每个programmer在编写代码的时候必须人手一个Licence才可以进行正常的工作, 为API的升级和维护也带来极大的不便, 为什么? 因为API不能作为一个Jar发布, 只能以class的方式来发布.   那么. 我们应该加密的是什么呢? 在我们设计web程序的时候, 一般的流程是, login 然后在session或cookie里面记录他的身份信息, 譬如她是一个什么样的用户, 是学生或者教师还是管理员, 同时, 我们要记录他具有什么权限, 每个权限的操作范围又是什么? 那么这个过程我们一般在用户登陆, 和数据库连接之后来进行的, 这是一个复杂的逻辑操作过程,, 加密这个方法是一个好的想法, 这样恶意的用户, 即使把所有的其他class文件用jad来还原, 也无济于事, 除非他可以猜出你在login的时候到底做了什么。 

7. 怎样加密自己的java文件

7.2.  文件的加密

   加密我们的文件, 我们采用的是JCE的算法来进行的, 具体的加密实现, 我再次不再叙述, 在google里面, 你可以获取n多的文章在描述这个JCE的用法, 对于我们的文件, 已经提供了一个windows的exe程序来之行,这个文件叫做encryption.exe你可以用如下命令来加密自己的文件
c:> encryption –encrypto myClass.class

 这样就可以把你的文件做成Jad等工具无法反编译的文件了。 

8. 从LicenceCenter获取的产品信息

无论再添加课程还是, 建立新的用户的时候, 您都可能会有一个需求, 我怎么知道自己的产品授权给这个用户什么样的信息呢, 是否允许他再建立一个课程或者添加一个客户? 我们提供的jar里面可以解决你的困惑:代码如下 
LicenceFactory licenceFactory=new LicenceFactory();        licenceFactory.getLicence("urProductName"); 

如果这个产品在验证中心没有注册序列号, 将返回null; 

9.程序需要增加什么配置

在licenceClient里面, 系统需要读取licenceCenter的地址, 在您的web应用发布的时候, 必须将webService的地址编写成环境变量, 在web.xml里面增加一段代码:
<env-entry>              <env-entry-name>licence_service_url</env-entry-name>                    <env-entry-value>http://192.168.2.212:8080/licenceCenter/LicenceService</env-entry-value>              <env-entry-type>java.lang.String</env-entry-type>       </env-entry>

 你可以将红色的部分放在你的web server上访问, 假设看到如下界面, 表示验证中心已经安装成功

10.关于验证中心的安装

验证中心的安装文件为 licenceService1.0.1.zip在你的操作系统里面解压在一个目录中。在你的Java web server里面配置一个应用, 譬如叫做:licenceCenter以Resin为例子:在httpd.conf里面加上一下代码:
<web-app id="demo" app-dir="E:/licencescenter/webapp">                            <servlet-mapping url-pattern='*.jsp'                                   servlet-name='com.caucho.jsp.JspServlet'/>         </web-app>

 其中在你的这个应用中的web.xml文件必须包含
<servlet servlet-name="LicenceService"      servlet-class="com.caucho.hessian.server.HessianServlet">    <init-param service-class="com.collegesoft.licence.LicenceService"/>    <init-param api-class="com.collegesoft.licence.LicenceServiceStub"/>  </servlet>  <servlet-mapping url-pattern="/LicenceService" servlet-name="LicenceService"/>

 

11. 常见问题

Q: 为什么不直接在webService里面加载好一个Class, 而是要在客户端来用classLoader来装载?A: 很多的程序员问过我这个问题,其实很简单, 你如果知道classloader的机制, 就知道假设你扩展login的实例用到你的另外一个对象, 譬如OnlineUser, 那么要在webService里面来装载你的类, 我就必须拥有你这个类, 但是webservice里面是不知道你未来是要用到什么类的。Q:为什么在redhat9上,访问验证中心会出现中文乱码问题?A:是由于redhat9的默认字符集不为GBK的缘故。一般采用将命令export LANG=zh_CN.GBK加在resin服务启动文件中。

时间: 2024-10-31 14:28:52

Java加密和licence控制的设计的相关文章

JAVA加密解密:自定义类加载器应用

最近在研究JAVA CLASS LOADING技术,已实现了一个自定义的加载器.对目前自定义加载器的应用,还在探讨中.下面是自定义的CLASSLOADER在JAVA加密解密方面的一些研究. JAVA安全 JAVA是解释执行的语言,对于不同的操作平台都有相应的JVM对字节码文件进行解释执行.而这个字节码文件,也就是我们平时所看到的每一个.class文件. 这是我们大家都知道的常识,也就是由.java文件,经过编译器编译,变成JVM所能解释的.class文件. 而这个过程,在现在公开的网络技术中,利

Java加密解密

JAVA是解释执行的语言,对于不同的操作平台都有相应的JVM对字节码文件进行解释执行.而这个字节码文件,也就是我们平时所看到的每一个.class文件.这是我们大家都知道的常识,也就是由.java文件,经过编译器编译,变成JVM所能解释的.class文件.而这个过程,在现在公开的网络技术中,利用一个反编译器,任何人都可以很容易的获取它的源文件.这对于很多人来说是不希望看到的.对于加密解密技术,我懂的不多,有些可以利用某种技术"模糊"JAVA类文件.这样能够使反编译的难度增加.但估计反编译

Java加密技术(一)——BASE64与单向加密算法MD5&amp;amp;SHA&amp;amp;MAC

 加密解密,曾经是我一个毕业设计的重要组件.在工作了多年以后回想当时那个加密.解密算法,实在是太单纯了.     言归正传,这里我们主要描述Java已经实现的一些加密解密算法,最后介绍数字证书.     如基本的单向加密算法:  BASE64 严格地说,属于编码格式,而非加密算法 MD5(Message Digest algorithm 5,信息摘要算法) SHA(Secure Hash Algorithm,安全散列算法) HMAC(Hash Message Authentication Cod

Java 高并发七:并发设计模型详解_java

1. 什么是设计模式 在软件工程中,设计模式(design pattern)是对软件设计中普遍存在(反复出现)的各种问题 ,所提出的解决方案.这个术语是由埃里希·伽玛(Erich Gamma)等人在1990年代从建筑设计领 域引入到计算机科学的. 著名的4人帮: Erich Gamma,Richard Helm, Ralph Johnson ,John Vlissides (Gof) <设计模式:可复用面向对象软件的基础>收录23种模式 2. 单例模式 单例对象的类必须保证只有一个实例存在.许

通过可视化继承和页面模板控制站点设计

继承|控制|模板|设计|页面|站点 作者:Fritz Onion相关技术:模板.ASP.NET,Master Pages难度:★★★☆☆读者类型:ASP.NET开发人员     [导读]本文首先介绍了在传统的Web开发下"模板"的实现,包括了ASP和ASP.NET 1.x的实现,然后介绍了ASP.NET 2.0下模板的实现方式--Master Pages,最后阐述了母版页的实现原理.     多年以来,Web开发人员一直在努力通过多种技术来"模板化"他们的站点,但没

Java加密技术(十)

在Java 加密技术(九)中,我们使用自签名证书完成了认证.接下来,我们使用第三方CA签名机构完成证书签名. 这里我们使用thawte提供的测试用21天免费ca证书. 1.要在该网站上注明你的域名,这里使用www.zlex.org作为测试用域名(请勿使用该域名作为你的域名地址,该域名受法律保护!请使用其他非注册域名!). 2.如果域名有效,你会收到邮件要求你访问https://www.thawte.com/cgi/server/try.exe获得ca证书. 3.复述密钥库的创建. Shell代码

Java加密技术(九)

在Java加密技术(八)中,我们模拟了一个基于RSA非对称加密网络的安全通信.现在我们深度了解一下现有的安全网络通信--SSL. 我们需要构建一个由CA机构签发的有效证书,这里我们使用上文中生成的自签名证书zlex.cer 这里,我们将证书导入到我们的密钥库. Shell代码 keytool -import -alias www.zlex.org -file d:/zlex.cer -keystore d:/zlex-client.keystore 其中 -import表示导入 -alias指定

Java加密技术(八)

本篇的主要内容为Java证书体系的实现. 请大家在阅读本篇内容时先阅读 Java加密技术(四),预先了解RSA加密算法. 在构建Java代码实现前,我们需要完成证书的制作. 1.生成keyStroe文件 在命令行下执行以下命令: Shell代码 keytool -genkey -alias www.zlex.org -keyalg RSA -keystore d:\zlex.keystore 其中 -genkey表示生成密钥 -alias指定别名,这里是www.zlex.org -keyalg指

Java加密技术(七)

ECC ECC-Elliptic Curves Cryptography,椭圆曲线密码编码学,是目前已知的公钥体制中,对每比特所提供加密强度最高的一种体制.在软件注册保护方面起到很大的作用,一般的序列号通常由该算法产生. 当我开始整理<Java加密技术(二)>的时候,我就已经在开始研究ECC了,但是关于Java实现ECC算法的资料实在是太少了,无论是国内还是国外的资料,无论是官方还是非官方的解释,最终只有一种答案--ECC算法在jdk1.5后加入支持,目前仅仅只能完成密钥的生成与解析. 尽管如