java的quoted-printable解码器源代码

王朝java/jsp·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

以下是根据apache-jcommons里的一组方法改写的一个方法,使用它可以用来解quoted-printable编码的字符串,类似

=B9=E3=B6=AB=D2=BB=BA=DA=CD=F8=B0=C9=C9=EE=D2=B9=C6=F0=BB=F0=B4=

=F3=BB=F0 4=C8=CB=D4=E1=C9=ED=BB=F0=BA=A3

这种,一般常用在邮件中,IE保存的MHT文件中也使用了这种编码。在网上很难搜索到Java实现,所以在此提供。

public final String qpDecoding(String str)

{

if (str == null)

{

return "";

}

try

{

str = str.replaceAll("=\n", "");

byte[] bytes = str.getBytes("US-ASCII");

for (int i = 0; i < bytes.length; i++)

{

byte b = bytes[i];

if (b != 95)

{

bytes[i] = b;

}

else

{

bytes[i] = 32;

}

}

if (bytes == null)

{

return "";

}

ByteArrayOutputStream buffer = new ByteArrayOutputStream();

for (int i = 0; i < bytes.length; i++)

{

int b = bytes[i];

if (b == '=')

{

try

{

int u = Character.digit((char) bytes[++i], 16);

int l = Character.digit((char) bytes[++i], 16);

if (u == -1 l == -1)

{

continue;

}

buffer.write((char) ((u << 4) + l));

}

catch (ArrayIndexOutOfBoundsException e)

{

e.printStackTrace();

}

}

else

{

buffer.write(b);

}

}

return new String(buffer.toByteArray(), "GBK");

}

catch (Exception e)

{

e.printStackTrace();

return "";

}

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航