

新闻资讯
行业动态Base64 是将二进制数据编码为 ASCII 字符串的手段,用于在 XML 中安全嵌入文件;它不加密不压缩,仅解决 XML 无法直接容纳非可打印字节的问题,编码后体积膨胀约 33%。
Base64 编码本身不加密、不压缩,只是把二进制数据转成 ASCII 字符串,因此它能用在 XML 中安全嵌入文件(如图片、PDF),但不是“上传方式”,而是“编码手段”。真正上传靠的是 HTTP 请求(如 POST)、XML-RPC 或特定 API(如 SetFile),Base64 只是把文件内容塞进 XML 文本的“包装纸”。
XML 是纯文本格式,无法直接容纳 \x00\xFF 这类非可打印字节。如果强行把图片原始字节写进 XML,会破坏文档结构,导致解析失败或乱码。
+, /, =)... 标签里常见于表单提交含附件的 XML 请求(比如政务/金融系统老接口)。关键点:别漏掉 reader.result.split(',')[1] —— readAsDataURL() 返回的是 data:image/png;base64,xxx,前缀必须剥离。
function fileToBase64(file) {
return new Promise((resolve, reject) => {
const reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = () => resolve(reader.result.split(',')[1]); // ← 关键!只取 base64 主体
reader.o
nerror = reject;
});
}
// 构建 XML 字符串(注意转义 & < >)
async function buildXmlWithImage(file) {
const b64 = await fileToBase64(file);
return zuojiankuohaophpcnrequestyoujiankuohaophpcn zuojiankuohaophpcndocTypeyoujiankuohaophpcnIDCARDzuojiankuohaophpcn/docTypeyoujiankuohaophpcn zuojiankuohaophpcnimageDatayoujiankuohaophpcn${b64}zuojiankuohaophpcn/imageDatayoujiankuohaophpcn zuojiankuohaophpcn/requestyoujiankuohaophpcn .trim();
}
> & 必须写成 zuojiankuohaophpcn youjiankuohaophpcn &
innerHTML 直接插入 XML 字符串——那是 HTML 解析器,会报错;要用 DOMParser 或发纯文本请求服务端拿到 XML 后,要先解析出 Base64 字符串,再解码为字节数组保存为文件。最容易出错的是:忽略补位等号、用错字符集、未校验长度。
Base64.decode("abc") 在 Java 中可能抛 IllegalArgumentException:因为 Base64 字符串长度必须是 4 的倍数,缺位要用 = 补齐(如 "abc=")base64.b64decode() 默认严格校验,传入含换行或空格的字符串会失败,建议先 .replace('\n', '').replace(' ', '')
Convert.FromBase64String() 要求输入不含 data:image/png;base64, 前缀,否则直接抛异常xml.etree.ElementTree)对超长文本节点默认有深度/长度限制,需显式配置(如设置 max_entity_expansions=0)除非对接遗留系统强制要求 XML 封装,否则优先考虑现代方式:
multipart/form-data 上传:文件走二进制流,元数据走字段,零编码开销,Nginx/Apache 原生支持SetFile 类接口(如你知识库提到的 Transaction/SetFile/{transactionID}/{fileName}/{fileExtension}):明确支持 Base64 或流式上传,且带事务上下文Base64 + XML 是“能跑通”的方案,不是“该首选”的方案。它的脆弱点藏在细节里:等号处理、空白截断、XML 实体转义、服务端解析器配置……任何一个环节松动,整条链就卡死在“XML 格式错误”或“Base64 格式非法”。