本文来自pilishen.com----; 欢迎作客我们的php&Laravel学习群:109256050
比如说你要给你的手机APP用户创建API,使用的是你已有的Laravel系统里的数据库,尤其是用户数据。现在我们来看一下,这里使用的是Laravel Passport组件。
我们将要创建三个api,分别是:
- Login API
- Register API
- Details API
(一)安装和配置Passport
composer require laravel/passport复制代码
在config/app.php
中注册provider
:
'providers' => [ .... Laravel\Passport\PassportServiceProvider::class,],复制代码
创建Passport需要的数据表:
php artisan migrate复制代码
然后初始化Passport,执行:
php artisan passport:install复制代码
该命令会生成用以后期创建安全令牌(access token)的秘钥,同时也会创建personal access
和password grant
两个客户端(clients)。
接下来,在app/User.php
中添加HasApiTokens
trait:
然后在app/Providers/AuthServiceProvider.php
中添加Passport::routes();
:
registerPolicies(); Passport::routes(); }}复制代码
在config/auth.php
中将api
的driver
改成passport
:
[ ... 'api' => [ 'driver' => 'passport', 'provider' => 'users', ], ], .....]复制代码
(二)创建相应的api路由
在你的routes/api.php
中
Route::post('login', 'API\UserController@login');Route::post('register', 'API\UserController@register');Route::group(['middleware' => 'auth:api'], function(){ Route::post('details', 'API\UserController@details');});复制代码
(三)创建相应的controller
路径app/Http/Controllers/API/UserController.php
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); } } 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); } public function details() { $user = Auth::user(); return response()->json(['success' => $user], $this->successStatus); }}复制代码
(四)使用rest client来测试api
Login API:
Register API:
Details API:
这个测试前需要添加一些header
信息:
'headers' => [ 'Accept' => 'application/json', 'Authorization' => 'Bearer '.$accessToken,]复制代码