在java快速和简单的字符串加密/解密问题,怎么解决
2个回答
展开全部
public class Test {
public static void main(String[] args) throws Exception {
String a = "在java快速和简单的字符串加密/解密问题,怎么解决";
System.out.println("原字符串: " + a);
String b = deal(a, (byte) 88); // 88 为加密密钥
System.out.println("加密后字符串: " + b);
String c = deal(b, (byte) 88); // 88 为解密密钥,要和加密一致,否则无法解密
System.out.println("解密后字符串: " + c);
}
/**
* 简单加密加密解密字符串<br/>
* 加密解密思路:先将字符串变成byte数组,再将数组每位与key做位运算,得到新的数组就是加密或解密后的byte数组.<br/>
* 知识:^ 是java位运算,可以百度了解下,a = b ^ skey 反之也成立,即b = a ^ skey
* @param str 解密/加密 字符串
* @param skey 解密/加密 密钥(加密解密为同一个密钥才能解密,否则是乱码)
* @return
* @throws Exception
*/
static String deal(String str, byte skey) throws Exception {
byte[] bytes = str.getBytes("GBK");
for (int i = 0; i < bytes.length; i++) {
bytes[i] = (byte) (bytes[i] ^ skey);
}
return new String(bytes, "GBK");
}
}
展开全部
public class Enande {
/**
* @param sourceString
* @param password
* @return 密文
*/
public static String encrypt(String sourceString, String password) {
char[] p = password.toCharArray(); // 字符串转字符数组
int n = p.length; // 密码长度
char[] c = sourceString.toCharArray();
int m = c.length; // 字符串长度
for (int k = 0; k < m; k++) {
int mima = c[k] + p[k / n]; // 加密
c[k] = (char) mima;
}
return new String(c);
}
/**
* @param sourceString
* @param password
* @return 明文
*/
public static String decrypt(String sourceString, String password) {
char[] p = password.toCharArray(); // 字符串转字符数组
int n = p.length; // 密码长度
char[] c = sourceString.toCharArray();
int m = c.length; // 字符串长度
for (int k = 0; k < m; k++) {
int mima = c[k] - p[k / n]; // 解密
c[k] = (char) mima;
}
return new String(c);
}
/*
* 使用例子
*/
public static void main(String arg[]) {
String wen = "这只是一个随便的字符串";
String pass = "1998";
System.out.println(encrypt(wen, pass));
System.out.println(decrypt(encrypt(wen, pass), pass));
}
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询