utf-8 - PayPal Payflow Gateway UTF-8 字符

标签 utf-8 paypal character-encoding payment-gateway payflowpro

我在让 PayPal Payflow Gateway 接受我的包含非 US-ASCII 字符的 HTTPS POST 时遇到问题。不管我用这些特殊字符发布什么,它似乎只想接受 US-ASCII 编码的字节。如果我发送 UTF-8 编码字节,它仍然有效,但无法解析某些请求 NVP 值。我知道这是可能的,因为我已经将另一个开发人员的测试页面发布到我的帐户(http://ccaples.com/ NVP 快速测试)并且该帖子似乎保留了特殊字符。

这是一个例子。我尝试过使用许多不同的 Content-Type header 和 Accept/Accept-Charset 值,包括在文本/名称值之后的 Content-Type 中指定“;charset=UTF-8”或“;charset=utf-8”。

POST https://pilot-payflowpro.paypal.com/ HTTP/1.1
Content-Type: text/namevalue
User-Agent: KLMS Payflow API for Java
X-VPS-Request-ID: 36A4ED051A8B492ABF70E6BE51CB13D5
X-VPS-CLIENT-TIMEOUT: 20
Connection: close
X-VPS-VIT-INTEGRATION-PRODUCT: KLMS Payflow API for Java
X-VPS-VIT-INTEGRATION-VERSION: 2.0.008
X-VPS-VIT-PROXY: Y
X-VPS-VIT-RUNTIME-VERSION: 20.45-b01
X-VPS-VIT-OS-ARCHITECTURE: amd64
X-VPS-VIT-OS-VERSION: 6.1
X-VPS-VIT-OS-NAME: Windows 7
Cache-Control: no-cache
Pragma: no-cache
Host: pilot-payflowpro.paypal.com
Content-Length: 694

USER[8]=XXXXXXXX&VENDOR[13]=XXXXXXXXXXXXX&PARTNER[6]=PayPal&PWD[8]=XXXXXXXX&VERBOSITY[4]=HIGH&BILLTOEMAIL[28]=XXXXXXXX@kineticlearning.com&TRXTYPE[1]=A&TENDER[1]=C&ACCT[16]=4111111111111111&EXPDATE[4]=1117&CVV2[3]=123&BILLTOFIRSTNAME[4]=Josè&BILLTOLASTNAME[7]=Elkjærd&BILLTOSTREET[14]=123 Elm Street&BILLTOCITY[9]=Elm Creek&BILLTOSTATE[2]=VA&BILLTOZIP[5]=22203&BILLTOCOUNTRY[2]=US&BILLTOPHONENUM[12]=763-221-5593&CUSTBROWSER[108]=Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/40.0.2214.91 Safari/537.36&CUSTHOSTNAME[12]=192.168.1.10&CUSTIP[12]=192.168.1.10&AMT[6]=600.00&CURRENCY[3]=USD&COMMENT1[26]=Law Enforcement Curriculum&COMMENT2[16]=Standard Version

HTTP/1.1 200 OK
Connection: close
Server: VPS-3.033.00
X-VPS-Request-ID: 36A4ED051A8B492ABF70E6BE51CB13D5
Date: Sun, 25 Jan 2015 17:45:05 GMT
Content-type: text/namevalue
Content-length: 199

RESULT=104&PNREF=B70P7B6EBAE7&RESPMSG=Timeout waiting for Processor response&TRANSTIME=2015-01-25 09:44:47&BILLTOFIRSTNAME=Jos &BILLTOLASTNAME=NotProvided&AMT=600.00&ACCT=1111&EXPDATE=1117&CARDTYPE=0

暂时忽略 104 超时。 Paypal 正在努力解决这个问题。您可以看到,BILLTOFIRSTNAME 是 Jos(不是 è 的奇怪字符)并且 BILLTOLASTNAME 中的 æ 字符一定导致服务器的 NVP 解析算法完全无法解析,因为它表示 NotProvided。

下面是将 NVP 格式的 Java 字符串转换为字节的代码:

        final byte[] requestBytes = requestString.getBytes(Charsets.UTF_8);

知道服务器端 NVP 解析器默认寻找什么字符编码,或者如何告诉它我发送 POST 正文的字符编码是什么?

最佳答案

我找到了解决方案。 Payflow Gateway Docs 似乎不支持它.文档似乎已过时,需要更新。我使用了 PayPal 支持,Payflow Gateway 似乎确实支持 UTF-8。诀窍是:要么您不需要在提交的名称/值对中指定长度参数(即 BILLTOFIRSTNAME=Josè),要么必须在长度参数中指定为不是 CHARACTERS 中的长度(即不是 value.length( )),但值的 UTF-8 编码字节流的 BYTES 实际长度(即 value.getBytes("UTF-8").length)。此交易有效,存储了 UTF-8 字符并在 PayPal 管理器中正确显示,并且在 Payflow Gateway 响应的名称/值对中返回了正确的值。如您所见,与上面的不同之处在于 BILLT0FIRSTNAME 和 BILLTOLASTNAME 长度标记现在更大,并且以字节而不是字符为单位指定长度。 Josè [4 个字符但 5 个字节:4A 6F 73 C3 A8] 和 Elkjærd & Grün [14 个字符但 16 个字节:45 6C 6B 6A C3 A6 72 64 20 26 20 47 72 C3 BC 6E]。

POST https://pilot-payflowpro.paypal.com/ HTTP/1.1
Content-Type: text/namevalue
Connection: close
User-Agent: KLMS Payflow for Java/2.0.008
X-VPS-Request-ID: B8DABD9BDFE246EC909B4CF741030133
X-VPS-CLIENT-TIMEOUT: 20
X-VPS-VIT-INTEGRATION-PRODUCT: KLMS Payflow for Java
X-VPS-VIT-INTEGRATION-VERSION: 2.0.008
X-VPS-VIT-PROXY: Y
X-VPS-VIT-RUNTIME-VERSION: 20.45-b01
X-VPS-VIT-OS-ARCHITECTURE: amd64
X-VPS-VIT-OS-VERSION: 6.1
X-VPS-VIT-OS-NAME: Windows 7
Cache-Control: no-cache
Pragma: no-cache
Host: pilot-payflowpro.paypal.com
Content-Length: 771

USER[8]=XXXXXXXX&VENDOR[13]=XXXXXXXXXXXXX&PARTNER[6]=PayPal&PWD[8]=XXXXXXXX&VERBOSITY[4]=HIGH&BILLTOEMAIL[28]=XXXXXX@kineticlearning.com&TRXTYPE[1]=A&TENDER[1]=C&ACCT[16]=4111111111111111&EXPDATE[4]=0216&CVV2[3]=123&BILLTOFIRSTNAME[5]=Josè&BILLTOLASTNAME[16]=Elkjærd & Grün&BILLTOSTREET[14]=123 Elm Street&BILLTOSTREET2[10]=Elm & Vine&BILLTOCITY[9]=Elm Creek&BILLTOSTATE[2]=VA&BILLTOZIP[5]=12345&BILLTOCOUNTRY[2]=US&BILLTOPHONENUM[12]=763-221-5593&CUSTBROWSER[108]=Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/40.0.2214.91 Safari/537.36&CUSTHOSTNAME[12]=192.168.1.10&CUSTIP[12]=192.168.1.10&AMT[6]=600.00&CURRENCY[3]=USD&COMMENT1[45]=Victim Advocate Curriculum (Standard Version)&COMMENT2[36]=Purchased for J.C. Hamlin (jchamlin)

HTTP/1.1 200 OK
Connection: close
Server: VPS-3.033.00
X-VPS-Request-ID: B8DABD9BDFE246EC909B4CF741030133
Date: Wed, 28 Jan 2015 01:45:29 GMT
Content-type: text/namevalue
Content-length: 209

RESULT=104&PNREF=B10P7D2F1643&RESPMSG=Timeout waiting for Processor response&TRANSTIME=2015-01-27 17:45:12&BILLTOFIRSTNAME=Josè&BILLTOLASTNAME[16]=Elkjærd & Grün&AMT=600.00&ACCT=1111&EXPDATE=0216&CARDTYPE=0

关于utf-8 - PayPal Payflow Gateway UTF-8 字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28160330/

相关文章:

mysql - 改变 MySQL 列编码,级联到 FK

paypal - 是否可以从 paypal 中提取历史记录?

parameters - Paypal IPN 和付款人电子邮件

java - Java中POST请求体不能包含中文字符

python UnicodeDecodeError : 'utf8' codec can't decode byte

utf-8 - Doctrine 正在将字符串转换为十六进制值

php - PayPal Rest API - 实时支付失败,沙盒工作

c++ - 如何在 Visual Studio 中处理混合的 unicode 和非 unicode 项目

php - preg_replace 用奇怪的字符替换引号?

ruby - 正则表达式错误 : too many multibyte code ranges are specified