java数字加密代码,java实现一个数字加密器

java编写数字加密解密

加多一个判断,当输入的长度小于指定长度的时候,出错;

成都网站制作、成都做网站服务团队是一支充满着热情的团队,执着、敏锐、追求更好,是创新互联的标准与要求,同时竭诚为客户提供服务是我们的理念。成都创新互联公司把每个网站当做一个产品来开发,精雕细琢,追求一名工匠心中的细致,我们更用心!

如果超出指定长度,则取前几位,譬如指定6位,输入123, 出错;输入123456789,那就只处理123456,忽略后面的789

import java.util.HashMap;

import java.util.Map;

import java.util.Scanner;

public class Test {

public static void main(String[] args) throws Exception {

System.out.print("请输入加密(解密)和要处理的数字个数:1为加密,2为解密; ");

Scanner scanner = new Scanner(System.in);

String[] input1 = scanner.nextLine().split("\\s+");

String choice = input1[0];

int count = Integer.parseInt(input1[1]);

System.out.print("请输入要处理的数字,用空格隔开:");

String input = scanner.nextLine().replaceAll("\\s+", "");

if(input.length() count){

throw new Exception("不足" + count + "位数字,请检查输入");

}else if(input.length() count){

System.out.println("太多数字,将处理前" + count + "个数字:" +

input.substring(0, 6));

input = input.substring(0, 6);

}

if(choice.equals("1")){

if(input.length() count){

}

String encode = EncodeUtil.encode(input);

System.out.println("加密后的数字是: " + encode);

}else{

String decode = EncodeUtil.decode(input);

System.out.println("解密后的数字: " + decode);

}

}

}

class EncodeUtil{

private static MapString, String encodeMap = null;

private static MapString, String decodeMap = null;

public final static String encode(String strToEncode){

if(encodeMap == null){

encodeMap = new HashMapString, String();

encodeMap.put("0", "7");

encodeMap.put("1", "5");

encodeMap.put("2", "9");

encodeMap.put("3", "1");

encodeMap.put("4", "3");

encodeMap.put("5", "6");

encodeMap.put("6", "8");

encodeMap.put("7", "0");

encodeMap.put("8", "2");

encodeMap.put("9", "4");

}

StringBuilder sb = new StringBuilder();

for(int i = 0; i strToEncode.length(); i++){

sb.append(encodeMap.get(String.valueOf(strToEncode.charAt(i))));

}

return sb.toString();

}

public final static String decode(String strToDecode){

if(decodeMap == null){

decodeMap = new HashMapString, String();

decodeMap.put("7", "0");

decodeMap.put("5", "1");

decodeMap.put("9", "2");

decodeMap.put("1", "3");

decodeMap.put("3", "4");

decodeMap.put("6", "5");

decodeMap.put("8", "6");

decodeMap.put("0", "7");

decodeMap.put("2", "8");

decodeMap.put("4", "9");

}

StringBuilder sb = new StringBuilder();

for(int i = 0; i strToDecode.length(); i++){

sb.append(decodeMap.get(String.valueOf(strToDecode.charAt(i))));

}

return sb.toString();

}

}

------------------测试

C:\Program Files\IBM\RAD 7\jdk\binjava Test

请输入加密(解密)和要处理的数字个数:1为加密,2为解密; 1 6

请输入要处理的数字,用空格隔开:1 2 3

Exception in thread "main" java.lang.Exception: 不足6位数字,请检查输入

at Test.main(Test.java:19)

C:\Program Files\IBM\RAD 7\jdk\binjava Test

请输入加密(解密)和要处理的数字个数:1为加密,2为解密; 1 6

请输入要处理的数字,用空格隔开:1 2 3 4 5 6 7

太多数字,将处理前6个数字:123456

加密后的数字是: 591368

C:\Program Files\IBM\RAD 7\jdk\binjava Test

请输入加密(解密)和要处理的数字个数:1为加密,2为解密; 1 6

请输入要处理的数字,用空格隔开:1 9 9 7 7 1

加密后的数字是: 544005

C:\Program Files\IBM\RAD 7\jdk\binjava Test

请输入加密(解密)和要处理的数字个数:1为加密,2为解密; 2 6

请输入要处理的数字,用空格隔开:5 4 4 0 0 5

解密后的数字: 199771

用java做数字加密,思路如下:输入一个四位数,每位相加,1~9分别代表ASC中的a~i

import java.util.Scanner;

public class Encpryt {

public Encpryt() {

Scanner scan = new Scanner(System.in);

System.out.println("输入一个四位数:");

String str = scan.next();

while(str != "q"){

if (str.length()!=4) {

System.out.println("您输入的不是4位的数字请重新输入");

str = scan.next();

continue;

}

System.out.println("加密后的数是:");

char[] ns = new char[4];

for(int i = 0; i 4; i++){

ns[i] = str.charAt(i);

System.out.println(ns[i] -'0' + 'a' - 1);

}

System.out.println("输入一个四位数:");

str = scan.next();

}

}

/** * @param args

*/

public static void main(String[] args) {

new Encpryt();

}

}

java加密的几种方式

基本的单向加密算法:

BASE64 严格地说,属于编码格式,而非加密算法

MD5(Message Digest algorithm 5,信息摘要算法)

SHA(Secure Hash Algorithm,安全散列算法)

HMAC(Hash Message Authentication Code,散列消息鉴别码)

复杂的对称加密(DES、PBE)、非对称加密算法:

DES(Data Encryption Standard,数据加密算法)

PBE(Password-based encryption,基于密码验证)

RSA(算法的名字以发明者的名字命名:Ron Rivest, AdiShamir 和Leonard Adleman)

DH(Diffie-Hellman算法,密钥一致协议)

DSA(Digital Signature Algorithm,数字签名)

ECC(Elliptic Curves Cryptography,椭圆曲线密码编码学)

代码参考:

/**

* BASE64加密

*

* @param key

* @return

* @throws Exception

*/

public static String encryptBASE64(byte[] key) throws Exception {

return (new BASE64Encoder()).encodeBuffer(key);

}

/**

* MD5加密

*

* @param data

* @return

* @throws Exception

*/

public static byte[] encryptMD5(byte[] data) throws Exception {

MessageDigest md5 = MessageDigest.getInstance(KEY_MD5);

md5.update(data);

return md5.digest();

}

/**

* SHA加密

*

* @param data

* @return

* @throws Exception

*/

public static byte[] encryptSHA(byte[] data) throws Exception {

MessageDigest sha = MessageDigest.getInstance(KEY_SHA);

sha.update(data);

return sha.digest();

}

}

/**

* 初始化HMAC密钥

*

* @return

* @throws Exception

*/

public static String initMacKey() throws Exception {

KeyGenerator keyGenerator = KeyGenerator.getInstance(KEY_MAC);

SecretKey secretKey = keyGenerator.generateKey();

return encryptBASE64(secretKey.getEncoded());

}

/**

* HMAC加密

*

* @param data

* @param key

* @return

* @throws Exception

*/

public static byte[] encryptHMAC(byte[] data, String key) throws Exception {

SecretKey secretKey = new SecretKeySpec(decryptBASE64(key), KEY_MAC);

Mac mac = Mac.getInstance(secretKey.getAlgorithm());

mac.init(secretKey);

return mac.doFinal(data);

}

java最常用的几种加密算法

简单的Java加密算法有:

第一种. BASE

Base是网络上最常见的用于传输Bit字节代码的编码方式之一,大家可以查看RFC~RFC,上面有MIME的详细规范。Base编码可用于在HTTP环境下传递较长的标识信息。例如,在Java Persistence系统Hibernate中,就采用了Base来将一个较长的唯一标识符(一般为-bit的UUID)编码为一个字符串,用作HTTP表单和HTTP GET URL中的参数。在其他应用程序中,也常常需要把二进制数据编码为适合放在URL(包括隐藏表单域)中的形式。此时,采用Base编码具有不可读性,即所编码的数据不会被人用肉眼所直接看到。

第二种. MD

MD即Message-Digest Algorithm (信息-摘要算法),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一(又译摘要算法、哈希算法),主流编程语言普遍已有MD实现。将数据(如汉字)运算为另一固定长度值,是杂凑算法的基础原理,MD的前身有MD、MD和MD。

MD算法具有以下特点:

压缩性:任意长度的数据,算出的MD值长度都是固定的。

容易计算:从原数据计算出MD值很容易。

抗修改性:对原数据进行任何改动,哪怕只修改个字节,所得到的MD值都有很大区别。

弱抗碰撞:已知原数据和其MD值,想找到一个具有相同MD值的数据(即伪造数据)是非常困难的。

强抗碰撞:想找到两个不同的数据,使它们具有相同的MD值,是非常困难的。

MD的作用是让大容量信息在用数字签名软件签署私人密钥前被”压缩”成一种保密的格式(就是把一个任意长度的字节串变换成一定长的十六进制数字串)。除了MD以外,其中比较有名的还有sha-、RIPEMD以及Haval等。

第三种.SHA

安全哈希算法(Secure Hash Algorithm)主要适用于数字签名标准(Digital Signature Standard DSS)里面定义的数字签名算法(Digital Signature Algorithm DSA)。对于长度小于^位的消息,SHA会产生一个位的消息摘要。该算法经过加密专家多年来的发展和改进已日益完善,并被广泛使用。该算法的思想是接收一段明文,然后以一种不可逆的方式将它转换成一段(通常更小)密文,也可以简单的理解为取一串输入码(称为预映射或信息),并把它们转化为长度较短、位数固定的输出序列即散列值(也称为信息摘要或信息认证代码)的过程。散列函数值可以说是对明文的一种“指纹”或是“摘要”所以对散列值的数字签名就可以视为对此明文的数字签名。

SHA-与MD的比较

因为二者均由MD导出,SHA-和MD彼此很相似。相应的,他们的强度和其他特性也是相似,但还有以下几点不同:

对强行攻击的安全性:最显著和最重要的区别是SHA-摘要比MD摘要长 位。使用强行技术,产生任何一个报文使其摘要等于给定报摘要的难度对MD是^数量级的操作,而对SHA-则是^数量级的操作。这样,SHA-对强行攻击有更大的强度。

对密码分析的安全性:由于MD的设计,易受密码分析的攻击,SHA-显得不易受这样的攻击。

速度:在相同的硬件上,SHA-的运行速度比MD慢。

第四种.HMAC

HMAC(Hash Message Authentication Code,散列消息鉴别码,基于密钥的Hash算法的认证协议。消息鉴别码实现鉴别的原理是,用公开函数和密钥产生一个固定长度的值作为认证标识,用这个标识鉴别消息的完整性。使用一个密钥生成一个固定大小的小数据块,即MAC,并将其加入到消息中,然后传输。接收方利用与发送方共享的密钥进行鉴别认证等。

Java编程如何给数字加密

最简单的,用异或运算。

你也可以自己写个加密方法啊。

比如说:利用unicode字符加密啊。假设一个数字a它的unicode值是1234,你自己设计个函数,比如说y=2x^3+3,得到一个新的unicode字符,然后把这个unicode字符转换为字母,这个字母可能是汉字,但更可能是外国符文,反正一般人不会认出来的。你解密的时候,倒推一下就行了。


网页标题:java数字加密代码,java实现一个数字加密器
文章网址:http://pwwzsj.com/article/hddsij.html