首页 > 解决方案 > java 7用重音解码base64字符串

问题描述

我在解码用 pl/sql 编码的字符串时遇到问题,用 oracle pl/sql 编码,像这样

SET SERVEROUTPUT ON DECLARE

l_vc_var1 VARCHAR2(32767):='nat=Assurés%20CNRPS';

l_rw_var2 RAW(32767);

BEGIN

dbms_output.put_line('Original string: '||l_vc_var1);

l_rw_var2:= utl_raw.cast_to_raw(l_vc_var1);

dbms_output.put_line('Original RAW string: '||l_rw_var2);

l_rw_var2:= utl_encode.base64_encode(l_rw_var2);

dbms_output.put_line('Encoded RAW string: '||l_rw_var2);

l_rw_var2:= utl_encode.base64_decode(l_rw_var2);

dbms_output.put_line('Decoded RAW string: '||l_rw_var2);

l_vc_var1:=utl_raw.cast_to_varchar2(l_rw_var2);

dbms_output.put_line('Decoded Original string: '||l_vc_var1);

END;

/

sqldeveloper 中的结果:

Original string: nat=Assurés%20CSS Original RAW string: 6E61743D4173737572E973253230435353 Encoded RAW string: 626D46305055467A6333567936584D6C4D6A424455314D3D Decoded RAW string: 6E61743D4173737572E973253230435353 Decoded Original string: nat=Assurés%20CSS

我想像这样用Java解码字符串:

try {
    String base64 = "6E61743D4173737572E973253230435353";
    BigInteger bi = new BigInteger(base64, 16);
    byte[] bdata = bi.toByteArray();

    String temp = new String(bdata, "UTF-8");
    System.out.println("temp =   " + temp);

} catch (Exception ex) {
    ex.printStackTrace();
}

不幸的是,java 结果的重音不正确:

temp = nat=Assur�s%20CSS

标签: java

解决方案


new String(bdata, "ISO-8859-1"), ISO 拉丁语-1。

"Windows-1252",MS Windows Latin-1,将是一个超集,并且可能被 SQLDeveloper 使用。


推荐阅读