网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.看看你能过关吗-J2EE面试题集锦.
.基于.Net的AOP实现技术.
.初始化类时newInstance和new的区.
.错误的堆大小产生的 “堆问题”.
.深入探讨Iterator模式.
.java版的MD5.
.J2ME游戏开发中如何使用层的概念.
.回顾Java Beans.
.Motorola V180,V501,V600,C650等.
.上海某全球五百强面试题(嵌入式.
.JAVA中的指针,引用及对象的clone.
.JAVA正则表达式4种常用功能.
.用代码学习Spring:IoC、AOP.
.java 基础入门 pom.xml 元素描述.
.replace 方法.
.轻松掌握Java泛型(第4部分).
.对JAVA的多线程浅析.
.20分钟熟悉猛虎脾气----JDK1.5新.
.Java规则引擎工作原理及应用.
.JAVA学习,是一条漫长的道路.

用Java编写的密码算法类

发表日期:2008-1-5



  package data;

import Java.security.*;
import javax.crypto.*;
import javax.crypto.spec.*;
import java.io.*;

/**
* Security 提供了一个安全算法类,其中包括对称密码算法和散列算法
*/
public final class Security
{
/**
* 对称加密方法
* @param byteSource 需要加密的数据
* @return 经过加密的数据
* @throws Exception
*/
public static byte[] symmetricEncrypto(byte[] byteSource) throws Exception
{
ByteArrayOutputStream baos = new ByteArrayOutputStream();
try
{
int mode = Cipher.ENCRYPT_MODE;
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
byte[] keyData = {1, 9, 8, 2, 0, 8, 2, 1};
DESKeySpec keySpec = new DESKeySpec(keyData);
Key key = keyFactory.generateSecret(keySpec);
Cipher cipher = Cipher.getInstance("DES");
cipher.init(mode, key);
int blockSize = cipher.getBlockSize();
int position = 0;
int length = byteSource.length;
boolean more = true;
while(more)
{
if(position + blockSize <= length)
{
baos.write(cipher.update(byteSource, position, blockSize));
position += blockSize;
}
else
{
more = false;
}
}
if(position < length)
{
baos.write(cipher.doFinal(byteSource, position, length - position));
}
else
{
baos.write(cipher.doFinal());
}
return baos.toByteArray();
}
catch(Exception e)
{
throw e;
}
finally
{
baos.close();
}
}
/**
* 对称解密方法
* @param byteSource 需要解密的数据
* @return 经过解密的数据
* @throws Exception
*/
public static byte[] symmetricDecrypto(byte[] byteSource) throws Exception
{
ByteArrayOutputStream baos = new ByteArrayOutputStream();
try
{
int mode = Cipher.DECRYPT_MODE;
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
byte[] keyData = {1, 9, 8, 2, 0, 8, 2, 1};
DESKeySpec keySpec = new DESKeySpec(keyData);
Key key = keyFactory.generateSecret(keySpec);
Cipher cipher = Cipher.getInstance("DES");
cipher.init(mode, key);
int blockSize = cipher.getBlockSize();
int position = 0;
int length = byteSource.length;
boolean more = true;
while(more)
{
if(position + blockSize <= length)
{
baos.write(cipher.update(byteSource, position, blockSize));
上一篇:用Java编写扫雷游戏--算法思考 人气:1178
下一篇:中断Java线程 人气:765
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐