一、加密
加密函数代码:
public String Encrypt(String S, int Key) {
StringBuffer Result = new StringBuffer();
StringBuffer str;
int i, j;
for (i = 0; i < S.length(); i++) {
// 依次对字符串中各字符进行操作
Result.append((char) (S.charAt(i) ^ (Key >> 8))); // 将密钥移位后与字符异或
Key = ((byte) Result.charAt(i) + Key) * C1 + C2; // 产生下一个密钥
}
S = Result.toString();
System.out.println("密文中间值:" + S);
Result = new StringBuffer();
for (i = 0; i < S.length(); i++) // 对加密结果进行转换
{
j = (int) S.charAt(i); // 提取字符
// 将字符转换为两个字母保存
str = new StringBuffer(); // 设置str长度为2
str.append((char) (65 + j / 26));//这里将65改大点的数例如256,密文就会变乱码,效果更好,相应的,解密处要改为相同的数
str.append((char) (65 + j % 26));
Result.append(str);
}
return Result.toString();
}
二、解密
解密函数代码:
public String Decrypt(String S, int Key) {
StringBuffer Result = new StringBuffer();
StringBuffer str;
int i, j;
for (i = 0; i < S.length() / 2; i++) // 将字符串两个字母一组进行处理
{
j = ((int) S.charAt(2 * i) - 65) * 26;//相应的,解密处要改为相同的数
j += (int) S.charAt(2 * i + 1) - 65;
Result.append((char) j);
}
S = Result.toString(); // 保存中间结果
System.out.println("原文中间值:" + S);
Result = new StringBuffer();
for (i = 0; i < S.length(); i++) // 依次对字符串中各字符进行操作
{
Result.append((char) (S.charAt(i) ^ (Key >> 8))); // 将密钥移位后与字符异或
Key = ((byte) S.charAt(i) + Key) * C1 + C2; // 产生下一个密钥
}
return Result.toString();
}
三、参数
代码:
private int C1 = 52845;
private int C2 = 22719;
四、结合到音乐管理系统
登录的界面代码:
System.out.print("请输入用户名:");
String username = input.next();
System.out.print("请输入密码:");
String password=input.next();
System.out.println("用户名"+username + "密码:"+password);
user= userDao.loges(username,password);
if (user!=null) {
musicService.getMenu(user);
flas=false;
}
else {
musicService.zhuce();
flas=false;
}
}
函数代码:
public User loges(String username,String password) throws SQLException {
Connection connection=DBUtil.getConnection();
String sql="select password,type from tb_user where username=?";
PreparedStatement statement=connection.prepareStatement(sql);
statement.setString(1,username);
ResultSet resultSet = statement.executeQuery();
User user=new User();
while (resultSet.next()){
String ps=resultSet.getString(1);
String decrypt = Decrypt(ps, 1);
if(password.equals(decrypt)){
user.setUsername(username);
user.setPassword(password);
user.setType(resultSet.getInt(2));
}
}
if(resultSet.next())
return user;
else{
user=null;
}
System.out.println(user);
return user;
}
登录里面需要对之前加密的密码进行解密,所以sql语句需要进行修改。
注册界面代码:
public void zhuce() throws SQLException {
Scanner input=new Scanner(System.in);
MusicDao musicDao=new MusicDao();
UserDao userDao = new UserDao();
System.out.println("---------------登录失败---------------");
System.out.println("---------------请先注册---------------");
System.out.print("请输入注册名:");
String zcm = input.next();
System.out.print("请输入密码:");
String zcmm1 = input.next();
System.out.print("请确认密码:");
String zcmm2 = input.next();
System.out.print("请选择权限(0.管理员 1.普通用户):");
int js=input.nextInt();
Boolean flag;
if (zcmm1.equals(zcmm2) && (js==0 || js==1)) {
zcmm1=userDao.Encrypt(zcmm1,1);
flag = userDao.zhuce(zcm, zcmm1,js);
if (flag) {
System.out.println("---------------注册成功---------------");
} else {
System.out.println("---------------注册失败---------------");
}
System.out.print("是否登录(Y/N):");
String pd=input.next();
if(pd.equals("N")){
System.exit(0);
}
else if(!pd.equals("Y")){
System.exit(0);
}
else{
User user=new User();
user.setUsername(zcm);
user.setPassword(zcmm1);
user.setType(js);
getMenu(user);
}
}
else {
System.out.println("注册密码错误,请重新输入!");
}
}
加密是直接将输入的密码进行加密,然后传入添加函数。