hash_hmac() 期望参数 2 为字符串,数组给定
hash_hmac() expects parameter 2 to be string, array given
我收到此错误:
[2019-04-04 05:00:04] local.ERROR: hash_hmac() expects parameter 2 to be
string, array given {"exception":"[object] (ErrorException(code: 0): hash_hmac()
expects parameter 2 to be string, array given at /home/domains/domain.com/smm/app/Http/Controllers/CoinPaymentsController.php:132)[stacktrace]
#0 [internal function]: Illuminate\Foundation\Bootstrap\HandleExceptions->handleError(2, 'hash_hmac() exp...', '/home/u37281288...', 132, Array)#1
这是我的代码:
public function ipn(Request $request)
{
if (!$request->filled('ipn_mode') || !$request->filled('merchant')) {
activity('coinpayments')
->withProperties(['ip' => $request->ip()])
->log('Missing POST data from callback.');
die();
}
if ($request->input('ipn_mode') == 'httpauth') {
//Verify that the http authentication checks out with the users supplied information
if ($request->server('PHP_AUTH_USER') != $this->merchantId || $request->server('PHP_AUTH_PW') != $this->secretKey) {
activity('coinpayments')
->withProperties(['ip' => $request->ip()])
->log('Unauthorized HTTP Request');
die();
}
} elseif ($request->input('ipn_mode') == 'hmac') {
// Create the HMAC hash to compare to the recieved one, using the secret key.
// line 132 of the error...
$hmac = hash_hmac("sha512", $request->all(), $this->secretKey);
if ($hmac != $request->server('HTTP_HMAC')) {
activity('coinpayments')
->withProperties(['ip' => $request->ip()])
->log('Unauthorized HMAC Request');
die();
}
} else {
activity('coinpayments')
->withProperties(['ip' => $request->ip()])
->log('Unauthorized HMAC Request');
die();
}
// Passed initial security test - now check the status
$status = intval($request->input('status'));
$statusText = $request->input('status_text');
if ($request->input('merchant') != $this->merchantId) {
activity('coinpayments')
->withProperties(['ip' => $request->ip()])
->log('Mismatching merchant ID. MerchantID:' . $request->input('merchant'));
die();
}
我正在尝试在我的网站上添加 CoinPayments。当我设置 IPN 时 URL 我收到此错误。付款正在进入我的帐户,但产品无法下载..
在将错误消息发布到 Whosebug 之前,您需要学会正确阅读错误消息,
$request->all()
给你一个数组,但是 hash_hmac()
方法只需要一个字符串,
如果你想要所有的数据。然后你可以使用 implode()
函数从输入数组中创建一个字符串。
$inputs = $request->all();
$string = implode("",$inputs);
$hmac = hash_hmac("sha512", $string, $this->secretKey);
错误告诉你传递给函数hash_hmac()
的第二个参数是一个数组,它必须是一个字符串。
$request->all())
将所有输入数据检索为数组
尝试传递输入名称而不是所有名称,例如:
$name = $request->input('name');
$hmac = hash_hmac("sha512", $name, $this->secretKey);
我收到此错误:
[2019-04-04 05:00:04] local.ERROR: hash_hmac() expects parameter 2 to be
string, array given {"exception":"[object] (ErrorException(code: 0): hash_hmac()
expects parameter 2 to be string, array given at /home/domains/domain.com/smm/app/Http/Controllers/CoinPaymentsController.php:132)[stacktrace]
#0 [internal function]: Illuminate\Foundation\Bootstrap\HandleExceptions->handleError(2, 'hash_hmac() exp...', '/home/u37281288...', 132, Array)#1
这是我的代码:
public function ipn(Request $request)
{
if (!$request->filled('ipn_mode') || !$request->filled('merchant')) {
activity('coinpayments')
->withProperties(['ip' => $request->ip()])
->log('Missing POST data from callback.');
die();
}
if ($request->input('ipn_mode') == 'httpauth') {
//Verify that the http authentication checks out with the users supplied information
if ($request->server('PHP_AUTH_USER') != $this->merchantId || $request->server('PHP_AUTH_PW') != $this->secretKey) {
activity('coinpayments')
->withProperties(['ip' => $request->ip()])
->log('Unauthorized HTTP Request');
die();
}
} elseif ($request->input('ipn_mode') == 'hmac') {
// Create the HMAC hash to compare to the recieved one, using the secret key.
// line 132 of the error...
$hmac = hash_hmac("sha512", $request->all(), $this->secretKey);
if ($hmac != $request->server('HTTP_HMAC')) {
activity('coinpayments')
->withProperties(['ip' => $request->ip()])
->log('Unauthorized HMAC Request');
die();
}
} else {
activity('coinpayments')
->withProperties(['ip' => $request->ip()])
->log('Unauthorized HMAC Request');
die();
}
// Passed initial security test - now check the status
$status = intval($request->input('status'));
$statusText = $request->input('status_text');
if ($request->input('merchant') != $this->merchantId) {
activity('coinpayments')
->withProperties(['ip' => $request->ip()])
->log('Mismatching merchant ID. MerchantID:' . $request->input('merchant'));
die();
}
我正在尝试在我的网站上添加 CoinPayments。当我设置 IPN 时 URL 我收到此错误。付款正在进入我的帐户,但产品无法下载..
在将错误消息发布到 Whosebug 之前,您需要学会正确阅读错误消息,
$request->all()
给你一个数组,但是 hash_hmac()
方法只需要一个字符串,
如果你想要所有的数据。然后你可以使用 implode()
函数从输入数组中创建一个字符串。
$inputs = $request->all();
$string = implode("",$inputs);
$hmac = hash_hmac("sha512", $string, $this->secretKey);
错误告诉你传递给函数hash_hmac()
的第二个参数是一个数组,它必须是一个字符串。
$request->all())
将所有输入数据检索为数组
尝试传递输入名称而不是所有名称,例如:
$name = $request->input('name');
$hmac = hash_hmac("sha512", $name, $this->secretKey);