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对冒号(:)、斜杠(/)、空格、中文、井号(#)都进行了编码字母和数字没有进行编码,所以此方法不可以用于网址进行编码,但可以用于对参数进行编码
4.另中解决方法
去掉url中的emoji表情