Class App\Http\Controllers\API\UserController does not exist

Neil Deb picture Neil Deb · May 13, 2019 · Viewed 10.3k times · Source

I am Having the issue of not getting token in postman as well as the following problem

ReflectionException …\vendor\laravel\framework\src\Illuminate\Container\Container.php790 user controller does not exist

my route file;

Route::post('login', 'API\UserController@login'); 
Route::post('register', 'API\UserController@register'); 
Route::group(['middleware' => 'auth:api'], function(){
   Route::post('details', 'API\UserController@details'); 
});

My controller file;


    namespace App\Http\Controllers;   
use App\Http\Controllers\Controller; 
use App\User; 
 use Illuminate\Support\Facades\Auth; 
 use Validator; 
use Illuminate\Http\Request;

    class UserController extends Controller {
        //
        public $successStatus = 200;
        /** 
         * login api 
         * 
         * @return \Illuminate\Http\Response 
         */ 
        public function login(){ 
            if(Auth::attempt(['email' => request('email'), 'password' => request('password')])){ 
                $user = Auth::user(); 
                $success['token'] =  $user->createToken('MyApp')-> accessToken; 
                return response()->json(['success' => $success], $this-> successStatus); 
            } 
            else{ 
                return response()->json(['error'=>'Unauthorised'], 401); 
            } 
        }
        /** 
         * Register api 
         * 
         * @return \Illuminate\Http\Response 
         */ 
        public function register(Request $request) 
        { 
            $validator = Validator::make($request->all(), [ 
                'name' => 'required', 
                'email' => 'required|email', 
                'password' => 'required', 
                'c_password' => 'required|same:password', 
            ]); if ($validator->fails()) { 
                return response()->json(['error'=>$validator->errors()], 401);            
            } $input = $request->all(); 
            $input['password'] = bcrypt($input['password']); 
            $user = User::create($input); 
            $success['token'] =  $user->createToken('MyApp')-> accessToken; 
            $success['name'] =  $user->name; return response()->json(['success'=>$success], $this-> successStatus); 
        } 
       /** 
         * details api 
         * 
         * @return \Illuminate\Http\Response 
         */ 
        public function details() 
        { 
            $user = Auth::user(); 
            return response()->json(['success' => $user], $this-> successStatus); 
        }  
} 

How can I Solve this?

Answer

bgaze picture bgaze · May 13, 2019

If your controller path is /App/Http/Controllers/API, you need to adjust it's namespace :

namespace App\Http\Controllers\API;

If your controller path is /App/Http/Controllers, you need to adjust your routes:

Route::post('login', 'UserController@login');