2017-09-01 92 views
0

我正在嘗試使用Sagepay Direct實現Omnipay,但我真的很難與3D安全位一起工作。Sagepay Direct 3D安全空白頁問題

當我發佈MD,PaReq和TermUrl到https://test.sagepay.com/mpitools/accesscontroler?action=pareq我只是得到一個空白屏幕。

這些以前的答案建議刪除PaReq字段中的空格解決了這個問題,但我的數據中沒有任何空格。

SagePay Direct 3DSecure checkout part returning blank page when redirecting out to bank

Sage Pay test server won't load 3D Secure page

數據從Omnipay方法$應答爲返回> getRedirectData()是

"PaReq" => "eJxVUk1TwjAQvfsrGO52mza0lVnCoBxERqcqOuMxpqt0pB8mrRZ/vQkUweTy3svO2+xLcNoVm8EXaZNX5WTIPH84FWe4Wmui+SOpVpPAWzJGvtMgzybDwGcjn7OLmEc8CXnAgmQ0FJjOHuhTYG8krI/HEA7UOmi1lmUjUKrPy8Wd4DwKoxFCT7EgvZiLgPn7HfpuIexlLGVBYqZkRsV2RaZ5pjKrNMJOR1W1ZaO3IgkihAPBVm/EumlqMwaQdW08U1bfmur2dZMrT1Ve+wGGNm/nhvQXIbh6hONF09YhY/27PBNyef308zKLuuXdA0u71DC5DrItj2/uJwiuAjPZkLDxxH4SsgGLx2E85hxhp6Ms3MUEc1P1GGvXYnZycCqgzV5TqQ5zHRhSV1cl2YoA4Q9jRkaJR/dKqdwObtOFbewkhOMgV9cuf9XYSJmLfoecX24DYwnbGzqC4Gqhf1XoP4BF/z7GLxIJvBw=" 

"MD" => "20150419746483421285" 

這是表單的HTML我使用

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> 
<title>Untitled Document</title> 
</head> 

    <body> 
    <form action="https://test.sagepay.com/mpitools/accesscontroler?action=pareq" method="post"> 
     <input name="MD" value="20150419746483421285" type="hidden"> 
     <input name="PaReq" value="eJxVUk1TwjAQvfsrGO52mza0lVnCoBxERqcqOuMxpqt0pB8mrRZ/vQkUweTy3svO2+xLcNoVm8EXaZNX5WTIPH84FWe4Wmui+SOpVpPAWzJGvtMgzybDwGcjn7OLmEc8CXnAgmQ0FJjOHuhTYG8krI/HEA7UOmi1lmUjUKrPy8Wd4DwKoxFCT7EgvZiLgPn7HfpuIexlLGVBYqZkRsV2RaZ5pjKrNMJOR1W1ZaO3IgkihAPBVm/EumlqMwaQdW08U1bfmur2dZMrT1Ve+wGGNm/nhvQXIbh6hONF09YhY/27PBNyef308zKLuuXdA0u71DC5DrItj2/uJwiuAjPZkLDxxH4SsgGLx2E85hxhp6Ms3MUEc1P1GGvXYnZycCqgzV5TqQ5zHRhSV1cl2YoA4Q9jRkaJR/dKqdwObtOFbewkhOMgV9cuf9XYSJmLfoecX24DYwnbGzqC4Gqhf1XoP4BF/z7GLxIJvBw=" type="hidden"> 
     <input name="TermUrl" value="https://www.example.com/payment/auth-return" type="hidden"> 
     <center><p>Please click button below to Authenticate your card</p><input value="Go" type="submit"></center> 
    </form> 
    </body> 
</html> 

你知道我爲什麼得到一個bla頁面?在發送給Sagepay之前,我需要以某種方式轉換數據嗎?

我試過了所有我能想到的東西,但我無處可去。

回答

0

好的,所以它現在神奇地工作....在Sagepay的結束可能是一個問題?

在情況下,它是爲別人有用的,這是我的iFrame代碼...

<iframe src="secure-3d.php?acsURL=<?=$responseUrl?>&PaReq=<?=$responseData['PaReq']?>&MD=<?=$responseData['MD']?>&TermUrl=<?=$responseData['TermUrl']?>" name="secure-3d" id="secure-3d" width="100%" height="500" frameborder="0"></iframe> 

...其中「安全,3d.php」是下面我的自我提交形式....

<form id="cardToken" name="cardToken" action="<?=$_GET['acsURL']?>" method="post"> 
    <input type="hidden" name="MD" value='<?=str_replace(' ','+',$_GET['MD'])?>' /> 
    <input type="hidden" name="PaReq" value='<?=str_replace(' ','+',$_GET['PaReq'])?>' /> 
    <input type="hidden" name="TermUrl" value='<?=str_replace(' ','+',$_GET['TermUrl'])?>' /> 
    <noscript> 
    <center><p>Please click button below to Authenticate your card</p><input type="submit" value="Go"/></p></center> 
    </noscript> 
</form> 
<script language="Javascript"> 
     var form = document.getElementById("cardToken"); 
     form.submit(); 
</script> 

我只是通過PaReq,通過在查詢字符串形式的MD和TermUrl數據,那麼你需要str_replace空間創建隱藏字段時,就加。

這應該做到這一點!

如果任何人有任何想法如何使這個更好,請評論