laravel5.5入门(dingo+jwt)

首先我们确保本机已经配置好PHP和mysql。

一、创建项目

composer create-project --prefer-dist laravel/laravel hello "5.5.*"

 所有问题默认回答y,等待命令执行完毕。laravel的脚手架确实还是非常好用,这样一个新的项目就已经创建完毕了,可以直接运行查看。

cd hello
php artisan serve

正常的话我们就可以在浏览器输入http://127.0.0.1:8000看到Laravel样式的输出。

二、VUE2环境配置

首先需要确保本机安装好了node.js,我这里用的是nvm来管理的,安装的版本是15.14.0

因为laravel内置的依赖有些过时,我们需要对package.json做一些调整,如下:

(注意:后续的操作将在phpstorm中进行)

"devDependencies": {
        "axios": "0.17",
        "bootstrap-sass": "3.3.7",
        "cross-env": "5.1",
        "jquery": "3.2",
        "laravel-mix": "5.0.9",
        "lodash": "4.17.4",
        "node-sass": "^5.0.0",
        "resolve-url-loader": "^3.1.0",
        "sass": "^1.78.0",
        "sass-loader": "10.0.5",
        "vue": "2.7.16",
        "vue-template-compiler": "^2.7.16"
    }

配置好后执行下面的命令安装依赖:

npm install

注意:这里npm安装可能不成功,可以考虑换cnpm或者设置代理,具体怎么操作请自行百度。

三、测试VUE2

因为VUE2版本的问题laravel自带的示例不能直接编译通过的,这里我们需要修改三个文件,如下图所示:

 welcome.blade.php内容如下:

<!doctype html>
<html lang="{{ app()->getLocale() }}">
    <head>
        <meta charset="utf-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1">
        <title>Laravel</title>
        <!-- Fonts -->
        <link href="https://fonts.googleapis.com/css?family=Raleway:100,600" rel="stylesheet" type="text/css">
    </head>
    <body>
        <div id="app">
        </div>
    </body>
    <script src="{{ mix('js/app.js') }}"></script>
</html>

app.js内容如下:

require('./bootstrap');

window.Vue = require('vue');
import Hello from './components/Hello.vue'; // 引入Hello 组件

const app = new Vue({
    el: '#app',
    render: h => h(Hello)
});

Hello.vue内容如下:

<template>
  <div>
    <h1>Hello, Laravel</h1>
    <p class="hello">{{ msg }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      msg: '欢迎使用vue2.0!'
    }
  }
}
</script>

<style>
.hello {
  font-size: 2em;
  color: green;
}
</style>

然后在项目目录执行如下命令:

npm run dev

编译通过后我们可以再次启动网站,命令如下:

php artisan serve

打开浏览器输入:http://127.0.0.1:8000,正常应该会得到如下的页面显示:

四、配置config/app.php

这里我们仅仅简单调整一下时区和语言配置

'timezone' => 'Asia/Shanghai',
    'locale' => 'zh-CN',
    'faker_locale' => 'zh_CN',

配置生效:

php artisan config:clear

五、创建自己的路由

5.1、创建控制器

在项目目录下执行命令:

php artisan make:controller Home/IndexController

修改IndexController.php内容如下:

<?php

namespace App\Http\Controllers\Home;

use Illuminate\Http\Request;
use App\Http\Controllers\Controller;

class IndexController extends Controller
{
    public function index()
    {
        return 'ok';
    }
}

 5.2、路由配置

在routes/web.php中添加到index()方法的路由:

<?php

Route::get('/', function () {
    return view('welcome');
});

Route::get('/home', 'Home\IndexController@index')->name('home');

再次运行网站:

php artisan serve

在浏览器中输入:http://127.0.0.1:8000/home

 六、dingo+jwt依赖安装及配置

6.1、升级依赖

修改composer.json添加相关依赖,最终的文件内容如下:

{
    "name": "laravel/laravel",
    "description": "The Laravel Framework.",
    "keywords": ["framework", "laravel"],
    "license": "MIT",
    "type": "project",
    "require": {
        "php": ">=7.0.0",
        "fideloper/proxy": "~3.3",
        "laravel/framework": "5.5.*",
        "laravel/tinker": "~1.0",
        "dingo/api": "2.4.7",
        "tymon/jwt-auth": "1.0.2"
    },
    "require-dev": {
        "filp/whoops": "~2.0",
        "fzaninotto/faker": "~1.4",
        "mockery/mockery": "~1.0",
        "phpunit/phpunit": "~6.0",
        "symfony/thanks": "^1.0"
    },
    "autoload": {
        "classmap": [
            "database/seeds",
            "database/factories"
        ],
        "psr-4": {
            "App\\": "app/"
        }
    },
    "autoload-dev": {
        "psr-4": {
            "Tests\\": "tests/"
        }
    },
    "extra": {
        "laravel": {
            "dont-discover": [
            ]
        }
    },
    "scripts": {
        "post-root-package-install": [
            "@php -r \"file_exists('.env') || copy('.env.example', '.env');\""
        ],
        "post-create-project-cmd": [
            "@php artisan key:generate"
        ],
        "post-autoload-dump": [
            "Illuminate\\Foundation\\ComposerScripts::postAutoloadDump",
            "@php artisan package:discover"
        ]
    },
    "config": {
        "preferred-install": "dist",
        "sort-packages": true,
        "optimize-autoloader": true,
        "allow-plugins": {
            "kylekatarnls/update-helper": true,
            "symfony/thanks": true
        }
    }
}

添加的部分内容如下:

"dingo/api": "2.4.7",
"tymon/jwt-auth": "1.0.2"

安装dingo/api的时候会需要访问github得到token,申请的网址为:https://github.com/settings/tokens

如果不想申请也可以考虑把这个依赖降级为2.2.3。

配置完成后我们升级一下依赖:

composer update

6.2、配置config/app.php

找到providers配置,在数组最后添加如下内容:

Dingo\Api\Provider\LaravelServiceProvider::class,
Tymon\JWTAuth\Providers\LaravelServiceProvider::class,

找到aliases配置,在数组最后添加如下内容:

'JWTAuth' => Tymon\JWTAuth\Facades\JWTAuth::class,
'JWTFactory' => Tymon\JWTAuth\Facades\JWTFactory::class,

6.3、发布配置文件

生成config/api.php

php artisan vendor:publish --provider="Dingo\Api\Provider\LaravelServiceProvider"

生成config/jwt.php

php artisan vendor:publish --provider="Tymon\JWTAuth\Providers\LaravelServiceProvider"

6.4、生成 JWT_SECRET 

php artisan jwt:secret

6.5、配置config/api.php

auth部分添加下面的代码(数组中):

'jwt' => Dingo\Api\Auth\Provider\JWT::class

6.6、环境变量(.env文件)配置dingo

# 环境
API_STANDARDS_TREE=vnd
# 子类型
API_SUBTYPE=hello
# 前缀
API_PREFIX=api
# 子域名  (前缀和子域名只能存在一个)可选,不用就必须注释掉
#API_DOMAIN=localhost
# 版本
API_VERSION=v1
# 名字(使用API Blueprint命令才会用到)
API_NAME='HelloApi'
# 带条件的请求
API_CONDITIONAL_REQUEST=false
# Strict模式
API_STRICT=false
# 响应格式
API_DEFAULT_FORMAT=json
# 调试模式
API_DEBUG=true

七、数据库准备

7.1、建库

 在mysql数据库中建立laravel5数据库:

create database if not exists laravel5 default character set utf8mb4 default collate utf8mb4_general_ci;

7.2、数据库连接配置(.env文件)

 请根据实际情况来配置:

DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3326
DB_DATABASE=laravel5
DB_USERNAME=root
DB_PASSWORD=yujsh123456

7.3、生成数据库

执行命令如下:

php artisan migrate

最后查看数据库创建情况:

八、API权限示例

8.1、创建AuthController

php artisan make:controller Home/AuthController

具体代码如下:

<?php

namespace App\Http\Controllers\Home;

use App\Http\Controllers\Controller;
use Dingo\Api\Routing\Helpers;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Log;
use App\User;

class AuthController extends Controller
{
    use Helpers;

    protected $guard = 'api';
    public function __construct()
    {
        $this->middleware('auth:api', ['except' => ['login','register']]);
    }

    public function test(){
        echo "test!!";
    }

    public function register(Request $request)
    {
        $payload = $request->only('name', 'email', 'password');
//        Log::info($payload);
        $result = User::create([
            'name' => $payload['name'],
            'email' => $payload['email'],
            'password' => bcrypt($payload['password']),
        ]);
        if ($result) {
            return $this->response->array(['success' => '创建用户成功']);
        } else {
            return $this->response->array(['error' => '创建用户失败']);
        }
    }

    public function login(Request $request)
    {
        $credentials = $request->only('email', 'password');
        if ($token = $this->guard()->attempt($credentials)) {
            return $this->respondWithToken($token);
        }
        return $this->response->errorUnauthorized('登录失败');
    }

    public function me()
    {
        return $this->response->array($this->guard()->user());
    }

    public function logout()
    {
        $this->guard()->logout();
        return $this->response->array(['message' => '退出成功']);
    }

    public function refresh()
    {
        return $this->respondWithToken($this->guard()->refresh());
    }

    protected function respondWithToken($token)
    {
        return response()->json([
            'access_token' => $token,
            'token_type' => 'bearer',
            'expires_in' => $this->guard()->factory()->getTTL() * 60
        ]);
    }

    public function guard()
    {
        return Auth::guard($this->guard);
    }
}

8.2、调整app/User.php

我们需要增加对jwt的支持,具体调整后的代码如下:

<?php

namespace App;

use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Tymon\JWTAuth\Contracts\JWTSubject;

class User extends Authenticatable implements JWTSubject
{
    use Notifiable;
    protected $fillable = [
        'name', 'email', 'password',
    ];
    protected $hidden = [
        'password', 'remember_token',
    ];

    public function getJWTIdentifier()
    {
        return $this->getKey();
    }

    public function getJWTCustomClaims()
    {
        return [];
    }
}

8.3、配置config/auth.php

<?php

return [
    'defaults' => [
        'guard' => 'api',
        'passwords' => 'users',
    ],
    'guards' => [
        'web' => [
            'driver' => 'session',
            'provider' => 'users',
        ],

        'api' => [
            'driver' => 'jwt',
            'provider' => 'users',
        ],
    ],
    'providers' => [
        'users' => [
            'driver' => 'eloquent',
            'model' => App\User::class,
        ],
    ],
    'passwords' => [
        'users' => [
            'provider' => 'users',
            'table' => 'password_resets',
            'expire' => 60,
        ],
    ],

];

8.4、配置路由(routes/api.php)

<?php
use Illuminate\Support\Facades\Log;
//接管路由
$api = app('Dingo\Api\Routing\Router');

Auth::routes();

app('Dingo\Api\Exception\Handler')->register(function (Illuminate\Validation\ValidationException $exception) {
    $errors = array_values($exception->errors());
    app('Dingo\Api\Exception\Handler')->setErrorFormat([
        'message' => $errors[0][0],
        'code' => ':code',
        'status_code' => ':status_code',
        'debug' => ':debug'
    ]);

});

app('Dingo\Api\Exception\Handler')->setErrorFormat([
    'message' => ':message',
    'errors' => ':errors',
    'code' => ':code',
    'status_code' => ':status_code',
    'debug' => ':debug'
]);

app('Dingo\Api\Exception\Handler')->register(function (Illuminate\Auth\AuthenticationException $exception) {
    return Response::make(['message' => trans('auth.user_not_logged_in'), 'status_code' => 401], 401);
});

app('Dingo\Api\Exception\Handler')->register(function (Symfony\Component\HttpKernel\Exception\NotFoundHttpException $exception) {
//    Log::info($exception);
    return Response::make(['message' => trans('exception.data_not_exist'), 'status_code' => 404], 404);
});

$api->version('v1',['namespace'=>'App\Http\Controllers\Home'], function ($api) {
    $api->group(['prefix'=>'auth'],function ($api){
        $api->get('test', 'AuthController@test');
        $api->post('register', 'AuthController@register');
        $api->post('login', 'AuthController@login');
        $api->post('logout', 'AuthController@logout');
        $api->post('refresh', 'AuthController@refresh');
        $api->post('me', 'AuthController@me');
    });

});

8.5、测试(postman)

register

login

test(token过期)

test(正常)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值