2017-09-01 141 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空间创建隐藏字段时,就加。

这应该做到这一点!

如果任何人有任何想法如何使这个更好,请评论