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);