然后是应用加密技术,该技术是应用系统通过加密API对敏感数据进行加密,将加密数据存储到数据库的底层文件中;在进行数据检索时,将密文数据取回到客户端,再进行解密,应用系统自行管理密钥体系。
其次是文件系统加解密技术,该技术不与数据库自身原理融合,只是对数据存储的载体从 *** 作系统或文件系统层面进行加解密。这种技术通过在 *** 作系统中植入具有一定入侵性的“钩子”进程,在数据存储文件被打开的时候进行解密动作,在数据落地的时候执行加密动作,具备基础加解密能力的同时,能够根据 *** 作系统用户或者访问文件的进程ID进行基本的访问权限控制。
最后后置代理技术,该技术是使用“视图”+“触发器”+“扩展索引”+“外部调用”的方式实现数据加密,同时保证应用完全透明。核心思想是充分利用数据库自身提供的应用定制扩展能力,分别使用其触发器扩展能力、索引扩展能力、自定义函数扩展能力以及视图等技术来满足数据存储加密,加密后数据检索,对应用无缝透明等核心需求。安华金和的加密技术在国内是唯一支持TDE的数据库加密产品厂商。
你的问题很不清晰。java jdbc连接mysql数据库
如何实现用户名密码以及传输数据的加密
你是要加密保存的数据,还是加密连接信息?
如果是连接串中的用户名与密码进行加密。恐怕用起来很不方便。
我就当你是要把入库的信息加密。
下边是DES加密的方法。将数据进行DES加密,将加密内容转为16进制内容表示。
--------------------------------------------------------------------------------------------
import javax.crypto.Cipher
import javax.crypto.spec.SecretKeySpec
public class DesTest {
public static void main(String[] args) throws Exception {
// 要加密的数据
String str = "123456"
// 密钥
String strKey = "86337898"
SecretKeySpec key = new SecretKeySpec(strKey.getBytes(), "DES")
Cipher cipher = Cipher.getInstance("DES")
cipher.init(Cipher.ENCRYPT_MODE, key)
byte[] byteFina = cipher.doFinal(str.getBytes())
String strFinal = byte2Hex(byteFina)
System.out.println(strFinal)
cipher.init(Cipher.DECRYPT_MODE, key)
byte[] decByte = hex2Byte(strFinal)
byte[] result = cipher.doFinal(decByte)
System.out.println(new String(result))
}
public static String byte2Hex(byte[] buff) {
String hs = ""
for (int i = 0i <buff.lengthi++) {
String stmp = (Integer.toHexString(buff[i] &0XFF))
if (stmp.length() == 1)
hs = hs + "0" + stmp
else
hs = hs + stmp
}
return hs
}
public static byte[] hex2Byte(String str) {
int len = str.length() / 2
byte[] buff = new byte[len]
int index = 0
for (int i = 0i <str.length()i += 2) {
buff[index++] = (byte) Integer
.parseInt(str.substring(i, i + 2), 16)
}
return buff
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)