一个简单的加密解密方法(java、shell脚本)
加密,解密,密码,shell2016-11-23
最近项目中有个小的需求,配置文件中配置有DB密码,客户担心xml文件被非法窃取,所以要求配置文件中的密码是经过加密的。这就有个问题,常用的MD5加密,理论上是不可逆的。所以简单写了一个加密解密方法。
加密是使用的shell脚本,当然使用java代码也可以。作用就是运维人员输入原密码,生成加密后的密文。然后配置即可,程序中根据约定的解密方式去解读密文,还原为可用密码。这样即使配置文件被盗用也无法获知原密码。
解密方法如下:
	/**
	 * 解密
	 * @param param
	 * @return
	 */
	public static String AsciiToStr(String param) {
		String str = "";
		String asciiPsw=param;//字符串
		
		if (asciiPsw.length() > 10) {
			asciiPsw = asciiPsw.substring(10) + asciiPsw.substring(0, 10);
		}
		System.out.println("\n恢复原密码\n----------------------");
		// 密码位数
		Integer pswLength = asciiPsw.length()/3;
		for (int i = 0;i < pswLength;i++) {
			// 三位拆分、分别减101
			Integer intPsw = Integer.valueOf(asciiPsw.substring(3*i, 3*(i+1))) - 101;
			str = str + (char)Integer.parseInt(String.valueOf(intPsw));
		}
		return str;
	}
加密 shell脚本如下