WWW请求的Url中含有表情特殊符号,微信支付失败

1.问题:
我在处理微信支付时,向Php端请求微信支付参数,但是出现有的用户能充值成功,有的用户充值不成功。这个问题我找好长时间,发现凡是用户昵称中带有表情的都支付不成功。
2.原因:
在向php请求参数时,url中携带了表情的特殊符号,导致www.error==400
参数请求失败,支付充值不成功,所有就需要将特殊符号重新编码,对特殊符号还原为转义表示形式。
3.解决方案:
在C#中值得推荐的有2中
System.Uri.EscapeUriString 用于对网址编码(我用的)
System.Uri.EscapeDataString 用于对网址参数进行编码

string url1 = "http://www.cnblogs.com/a file with spaces.html?a=1&b=博客园#abc";
Response.Write( Uri.EscapeUriString(url1));
//outputs:
    http://www.cnblogs.com/a%20file%20with%20spaces.html?a=1&b=%E5%8D%9A%E5%AE%A2%E5%9B%AD#abc
    可以看出,Uri.EscapeUriString对**空格进行了编码,也对中文进行了编码,但对冒号(:)、斜杠(/)和井号(#)、字母、数字未编码**,所以此方法可以用于网址进行编码,但不能对参数进行编码,作用类似JavaScript中的encodeURI方法。

string url1 = "http://www.cnblogs.com/a file with spaces.html?a=1&b=博客园#abc";
Response.Write(Uri.EscapeDataString(url1));
//outputs:
    http%3A%2F%2Fwww.cnblogs.com%2Fa%20file%20with%20spaces.html%3Fa%3D1%26b%3D%E5%8D%9A%E5%AE%A2%E5%9B%AD%23abc
  可以看出,Uri.EscapeDataString对冒号(:)、斜杠(/)、空格、中文、井号(#)都进行了编码字母和数字没有进行编码,所以此方法不可以用于网址进行编码,但可以用于对参数进行编码

参考 https://www.cnblogs.com/gavin-num1/p/5133435.html

4.另中解决方法
去掉url中的emoji表情

参考 https://www.cnblogs.com/lilo202/p/8058012.html

### 企业微信自建应用 OpenAPI 回调地址请求失败解决方案 对于企业微信自建应用中遇到的OpenAPI回调地址请求不通过的问题,主要的原因在于验证URL的有效性过程中出现问题。具体来说,在返回响应给企业微信服务器时,如果返回的内容包含了额外的字符(如引号),则可能导致验证失败。 为了确保回调地址能够成功通过验证,应当注意以下几点: - **返回值格式**:确保控制器中的方法直接返回未经修饰的字符串对象,而不是被框架自动封装成JSON或其他格式的数据结构。特别是当使用Spring MVC框架时,`@RestController`注解会默认将所有的返回结果转换为JSON格式发送出去,因此需要特别小心处理这种情况[^3]。 - **去除多余符号**:检查并确认返回的消息体里没有任何多余的双引号或者其他特殊字符。例如,正确的做法是在Controller层的方法上指定返回类型为`String`,并且只返回必要的校验Token作为纯文本内容,而不应包含任何HTML标签或JSON包裹。 下面是调整后的代码片段示例,展示了如何正确配置Spring MVC应用程序来满足这一需求: ```java import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; @RestController public class WeChatCallbackController { @GetMapping("/wechat/callback") public String handleWeChatVerification(@RequestParam(value="msg_signature") String msgSignature, @RequestParam(value="timestamp") String timestamp, @RequestParam(value="nonce") String nonce, @RequestParam(value="echostr", required=false) String echoStr){ // 进行业务逻辑判断... // 如果是首次接入验证,则直接返回echostr参数值即可, // 注意这里不能有任何其他附加信息,比如前后有空格也不可以 return echoStr; } } ``` 此外,还需要仔细阅读官方提供的接口文档说明,按照指引完成相应的安全性和功能性测试,以确保整个流程顺畅无误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值