2015-04-17 49 views
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); 
+0

谢谢Rik.I已经发现我的服务器实现不需要AES部分。我通过https运行,因此不需要进一步加密。看起来像一个简单的协议值变化就是所需要的。 –

回答

0

AES要求仅适用于使用表格集成方法。看起来你正在发布到Sage Pay的Direct API。所以你可能没有太多的事情要做:-)