<?php

namespace app\admin\controller;

use think\Config;
use think\Controller;
use think\Request;
use think\cache\driver\Redis;

/**
* Class Base
* @package
app\admin\controller
*/
class Base extends Controller
{
/**
* Base constructor.
* @param
Request|null $request
*/
public function __construct(Request $request = null)
{
not_region(true);//允许
parent::__construct($request);
}

static function getAdminKey()
{
$admin_key = Config::get('key')["admin_key"];
return $admin_key;
}

/**
*
@var
*/
protected $head;

/**
*
@var
*/
protected $payload;

/**
* @param
string $iss 发行者
* @param
string $exp 过期时间
* @param
$uid int 用户id
* @return
array
*/
protected function payload($uid)
{
$this->payload = [
'iss'=>request()->domain(),
'exp'=>time(),
'uid'=>$uid,
];
return $this->payload;
}

protected function head()
{
$this->head = [
'type'=>"JWT",
'alg'=>'HA256',
];
return $this->head ;
}

/**

* @param $str
* @return
string
*/
static function baseEn($str)
{
return base64_encode($str);
}

/**
* @param
$str
* @return
string
*/
static function baseDe($str)
{
return base64_decode($str);
}

/**
* @param
$strdata
* @return
string
*/
static function hash_hmac($strdata)
{
$hashSha256 = self::baseEn(hash_hmac("sha256",$strdata,"secret",true));
return $hashSha256;
}

/**
* @param
array $head $this->head();/other
* @param
array $payload $this->payload();/other
* @return
string
*/
static function base64_meger($head=[],$payload=[],$redis)
{
$new_arr = [];
foreach (func_get_args() as $keies)
{
if(is_array($keies)){
$new_arr[] = self::baseEn(json_encode($keies));
}
}
$new_signature = implode('.',$new_arr);
// ----------- 签名生成------
$signature = self::hash_hmac($new_signature);
// ------------保存签名------
self::setRedis($redis,$signature);
$token = $new_signature.'.'.$signature;

return $token;
}

/**
*
* @param Redis $redis

* @param $signature
* @return
bool
*/
protected static function setRedis($redis,$signature)
{
return $redis->set(self::getAdminKey(),$signature);
}

}

实现:

<?php
namespace
app\admin\controller;

use think\cache\driver\Redis;

/**
* Class Index
* @package
app\admin\controller
*/
class Index extends Base
{
public function index(Redis $redis)
{
$token = $this::base64_meger($this->head(),$this->payload(2),$redis);
return $token;
}
}

输出:


jwt实现的更多相关文章

  1. 看图理解JWT如何用于单点登录

    单点登录是我比较喜欢的一个技术解决方案,一方面他能够提高产品使用的便利性,另一方面他分离了各个应用都需要的登录服务,对性能以及工作量都有好处.自从上次研究过JWT如何应用于会话管理,加之以前的项目中也 ...

  2. JWT实现token-based会话管理

    上文<3种web会话管理的方式>介绍了3种会话管理的方式,其中token-based的方式有必要从实现层面了解一下.本文主要介绍这方面的内容.上文提到token-based的实现目前有一个 ...

  3. 用JWT来保护我们的ASP.NET Core Web API

    在上一篇博客中,自己动手写了一个Middleware来处理API的授权验证,现在就采用另外一种方式来处理这个授权验证的问题,毕竟现在也 有不少开源的东西可以用,今天用的是JWT. 什么是JWT呢?JW ...

  4. Laravel-lumen 配置JWT

    具体步骤参照: [ JWT & Lumen ] 第一步 在项目根目录 执行命令 composer require tymon/jwt-auth第二步 在 bootstrap/app.php 的 ...

  5. .net core Jwt 添加

    Jwt 已经成为跨平台身份验证通用方案,如不了解请关注:https://jwt.io/. 为了和微软其他验证模块有个比较好的衔接,项目中采用了微软开发的jwt组件: System.IdentityMo ...

  6. 多说评论系统API调用和本地身份说明(JWT)

    多说评论系统是一个非常好用的第三方评论插件,聚合了大多数的SNS平台账号登录和分享功能,UI也很不错. 作为网站快速接入评论系统,多说是一个比较好的选择,其也提供了一些实用的API去满足定制化需求. ...

  7. 【JWT】JWT+HA256加密 Token验证

    目录 Token验证 传统的Token验证 JWT+HA256验证 回到顶部 Token验证 最近了解下基于 Token 的身份验证,跟大伙分享下.很多大型网站也都在用,比如 Facebook,Twi ...

  8. 基于Token的身份验证——JWT

    初次了解JWT,很基础,高手勿喷. 基于Token的身份验证用来替代传统的cookie+session身份验证方法中的session. JWT是啥? JWT就是一个字符串,经过加密处理与校验处理的字符 ...

  9. jwt refresh token

    $app->post('auth/refresh-token', ['middleware' => 'jwt.refresh', function() { try { $old_token ...

  10. JWT【JSON Web Token】 简述

    draft: http://self-issued.info/docs/draft-ietf-oauth-json-web-token.html http://tools.ietf.org/html/ ...

随机推荐

  1. Leetcode 153. Find Minimum in Rotated Sorted Array -- 二分查找的变种

    Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand. (i.e. ...

  2. Oja’s rule

    目录 Oja's rule 背景 Hebbian learning 主要的一些理论 论文里面一些主要的假设 引理1 引理2 引理3 定理1 LEMMA 3(ALL) 引理 4 定理 2 定理 3(关于 ...

  3. [2017BUAA软工助教]个人项目准备工作

    BUAA软工个人项目准备工作 零.注册Github个人账号(你不会没有吧..) 这是Git的使用教程: http://www.cnblogs.com/schaepher/p/5561193.html ...

  4. MySQL unknown variable 'default-character-set=utf8'的解决

    Windows07 安装了MySQL-server-5.5,直接在命令行输入net start mysql ,启动mysql成功, 然后修改/MySQL Server 5.5/my.ini,增加了de ...

  5. 【学亮IT手记】MySql行列转换案例

    create table score( name ), math int, english int ); ,); ,); ,); ,); SHOW tables; SELECT * from scor ...

  6. MyBatis映射文件1(增删改、insert获取自增主键值)

    增删改 Mybatis为我们提供了<insert>.<update>.<delete>标签来对应增删改操作 在接口中写增删改的抽象方法 void addEmp(Em ...

  7. 校园电商项目2(基于SSM)——模块设计

    步骤一:各模块职责 步骤二:实体类设计 package com.figsprite.o2o.bean; import java.util.Date; public class Area { priva ...

  8. 修改tomcat控制台title的方法

    修改tomcat控制台title的方法,参考:http://www.jspkongjian.net/news.jsp?id=1125,具体如图:

  9. Mysql如何快速插入100万条记录?

    1.java程序拼接insert带多个value,使一次提交多个值. 2.插入数据之前先删除索引(注意主键不能删除),然后插入数据,最后重建索引 3.可以设置手动commit,用来提高效率 4.使用批 ...

  10. netstat -na 查看有大量TIME_WAIT解决办法(修改内核参数)

    # netstat -an|awk '/tcp/ {print $6}'|sort|uniq -c      16 CLOSING     130 ESTABLISHED     298 FIN_WA ...