Android HttpsURLConnection上送Base64过的图片遇到的奇葩问题

本文介绍了一个关于使用HttpsURLConnection上传图片时遇到的问题:客户端发送的Base64字符串中的'+'字符在服务端被误读为空格。通过对比新旧版本的代码,最终定位到字符编码的问题,并给出了具体的解决方案。

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

公司项目有个设置头像的功能,以前是用HttpClient通信,现改为HttpsURLConnection,结果设置完头像,再次登录时出现java.lang.IllegalArgumentException: bad base-64。上送图片的逻辑为先将图片转化成字节,然后 Base64.encodeToString(bytes, Base64.DEFAULT);再将它和其他参数组装成一个json字符串给服务器,服务器接收到后不做任何处理,直接存入数据库,当登录时,直接从数据库中取出返回,客户端再解码成图片。

先让服务端查了下接收的数据和返回的数据,没有任何问题,接收的数据和返回给我的数据都是一样的。于是看客户端的代码,也没发现有错误,虽然我确信优化时对原有的逻辑没有任何影响,但还是各种折腾各种日志打印。最后没法,拿老版本的一一对比,弄了半天,才发现用HttpsURLConnection客户端上送'+'(2B%),服务端接收到是‘ ’(空格20%),为了确认这问题,还特地写了个Demo,发现确实如此,当时直接崩溃了。这问题花了我整整两天时间....

解决方法:上送前对字符串做下replace("+", "%2B");处理

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值