从DB解密unicode文本

时间:2012-10-12 22:11:04

标签: java

当我尝试将加密的“密码文本”保存到SQL Server 2008r2数据库时,我遇到了问题。当我从java-Netbeans中保存时,sql收到“?????”在文本字段,我发现是因为或unicode ...我正在使用BLOWFISH加密(该类工作完美)但我不能解密它,因为我从DB“????”文本而不是原始文本(密码)

你知道我怎么能解决这个问题吗?一位朋友告诉他在DB上使用“varbinary”而不是“varchar”,但不知道怎么做:S

由于

public boolean SavetoDB() {
    DATABASE_CONNECTION con = new DATABASE_CONNECTION();
    cn = con.conectar();

    boolean resp = false;
    try {
        String sql = "INSERT INTO cliente(usuario, pass, Nombre, Apellido, Edad,"
                + "genero, Direccion, Telefono, Celular, img_name,tipo_cuenta, ipaddress, puerto,segundos,minutos,horas)"
                + " VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?,?,?,?,?,?)";
        PreparedStatement cmd = cn.prepareStatement(sql);
        cmd.setString(1, usuario);
        cmd.setString(2, pass);
        cmd.setString(3, Nombre);
        cmd.setString(4, Apellido);
        cmd.setInt(5, Edad);
        cmd.setString(6, genero);
        cmd.setString(7, Direccion);
        cmd.setInt(8, Telefono);
        cmd.setInt(9, Celular);
        cmd.setString(10, nombrearch);
        cmd.setString(11, tipo_cuenta);
        cmd.setString(12, ip);
        cmd.setString(13, puerto);
        cmd.setInt(14, 1);
        cmd.setInt(15, 0);
        cmd.setInt(16, 0);
        ////////////////////////////////////////////////////////
        ///////////////////////////////////////////////////////


        if (!cmd.execute()) {
            resp = true;
        }
        cmd.close();
        cn.close();
    } catch (Exception ex) {
        System.out.println("Error: " + ex.getMessage());
    }
    return resp;
}

SQL TABLE:

创建表cliente(

usuario varchar(15)not null primary key,

传递varchar(90)非空,

Nombre varchar(32)not null,

Apellido varchar(32)not null,

Edad int not null,

genero varchar(15)not null,

Direccion varchar(32),

Telefono int,

Celular int,

img_name varchar(32)not null,

tipo_cuenta varchar(15)not null,

fecha_creacion date,

ipaddress varchar(20)not null,

puerto varchar(30)not null,

segundos int not null,

minutos int not null,

horas int not null,

1 个答案:

答案 0 :(得分:1)

尝试在数据库中保存密码文本字节的md5 / sha摘要。当您需要检查密码时,请计算输入密码的摘要并与数据库中的密码进行比较。