php - 类 App\Http\Controllers\PostController 不存在

标签 php laravel-5 controller

让我先说“我知道这个问题经常被问到。”当我说没有任何效果时,请相信我。

我创建了一个名为 PostController 的 Controller .这是我博客的 Controller 。当我导航到我的博客时,我收到以下错误 Class App\Http\Controllers\PostController does not exist即使它确实存在。 Controller 名为 PostController.php .这是路线的样子 Route::get('blog','PostController@index'); .我读过运行一些 composer命令会有所帮助,但没有一个对我有帮助。 composer dumpautoload以及 composer update .我在这里错过了一些步骤吗?有人遇到过类似的问题吗?如果需要其他信息,请告诉我。

编辑
这是顶部的命名空间。

use App\Http\Controllers;
use App\Posts;
use App\User;
use App\Http\Controllers\Controller;
use App\Http\Requests\PostFormRequest;
use Illuminate\Http\Request;

这是整个 Controller 。
<?php 
use App\Http\Controllers;
use App\Posts;
use App\User;
use App\Http\Controllers\Controller;
use App\Http\Requests\PostFormRequest;
use Illuminate\Http\Request;



class PostController extends Controller {

/**
 * Display a listing of the resource.
 *
 * @return Response
 */
    public function index()
    {
      //fetch 5 posts from database which are active and latest
      $posts = Posts::where('active',1)->orderBy('created_at','desc')->paginate(5);
      //page heading
      $title = 'Latest Posts';
      //return home.blade.php template from resources/views folder
      return view('blog/home')->withPosts($posts)->withTitle($title);
    }


/**
 * Show the form for creating a new resource.
 *
 * @return Response
 */
    public function create(Request $request)
    {
      // if user can post i.e. user is admin or author
      if($request->user()->can_post())
      {
        return view('blog.create');
      }    
      else 
      {
        return redirect('blog');
      }
    }


/**
 * Store a newly created resource in storage.
 *
 * @return Response
 */
    public function store(PostFormRequest $request)
    {
      $post = new Posts();
      $post->title = $request->get('title');
      $post->body = $request->get('body');
      $post->slug = str_slug($post->title);
      $post->author_id = $request->user()->id;
      if($request->has('save'))
      {
        $post->active = 0;
        $message = 'Post saved successfully';            
      }            
      else 
      {
        $post->active = 1;
        $message = 'Post published successfully';
      }
      $post->save();
      return redirect('edit/'.$post->slug)->withMessage($message);
    }


/**
 * Display the specified resource.
 *
 * @param  int  $id
 * @return Response
 */
    public function show($slug)
    {
      $post = Posts::where('slug',$slug)->first();
      if(!$post)
      {
         return redirect('/')->withErrors('requested page not found');
      }
      $comments = $post->comments;
      return view('posts.show')->withPost($post)->withComments($comments);
    }


/**
 * Show the form for editing the specified resource.
 *
 * @param  int  $id
 * @return Response
 */
    public function edit(Request $request,$slug)
    {
      $post = Posts::where('slug',$slug)->first();
      if($post && ($request->user()->id == $post->author_id || $request->user()->is_admin())){
          return view('posts.edit')->with('post',$post);
      }
      return redirect('blog')->withErrors('you have not sufficient permissions');
    }


/**
 * Update the specified resource in storage.
 *
 * @param  int  $id
 * @return Response
 */
    public function update(Request $request)
    {
      //
      $post_id = $request->input('post_id');
      $post = Posts::find($post_id);
      if($post && ($post->author_id == $request->user()->id || $request->user()->is_admin()))
      {
        $title = $request->input('title');
        $slug = str_slug($title);
        $duplicate = Posts::where('slug',$slug)->first();
        if($duplicate)
        {
          if($duplicate->id != $post_id)
          {
            return redirect('edit/'.$post->slug)->withErrors('Title already exists.')->withInput();
          }
          else 
          {
            $post->slug = $slug;
          }
        }
        $post->title = $title;
        $post->body = $request->input('body');
        if($request->has('save'))
        {
          $post->active = 0;
          $message = 'Post saved successfully';
          $landing = 'edit/'.$post->slug;
        }            
        else {
          $post->active = 1;
          $message = 'Post updated successfully';
          $landing = $post->slug;
        }
        $post->save();
             return redirect($landing)->withMessage($message);
      }
      else
      {
        return redirect('blog')->withErrors('you have not sufficient permissions');
      }
    }


/**
 * Remove the specified resource from storage.
 *
 * @param  int  $id
 * @return Response
 */
    public function destroy(Request $request, $id)
    {
      //
      $post = Posts::find($id);
      if($post && ($post->author_id == $request->user()->id || $request->user()->is_admin()))
      {
        $post->delete();
        $data['message'] = 'Post deleted Successfully';
      }
      else 
      {
        $data['errors'] = 'Invalid Operation. You have not sufficient permissions';
      }
      return redirect('blog')->with($data);
    }


}

谢谢。

最佳答案

打开 App\Provider\RouteServiceProvider.php
并添加
这条线

protected $namespace = 'App\Http\Controllers'; 
在这个下面
public const HOME = '/home';
你的错误就会消失。

关于php - 类 App\Http\Controllers\PostController 不存在,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37975921/

相关文章:

php - 检测 MySQL 表何时处于读锁定状态(来自 PHP)

php - openshift Mysql ip的rhc命令

php - 如何在 Laravel 路由中返回一个 .xml 文件

php - 无法从干预/图像中的给定 url 初始化": "^2. 3

php - Laravel 5.2 漂亮的 URL

javascript - AngularJS UI-Router 无法识别模块上定义的 Controller

php - Codeigniter 2 index 和 __construct 之间的区别以及在 __construct 中放置的内容

php - 在 PHP 中获取小时和分钟

php - 无法从 Nest 服务器获取访问 token

javascript - 更新 AngularJS 服务中的 radio 值