0

您好,我正在为我的 laravel 应用程序创建我的评论系统,但是当我尝试评论时出现此错误.. 基本上当用户未登录并且他尝试评论并提交时,它应该将他重定向到登录页面,所以我的CreateRequest 文件是这个

<?php

namespace App\Http\Requests\Comment;

use App\Http\Requests\Request;
use App\Repositories\Image\ImageRepository;

class CreateRequest extends Request {
    /**
     * Determine if the user is authorized to make this request.
     *
     * @param ImageRepository $image
     * @return bool
     */
    public function authorize(ImageRepository $image) {
        $image = $image->getById($this->route('id'))->first();
        if (!$image) {
            return false;
        }
        return auth()->check();
    }

    /**
     * Get the validation rules that apply to the request.
     *
     * @return array
     */
    public function rules() {
        return [
            'comment' => ['required', 'min:2'],
        ];
    }

    /**
     * @return \Illuminate\Http\RedirectResponse
     */
    public function forbiddenResponse() {
        return redirect()->route('login');
    }
}

我的App\Http\Requests\Request文件是这个

<?php

namespace App\Http\Requests;

use Illuminate\Foundation\Http\FormRequest;

abstract class Request extends FormRequest {
    public function authorize() {
        return true;
    }
}

如果我删除

public function authorize() {
    return true;
}

然后评论有效,如果用户未登录,则用户将被重定向到登录页面,但是我的登录无效,当我尝试登录时我被禁止

我在这个项目之上开发我的应用程序https://github.com/laravelish/EasyAdmin 希望有人可以帮助我

4

1 回答 1

2

您已经authorize在抽象 Request 类中定义了一个方法:

public function authorize() {
    return true;
}

请注意,它不带任何参数。现在,如果你扩展这个抽象类(就像你对 CreateRequest 所做的那样)并编写一个authorize方法,你必须使用相同的签名。具体来说:authorize不能带任何参数,因为它不在抽象类中。


如果您authorize要从抽象类中删除该方法,则此特定错误将消失。但是我不确定这会解决你的问题。我不认为 Laravel 为该authorize方法提供依赖注入,你不能像那样注入你的存储库。

这是解决这两个问题的一种方法:

public function authorize() {
    $image = app(ImageRepository::class)->getById($this->route('id'))->first();
    ...
于 2016-06-13T12:32:00.150 回答