前后端分离api安全php,用Thinkphp5开发API,前后端分离步骤

自定义全局异常处理

跨域问题

修改默认输出类型

自定义路由+强制路由

路由中间件做权限判断

前端访问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);

}

}

}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值