php - 无法直接传输的字段,用url_encode还是用base64?

 郑谊099_448 发布于 2022-11-16 13:08

问题描述:

在用一个某开源插件做封装,想要传一些参数进去。

多数字段都是普通字符串参数,但是有一个字段传的是json,结果发现这个插件一看到大括号和双引号就识别错误了。

不想改这个插件的源码,考虑自己传进去的时候转译一下。实测url_encode和base64都可用。

没有任何加密需求(传输走的https。两端接口的这个字段都是公开的,谁看到都无所谓)。

想知道url_encode和base64哪个更好

4 个回答
  • 不是urlencode?前者适合于URL里的参数,后者更适合传输二进制数据。功能上其实没什么差别

    2022-11-16 13:30 回答
  • php中使用url_encode是不区分英文不变的,而且对于二进制效率也不高;base64兼容性好点,但是生成的编码会比数据源多33%左右。

    2022-11-16 13:30 回答
  • base64编码后的长度比编码前多了1/3,标准的Base64并不适合直接放在URL里传输,有一些Base64的变种,它们将+/等符号转换为其他符号(如_-)
    建议使用rawurlencode

    2022-11-16 13:30 回答
  • ajax基本没什么不能传输,你文中遇到"一看到大括号和双引号",那么在提交之前对字段进行处理下.至于处理方式多种多样,比如数组最简单的序列化和反序列化.

    2022-11-16 13:30 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有