美文网首页小知识
用Thinkphp5开发API,前后端分离步骤

用Thinkphp5开发API,前后端分离步骤

作者: wyc0859 | 来源:发表于2019-03-08 17:54 被阅读358次

自定义全局异常处理
跨域问题
修改默认输出类型
自定义路由+强制路由
路由中间件做权限判断

前端访问API如果是TP5的错误提示,那错误是致命的。所以要修改为json格式的错误提示,调试模式仍然报tp5提示

自定义全局异常处理

修改TP5配置文件config/app.php

  'exception_handle'       => '\app\lib\exception\ExceptionHandler',
namespace app\lib\exception;

use think\exception\Handle;
use think\Log;
use think\facade\Request;

class ExceptionHandler extends Handle
{
    private $code;
    private $msg;
    private $errorCode;
    
    // 需要返回客户端当前请求的URL路径
    public function render(\Exception $e)
    {
        if ($e instanceof BaseException)
        {
            //返回自定义的异常提示信息
            $this->code = $e->code;
            $this->msg = $e->msg;
            $this->errorCode = $e->errorCode;
        } else {
            if (config('app_debug')){
                return parent::render($e);//不属于自定义异常类错误,并且当前是调试模式。则返回TP5原异常错误信息
            } else {
                $this->code = 500;
                $this->msg = '服务器内部错误,不想告诉你';
                $this->errorCode = 999;
                //$this->recordErrorLog($e); //记录错误日志
            }
        }
        $result = [
            'msg' => $this->msg,
            'error_code' => $this->errorCode,
            'request_url' => Request::url()   //获取当前访问的URL
        ];
        return json($result, $this->code);
    }
}

前后端分离,免不了跨域问题

跨域问题

修改应用行为扩展定义文件:application\tags.php

// 应用初始化
'app_init'     => [
        'app\\api\\behavior\\CORS'
    ],
namespace app\api\behavior;
class CORS
{
    public function appInit($params)
    {
        header('Access-Control-Allow-Origin: *');
        header("Access-Control-Allow-Headers: token,Origin, X-Requested-With, X_Requested_With,Content-Type, Accept");
        header('Access-Control-Allow-Methods: POST,GET,PUT');
        if(request()->isOptions()){
            exit();
        }
    }
}

既然是api,对外输出当然都是json格式。没必要每次都return json($res);return json_encode($res)

修改默认输出类型

修改TP5配置文件config/app.php,一劳永逸

 'default_return_type'    => 'json',

API肯定是用自定义路由,既然全部都自定义了,那就强制吧

自定义路由+强制路由

app.php中开启强制路由,路由完全匹配
'url_lazy_route' => true
'route_complete_match' => true,

route.php配置自定义路由

Route::get('/', function () {
    return '欢迎使用如花商城';
});
Route::get('/article/getList', 'api/Article/getList');

Route::group('/favorite', function() {
    Route::post('/get_one', 'api/Favorites/scFavGood'); 
});

路由中间件做权限判断

***route.php配置路由中间件***
Route::group('admin', function(){    
    Route::get('/check_login', 'api/Login/check_login');   //检查是否登陆
})->middleware('CheckCms'); //路由中间件
application\http\middleware
namespace app\http\middleware;

//中间件,验证token,检测权限
use app\api\service\TokenService;

class CheckCms{
    public function handle($request, \Closure $next)
    {
        $res = 权限判断code
        if($res == true) {
            return $next($request);
        }
    }
}

相关文章

  • 用Thinkphp5开发API,前后端分离步骤

    自定义全局异常处理跨域问题修改默认输出类型自定义路由+强制路由路由中间件做权限判断 前端访问API如果是TP5的错...

  • 使用spring-boot-starter-swagger实现A

    为什么要实现API文档化? API文档化有利于前后端分离的开展。随着开发方式全面转成前后端分离,前端和后端的唯一沟...

  • Django rest framework 框架

    开发模式普通开发模式(前后端放一起)前后端分离后端开发为前端提供URL(API/接口的开发)Django中的 FB...

  • 前后端分离 跨域

    前提提示:最近的项目中,采用了前后端分离的开发模式。前端通过fetch api访问后端rest api。其间很自然...

  • 有了Swagger2,再也不用为写Api文档头疼了

    1、为什么要写Api文档 现在,前后端分离的开发模式已经非常流行,后端开发工程师只负责完成后端接口,前端页面的开发...

  • springboot集成swagger2生产API文档

    springboot项目中,前后端分离开发,前端页面要调用后端api处理业务就需要知道api接口的详细说明,包括调...

  • 01_搭建环境 CMS服务端开发

    1:=====开发步骤 项目是基于前后端分离的架构进行开发,前后端分离架构总体上包括前端和服务端,通常是多人协作并...

  • Python前后端分离开发项目介绍

    主要技术介绍 Vue+Django REST Framework前后端分离技术 玩转restful api开发流程...

  • swagger简单了解

    前情简介:随着互联网发展,前后端慢慢分离,到最后仅靠API接口联系。于是API文档变成了前后端开发人员联系的...

  • Spec Driven API开发思想在Grails REST工

    前言 在前后台分离的开发中,后端需要维护一套REST API。在开发中API少不了要有变更。在传统的开发中,通常我...

网友评论

    本文标题:用Thinkphp5开发API,前后端分离步骤

    本文链接:https://www.haomeiwen.com/subject/gwhdpqtx.html