php 跨域 验证_登录及跨域验证

~~~

/**

* Created by PhpStorm.

* User: RT003

* Date: 2019/9/24

* Time: 14:47

*/

namespace app\http\middleware;

use think\cache\driver\Redis;

class Base

{

public function handle($request, \Closure $next)

{

//跨域访问的时候才会存在此字段

$origin = isset($_SERVER['HTTP_ORIGIN']) ? $_SERVER['HTTP_ORIGIN'] : '';

// 设置多个域名跨域

$allow_origin = array(

'http://localhost:9528',

'http://localhost:8080',

'http://localhost:8081',

'http://192.168.0.187:8080',

'http://192.168.0.187:8081',

'http://127.0.0.1',

'http://192.168.0.128:98',

'http://192.168.0.189:9528'

);

if(in_array($origin, $allow_origin)){

header('Access-Control-Allow-Origin:'.$origin);

}

header('Access-Control-Allow-Methods: GET, POST, OPTIONS');

header('Access-Control-Allow-Headers: x-requested-with, content-type, X-Token');

header('Content-Type: text/html; charset=utf-8');// 返回数据类型

header('Access-Control-Allow-Credentials: true');// 是否可以携带cookie

// 拦截http预请求

if(request()->isOptions()){

exit;

}

//POST请求入口

if(request()->isPost()||request()->isGet()) {

// 获取token

$token = request()->header()['x-token'];

$redis = new Redis();

// 判断token

if (!$token || !$redis->get($token)){

unset($redis);

apiJson(401,'请先登录!')->getContent();die;

}

unset($redis);

}else{

apiJson(401,'请求失败')->getContent();die;

}

// $weChat = new WeChat();

// $weChat->saveFormId();

return $next($request);

}

}

~~~

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值