如何修复 Viber 深度链接在移动设备上失效的问题

如何修复 Viber 深度链接在移动设备上失效的问题

如何修复 viber 深度链接在移动设备上失效的问题?viber 的 viber://chat/?number= 链接在 pc 上可正常跳转,但在手机端常无响应;根本原因是 url 中的加号 + 被移动端浏览器误解析为空格,需将其编码为 %2b 才能被 viber 客户端正确识别。

Viber 官方文档虽未明确强调 URL 编码要求,但实际行为表明:移动端 Viber 协议处理对 URL 格式极为严格。原始写法:

发送消息

存在两个关键问题:

  • + 在 URL 中默认表示空格(遵循 application/x-www-form-urlencoded 规则),而非字面意义的加号;
  • 空格和非数字字符(如空格、短横线)在 number 参数中必须完全移除或编码——Viber 移动客户端仅接受连续数字字符串,且国际号码必须以 %2B 开头(而非 + 或 00)。

✅ 正确做法是:

  1. 移除所有非数字字符(空格、-、(、) 等);
  2. 将开头的 + 替换为 URL 编码形式 %2B;
  3. 确保号码为 E.164 格式(例如格鲁吉亚号码 +995 555 55 55 55 → 995555555555,再拼前缀 %2B)。

修正后的 HTML 示例:

微信 WeLM

微信 WeLM

WeLM不是一个直接的对话机器人,而是一个补全用户输入信息的生成模型。

下载

通过 Viber 联系我们

⚠️ 注意事项:

  • 不要使用 encodeURI() 全量编码(它不会编码 /, ?, = 等保留字符,但可能遗漏 +);推荐手动替换 + → %2B,并用 .replace(//D/g, ”) 清洗号码;
  • 测试前请确保手机已安装最新版 Viber App(旧版本协议支持不完整);
  • iOS 和 Android 行为一致,均需 %2B;部分浏览器(如 Chrome for Android)会拦截未声明 target=”_blank” 的协议链接,可添加该属性提升兼容性;
  • 若仍失败,可在链接后追加 &text=(需同样编码)预填消息,例如:?number=%2B995555555555&text=Hello%20World。

总结:Viber 移动端深度链接不是“不工作”,而是对 URL 编码零容忍。牢记 + → %2B,号码去格式化,E.164 为唯一标准 —— 这三步即可 100% 解决跨端不一致问题。

https://www.php.cn/faq/2034610.html

发表回复

Your email address will not be published. Required fields are marked *