Laravel 403 无效签名仅在 Nginx Web 服务器上

And*_*lin 3 php https nginx laravel

问题

我正在通过从 laravel签名路由文档复制和粘贴的 laravel 'temporarySignedRoute' 函数创建签名 URL ,在我的 Web 服务器上,该 url 输出为 403 无效签名。签名的 URL 在我的本地机器上工作,但在将其上传到我的测试服务器时,它给出了如下所示的错误。

在此处输入图片说明

我试过的

我一直在寻找解决方案一段时间,并尝试了许多已发布在堆栈溢出上的解决方案,但似乎没有任何解决方案可以解决我的问题。

我已经尝试了以下所有方法:

  • 通过 AppServiceProvider 强制所有路由到 https,这会强制所有 url 为 https,但给出了相同的结果。
  • 我尝试按照此处所述更改 Nginx 的配置。

  • 我还尝试添加 TrustProxies 中间件,并将代理配置为 '*' 或 all,就像 laravel 关于Trust Proxies的文档中所述,结果相同。

  • 停止 Web 服务器强制域到 https 以测试它是否只是 https 导致它,结果相同。

- 更新 -

vendor/laravel/framework/src/Illuminate/Routing/UrlGenerator.php在尝试搜索项目中的任何线索时进入。我决定数据转储 (dd) 出它在我的本地和托管项目上比较的令牌,这就是结果。代码如下所示。

public function hasValidSignature(Request $request, $absolute = true)
{
    $url = $absolute ? $request->url() : '/'.$request->path();

    $original = rtrim($url.'?'.Arr::query(
        Arr::except($request->query(), 'signature')
    ), '?');

    $expires = $request->query('expires');

    $signature = hash_hmac('sha256', $original, call_user_func($this->keyResolver));
    dd($signature . " :: " . $request->query('signature', ''));
    return  hash_equals($signature, (string) $request->query('signature', '')) &&
           ! ($expires && Carbon::now()->getTimestamp() > $expires);
}
Run Code Online (Sandbox Code Playgroud)

本地项目

本地项目

主持项目

远程机器

所以令牌没有在我的网络服务器上传递,而是在我的本地。另外我注意到的另一件事是网络服务器令牌始终相同并且无论如何都不会改变。

我当前的 Nginx 配置可以在这里查看。

我当前的虚拟主机配置在这里

Pri*_*wal 6

我想这可能是问题所在。尝试将配置文件中的位置块更改为

try_files $uri $uri/ /index.php?$query_string;

我想你已经错过了?索引和查询字符串

更新它并确保重新加载您的 Nginx 服务器。 sudo service nginx reload

让我知道这个是否奏效。