base64编码发送到服务端需要URLEncode

本文描述了在Android端应用OCR算法时,使用base64编码将图片转化为字符串发送到服务器过程中出现的问题及解决方案。主要问题是由于未对特殊字符进行URLEncode,导致服务器端解码失败。文章提供了正确的URLEncode和URLDecoded方法。

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

最近在做手机端app的ocr算计集成的时候,遇到android端对jpg图片进行base64编码的大坑,android端的base64编码发送到server端,base64 encode字符串竟然发送了改变,什么,竟然这么坑

1.android端请求python搭建的server

android自带的base64对bitmap进行encode,然后发送到server,server端收到base64字符串后decode失败了,无法转为jpg图片,后面经过server端的接收base64 encode字符串和android端发送的base64 encode字符串进行比对,发现二者不一样,部分‘=’号被空格代替了。

2. 解决办法

发送给服务端的请求中的参数值,如果含有特殊符号,需要是做URLEncode,服务端才可以正常解析,否则可能会出错。

URLEncode主要是把一些特殊字符转换成转移字符,比如:&要转换成&这样的。

如果不转换,可能会在运行时直接报错。

如果全部转换,也会报错,因为会把其中非参数的部分也给转换了。

所以要确保只有参数部分被转换。

转换方式:

public static String toURLEncoded(String paramString) {
        if (paramString == null || paramString.equals("")) {
            LogD("toURLEncoded error:"+paramString);
            return "";
        }
        
        try
        {
            String str = new String(paramString.getBytes(), "UTF-8");
            str = URLEncoder.encode(str, "UTF-8");
            return str;
        }
        catch (Exception localException)
        {
            LogE("toURLEncoded error:"+paramString, localException);
        }
        
        return "";
    }


返回的参数的转换:

public static String toURLDecoded(String paramString) {
        if (paramString == null || paramString.equals("")) {
            LogD("toURLDecoded error:"+paramString);
            return "";
        }
        
        try
        {
            String str = new String(paramString.getBytes(), "UTF-8");
            str = URLDecoder.decode(str, "UTF-8");
            return str;
        }
        catch (Exception localException)
        {
            LogE("toURLDecoded error:"+paramString, localException);
        }
        
        return "";
    }

参考链接:https://blog.csdn.net/a102111/article/details/40978541

### BP工具 URL 编码方法及相关解决方案 Burp Suite(简称BP)是一款功能强大的Web安全测试工具,广泛用于渗透测试和漏洞分析。其核心组件之一是Proxy模块,允许用户拦截、修改HTTP/HTTPS流量并执行各种操作,比如URL编码。 #### 1. Burp Suite 中的 URL 编码机制 在Burp Suite中,可以通过手动方式或内置的功能来处理URL编码问题。以下是具体说明: - **手动编码**:可以利用Burp自带的Decoder工具完成字符的编码与解码工作。例如,对于中文字符串`你好`,如果需要将其转换为GBK编码形式,则可以在Decoder输入框中粘贴原始数据,并选择相应的编码选项[^3]。 - **自动编码**:当通过Intruder或其他攻击模块发送请求时,某些字段可能默认被转义成百分号表示法(%XX)。这种情况下无需额外干预即可实现标准的URL编码过程[^2]。 #### 2. Python 实现自定义 URL 编码逻辑 除了依赖于BP外,还可以借助编程语言如Python编写脚本来辅助完成复杂的场景需求。下面展示了一个简单的例子演示如何模拟浏览器行为提交表单的同时正确处理特殊字符的情况: ```python import urllib.parse data = {'username': 'admin', 'password': '123456!', 'comment': '<script>alert("XSS")</script>'} encoded_data = urllib.parse.urlencode(data, quote_via=urllib.parse.quote_plus) print(encoded_data) ``` 上述代码片段会输出如下结果: ``` username=admin&password=123456%21&comment=%3Cscript%3Ealert%28%22XSS%22%29%3C%2Fscript%3E ``` 此结果显示所有敏感符号均已被妥善替换成了合法的形式以便顺利传递给服务端解析[^1]。 #### 3. 常见错误及其修复建议 有时可能会遇到因不当使用而导致的问题,这里列举几个典型状况以及对应的解决办法: - 如果发现部分参数未能成功送达目标站点可能是由于未遵循RFC规范所规定的格式所致;此时应仔细核对每一项内容是否存在非法成分并且重新调整直至满足要求为止。 - 当面临多层嵌套结构或者非ASCII范围内的文字序列化难题时可考虑采用Base64或者其他高级算法作为补充手段进一步增强兼容性表现效果。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值