0
以下代码是我们的结算付款页面的一部分,该页面向sagepay服务器注册付款。我只需要在获取响应之后更改编码之前的解码和解码以符合AES要求。Sagepay 2.23至3.00。需要更新到AES
我是否认为我的strPost需要分解非加密部分和Crypt部分?
在这种情况下,我有一些工作要做。
//** The full transaction registration POST has now been built **
System.Text.UTF8Encoding objUTFEncode = new System.Text.UTF8Encoding();
Uri objUri = new Uri(SagePay.SystemURL(SagePay.ConnectTo, "purchase"));
System.Net.HttpWebRequest objHttpRequest = (HttpWebRequest)WebRequest.Create(objUri.ToString());
objHttpRequest.KeepAlive = false;
objHttpRequest.Method = "POST";
objHttpRequest.ContentType = "application/x-www-form-urlencoded";
byte[] arrRequest = objUTFEncode.GetBytes(strPost);
objHttpRequest.ContentLength = arrRequest.Length;
Stream objStreamReq = objHttpRequest.GetRequestStream();
objStreamReq.Write(arrRequest, 0, arrRequest.Length);
objStreamReq.Close();
//Get response
HttpWebResponse objHttpResponse = (HttpWebResponse)objHttpRequest.GetResponse();
StreamReader objStreamRes = new StreamReader(objHttpResponse.GetResponseStream(), System.Text.Encoding.ASCII);
strResponse = objStreamRes.ReadToEnd();
objStreamRes.Close();
//** No transport level errors, so the message got the SagePay **
//** Analyse the response from VSP Direct to check that everything is okay **
//** Registration results come back in the Status and StatusDetail fields **
strStatus = SagePay.FindField("Status", strResponse);
strStatusDetail = SagePay.FindField("StatusDetail", strResponse);
谢谢Rik.I已经发现我的服务器实现不需要AES部分。我通过https运行,因此不需要进一步加密。看起来像一个简单的协议值变化就是所需要的。 –