Adyen - 无法解密数据
Adyen - Unable to decrypt data
您好,我正在尝试将 Adyen 支付网关集成到我的项目中。
我使用了以下 PHP SDK Adyen PHP SDK
我已经按照sdk中提到的步骤生成客户端加密并将这些加密值传递给服务器端以执行支付。但是我被一条错误消息卡住了 "Unable to Decrypt data"
以下是我的示例代码,
前端:
<script type="text/javascript" src="https://test.adyen.com/hpp/cse/js/MY_LIBRARY_TOKEN.shtml"></script>
<form method="POST" id="adyen-encrypted-form">
<input placeholder="number" type="text" size="20" data-encrypted-name="number" value="2223520443560010" />
<input placeholder="holderName" type="text" size="20" data-encrypted-name="holderName" value="Ashok" />
<input placeholder="expiryMonth" type="text" size="2" data-encrypted-name="expiryMonth" value="10" />
<input placeholder="expiryYear" type="text" size="4" data-encrypted-name="expiryYear" value="2020" />
<input placeholder="cvc" type="text" size="4" data-encrypted-name="cvc" value="737" />
<input type="hidden" value="<?php echo date('Y-m-d\TH:i:sO'); ?>" data-encrypted-name="generationtime"/>
<input type="submit" value="Pay"/>
</form>
<script>
// The form element to encrypt.
var form = document.getElementById('adyen-encrypted-form');
var options = {};
// Bind encryption options to the form.
var encryptedBlobFieldName = "myFieldName";
options.name = encryptedBlobFieldName;
options.onsubmit = function(e) {
var encryptedData = form.elements[encryptedBlobFieldName].value;
// Encrypted form detials
console.log(encryptedData);
e.preventDefault();
};
var result = adyen.createEncryptedForm(form, options);
</script>
我从上面的提交操作中获得了加密值,我在表单中填充了测试细节。 (即)加密数据
服务器代码:
$client = new \Adyen\Client();
$client->setApplicationName("Adyen PHP Api Library Example");
$client->setUsername("WS_USERNAME");
$client->setPassword("WS_USER_PASSWORD");
$client->setEnvironment(\Adyen\Environment::TEST);
$service = new \Adyen\Service\Payment($client);
$result = $service->authorise($params);
以下是我传递给授权方法的值,
Array(
[amount] => Array
(
[value] => 19
[currency] => GBP
)
[reference] => payment-test
[merchantAccount] => MERCHANT_ACCOUNT_CODE
[additionalData] => Array
(
[card.encrypted.json] => 'ENCRYPTED_DATA_FROM_FRONT_END'
)
)
我不确定我做错了什么,从服务器端收到无法解密数据的错误。请帮我解决这个问题
您是否尝试在不刷新页面的情况下进行付款?
在那种情况下,您确实应该创建字段来加密自己,在您的情况下,您将其称为 'myFieldName'。如果您将其添加到您的表格中,您应该可以开始了。如果这不起作用,请告诉我。
您需要使用以冒号分隔小时和分钟的偏移量。
更改日期生成方式
echo date('Y-m-d\TH:i:sO');
至
echo date('Y-m-d\TH:i:sP');
我发现了问题。问题是在通过 CSE 从前端生成令牌后,我已经通过 GET api 将这些值传递到服务器端。所以在加密字符串中添加了一些额外的字符。 (在 url 中传递的数据使用 url 加密进行了加密)。
我已将服务器 API 方法更改为 post,它运行良好。
您好,我正在尝试将 Adyen 支付网关集成到我的项目中。 我使用了以下 PHP SDK Adyen PHP SDK
我已经按照sdk中提到的步骤生成客户端加密并将这些加密值传递给服务器端以执行支付。但是我被一条错误消息卡住了 "Unable to Decrypt data"
以下是我的示例代码,
前端:
<script type="text/javascript" src="https://test.adyen.com/hpp/cse/js/MY_LIBRARY_TOKEN.shtml"></script>
<form method="POST" id="adyen-encrypted-form">
<input placeholder="number" type="text" size="20" data-encrypted-name="number" value="2223520443560010" />
<input placeholder="holderName" type="text" size="20" data-encrypted-name="holderName" value="Ashok" />
<input placeholder="expiryMonth" type="text" size="2" data-encrypted-name="expiryMonth" value="10" />
<input placeholder="expiryYear" type="text" size="4" data-encrypted-name="expiryYear" value="2020" />
<input placeholder="cvc" type="text" size="4" data-encrypted-name="cvc" value="737" />
<input type="hidden" value="<?php echo date('Y-m-d\TH:i:sO'); ?>" data-encrypted-name="generationtime"/>
<input type="submit" value="Pay"/>
</form>
<script>
// The form element to encrypt.
var form = document.getElementById('adyen-encrypted-form');
var options = {};
// Bind encryption options to the form.
var encryptedBlobFieldName = "myFieldName";
options.name = encryptedBlobFieldName;
options.onsubmit = function(e) {
var encryptedData = form.elements[encryptedBlobFieldName].value;
// Encrypted form detials
console.log(encryptedData);
e.preventDefault();
};
var result = adyen.createEncryptedForm(form, options);
</script>
我从上面的提交操作中获得了加密值,我在表单中填充了测试细节。 (即)加密数据
服务器代码:
$client = new \Adyen\Client();
$client->setApplicationName("Adyen PHP Api Library Example");
$client->setUsername("WS_USERNAME");
$client->setPassword("WS_USER_PASSWORD");
$client->setEnvironment(\Adyen\Environment::TEST);
$service = new \Adyen\Service\Payment($client);
$result = $service->authorise($params);
以下是我传递给授权方法的值,
Array(
[amount] => Array
(
[value] => 19
[currency] => GBP
)
[reference] => payment-test
[merchantAccount] => MERCHANT_ACCOUNT_CODE
[additionalData] => Array
(
[card.encrypted.json] => 'ENCRYPTED_DATA_FROM_FRONT_END'
)
)
我不确定我做错了什么,从服务器端收到无法解密数据的错误。请帮我解决这个问题
您是否尝试在不刷新页面的情况下进行付款? 在那种情况下,您确实应该创建字段来加密自己,在您的情况下,您将其称为 'myFieldName'。如果您将其添加到您的表格中,您应该可以开始了。如果这不起作用,请告诉我。
您需要使用以冒号分隔小时和分钟的偏移量。
更改日期生成方式
echo date('Y-m-d\TH:i:sO');
至
echo date('Y-m-d\TH:i:sP');
我发现了问题。问题是在通过 CSE 从前端生成令牌后,我已经通过 GET api 将这些值传递到服务器端。所以在加密字符串中添加了一些额外的字符。 (在 url 中传递的数据使用 url 加密进行了加密)。
我已将服务器 API 方法更改为 post,它运行良好。