在JDBC和&amp ;;之间插入postgreSQL函数时产生不同的结果格式控制台

时间:2018-05-08 15:29:22

标签: java sql postgresql jdbc bytea

在postgreSQL中,我使用 pgcrypto 模块调用 pgp_sym_encrypt 函数(返回bytea类型)并将结果保存到文本列中:

例如,我有测试表,列 columnA (文字):

CREATE EXTENSION pgcrypto;
insert into test (columnA) values (pgp_sym_encrypt('test','test'));

如果我在控制台中运行,结果类似于(转义二进制):

\303\015\004\007\003\002\022\261B\015\376\235\023\010j\3225\001\244l\253\332\026\037\\Q\305\253\365H\264\222\021\233\345\326\036Ma\346vwq\373\201\303\300\000\303\354\327:\017\020\036Q\201\025\210\364%\215$\017\304Y^_&\267

如果我在JDBC中运行,结果类似于(十六进制格式):

public class Main {
    public static void main(String[] args) throws Exception {
        Class.forName("org.postgresql.Driver");
        Connection connection = DriverManager.getConnection("jdbc:postgresql://localhost:5432/db", "postgres", "postgres");
        Statement stmt = connection.createStatement();
        String sql = "insert into test (columnA) values (pgp_sym_encrypt('test','test'))";
        stmt.executeUpdate(sql);
        connection.close();
    }
}

结果:

\xc30d040703026859a0885a496bc66bd240018d9cbede4805fc5b733afc706d061ae613600962222f008ab2fc4e99cc1c87841e3929833066ba42697784276c49efa67655a399fa9f77264769a42eb7c85e

如果我使用 pgp_sym_decrypt 进行解密,两者都可以流利地解密,但我想知道为什么结果会有不同的格式。如果我想要相同的格式,我该怎么办?

更新  我知道他们是逃脱的格式& hext格式可以设置为@Vao Tsun的答案。但我想知道为什么,我认为他们必须使用相同的默认格式? JDBC覆盖格式了吗?是否有针对此默认格式的JDBC配置,或者我必须在每个事务中调用set语句?

1 个答案:

答案 0 :(得分:2)

这是您的客户设置问题:

so=# set bytea_output to escape;
SET    
so=# select '\xc30d040703026859a0885a496bc66bd240018d9cbede4805fc5b733afc706d061ae613600962222f008ab2fc4e99cc1c87841e3929833066ba42697784276c49efa67655a399fa9f77264769a42eb7c85e'::bytea;
                                                                                                          bytea
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
 \303\015\004\007\003\002hY\240\210ZIk\306k\322@\001\215\234\276\336H\005\374[s:\374pm\006\032\346\023`\011b"/\000\212\262\374N\231\314\034\207\204\0369)\2030f\272Biw\204'lI\357\246vU\243\231\372\237w&Gi\244.\267\310^
(1 row)

Time: 0.487 ms
so=# set bytea_output to hex;
SET
Time: 2.134 ms
so=# select '\xc30d040703026859a0885a496bc66bd240018d9cbede4805fc5b733afc706d061ae613600962222f008ab2fc4e99cc1c87841e3929833066ba42697784276c49efa67655a399fa9f77264769a42eb7c85e'::bytea;
                                                                                bytea
----------------------------------------------------------------------------------------------------------------------------------------------------------------------
 \xc30d040703026859a0885a496bc66bd240018d9cbede4805fc5b733afc706d061ae613600962222f008ab2fc4e99cc1c87841e3929833066ba42697784276c49efa67655a399fa9f77264769a42eb7c85e
(1 row)

https://www.postgresql.org/docs/current/static/runtime-config-client.html#GUC-BYTEA-OUTPUT

  

设置bytea类型值的输出格式。有效值为十六进制   (默认)和escape(传统的PostgreSQL格式)。看到   第8.4节了解更多信息。 bytea类型始终接受两者   输入格式,无论此设置如何。

<强>更新

您可以为每个用户alter user vao set bytea_output to hex或每个数据库甚至每个群集设置此设置,不仅适用于会话或事务。如果你不想要,你绝对不必在每个陈述之前运行它。

关于jdbc是否有特定设置 - 我不知道,afaik你可以在连接字符串中传递客户端设置。

最后,如果您按用户/ db更改它,则需要重新连接以获得效果。 SET LOCAL/SESSION将立即克服此参数...