java qp编码,java 编码 解码问题?

这个博客分享了一段Java代码,用于解码Quoted-Printable编码的字符串,这种编码常用于邮件和MHT文件中。博主提供了从Apache JCommons方法改写的qpDecoding函数,详细解释了其工作原理,并提供了异常处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

以下是根据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 "";

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值