亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python用摘要算法生成token及檢驗(yàn)token的示例代碼

 更新時間:2020年12月01日 15:37:37   作者:希希大隊(duì)長  
這篇文章主要介紹了Python用摘要算法生成token及檢驗(yàn)token的示例代碼,幫助大家更好的理解和學(xué)習(xí)python,感興趣的朋友可以了解下
# 基礎(chǔ)版,不依賴環(huán)境

import time
import base64
import hashlib
class Token_hander():
  def __init__(self,out_time):
    self.out_time = out_time
    self.time = self.timer
    pass
  def timer(self):
    return time.time()

  def hax(self,str):
    """
    摘要算法加密
    :param str: 待加密字符串
    :return: 加密后的字符串
    """
    if not isinstance(str,bytes): # 如果傳入不是bytes類型,則轉(zhuǎn)為bytes類型
      try:
        str = bytes(str,encoding="utf8")
      except BaseException as ex:
        raise ValueError("'%s'不可被轉(zhuǎn)換為bytes類型"%str)

    md5 = hashlib.md5()
    md5.update("天王蓋地虎erafe23".encode(encoding='utf-8'))
    md5.update(str)
    md5.update("992ksd上山打老虎da".encode(encoding='utf-8'))
    return md5.hexdigest()

  def build_token(self,message):
    """
    hax_message: 待加密字符串內(nèi)容 格式: '當(dāng)前時間戳:message:過期時間戳'
    :param message: 需要生成token的字符串
    :param time: 過期時間
    :return: token
    """
    hax_message = "%s:%s:%s"%(str(self.time()),message,
                    str(float(self.time())+float(self.out_time)))
    hax_res = self.hax(hax_message)
    token = base64.urlsafe_b64encode(("%s:%s"%(hax_message,hax_res)).encode(encoding='utf-8'))
    return token.decode("utf-8")

  def check_token(self,token):
    """

    :param token: 待檢驗(yàn)的token
    :return: False  or new token
    """
    try:
      hax_res = base64.urlsafe_b64decode(token.encode("utf8")).decode("utf-8")
      message_list = hax_res.split(":")
      md5 = message_list.pop(-1)
      message = ':'.join(message_list)
      if md5 != self.hax(message):
        # 加密內(nèi)容如果與加密后的結(jié)果不符即token不合法
        return False
      else:
        if self.time() - float(message_list.pop(-1)) >0:
          # 超時返回False
          return False
        else:
          # token驗(yàn)證成功返回新的token
          return self.build_token(message_list.pop(-1))
    except BaseException as ex:
      # 有異常表明驗(yàn)證失敗或者傳入?yún)?shù)不合法
      return False

# 測試
if __name__ == '__main__':
  token_hand = Token_hander(5)
  token = token_hand.build_token(b'dxxx')
  print(token_hand.check_token(token))
  time.sleep(5)
  print(token_hand.check_token(token))
# 封裝成Django源碼版
# 依賴Django運(yùn)行環(huán)境,不可單獨(dú)測試,需運(yùn)行Django環(huán)境,
# 需要在settings配置文件中配置 OUT_TIME = 時間 ,以秒為單位

import os
import time
import base64
import hashlib
import importlib
ENVIRONMENT_VARIABLE = "DJANGO_SETTINGS_MODULE"


class Token_hander():
  def __init__(self):
    self.out_time = self.getOutTime()
    self.time = self.timer


    pass
  def timer(self):
    return time.time()


  def getOutTime(self):
    module = importlib.import_module(os.environ.get(ENVIRONMENT_VARIABLE))
    return getattr(module, "OUT_TIME",60)  # 在settings配置文件中找 OUT_TIME 變量,如果沒有,默認(rèn)60秒

  def hax(self,str):
    """
    摘要算法加密
    :param str: 待加密字符串
    :return: 加密后的字符串
    """
    if not isinstance(str,bytes): # 如果傳入不是bytes類型,則轉(zhuǎn)為bytes類型
      try:
        str = bytes(str,encoding="utf8")
      except BaseException as ex:
        raise ValueError("'%s'不可被轉(zhuǎn)換為bytes類型"%str)

    md5 = hashlib.md5()
    md5.update("天王蓋地虎erafe23".encode(encoding='utf-8'))
    md5.update(str)
    md5.update("992ksd上山打老虎da".encode(encoding='utf-8'))
    return md5.hexdigest()

  def build_token(self,message):
    """
    hax_message: 待加密字符串內(nèi)容 格式: '當(dāng)前時間戳:message:過期時間戳'
    :param message: 需要生成token的字符串
    :param time: 過期時間
    :return: token
    """
    hax_message = "%s:%s:%s"%(str(self.time()),message,
                    str(float(self.time())+float(self.out_time)))
    hax_res = self.hax(hax_message)
    token = base64.urlsafe_b64encode(("%s:%s"%(hax_message,hax_res)).encode(encoding='utf-8'))
    return token.decode("utf-8")

  def check_token(self,token):
    """

    :param token: 待檢驗(yàn)的token
    :return: False  or new token
    """
    try:
      hax_res = base64.urlsafe_b64decode(token.encode("utf8")).decode("utf-8")
      message_list = hax_res.split(":")
      md5 = message_list.pop(-1)
      message = ':'.join(message_list)
      if md5 != self.hax(message):
        # 加密內(nèi)容如果與加密后的結(jié)果不符即token不合法
        return False
      else:
        if self.time() - float(message_list.pop(-1)) >0:
          # 超時返回False
          return False
        else:
          # token驗(yàn)證成功返回新的token
          return self.build_token(message_list.pop(-1))
    except BaseException as ex:
      # 有異常表明驗(yàn)證失敗或者傳入?yún)?shù)不合法
      return False
# 封裝成Django模塊,也依賴Django運(yùn)行環(huán)境 
# 需要在settings配置文件中配置 OUT_TIME = 時間 , 秒為單位


import time
import base64
import hashlib
from django.conf import settings


class Token_hander():
  def __init__(self):
    self.out_time = self.getOutTime()
    self.time = self.timer


    pass
  def timer(self):
    return time.time()


  def getOutTime(self):
    try:
      return settings.__getattr__("OUT_time")  # 在導(dǎo)入的settings中找 OUT_TIME 變量
    except BaseException:
      return 60  # 找不到默認(rèn)60 也可以設(shè)置直接拋異常

  def hax(self,str):
    """
    摘要算法加密
    :param str: 待加密字符串
    :return: 加密后的字符串
    """
    if not isinstance(str,bytes): # 如果傳入不是bytes類型,則轉(zhuǎn)為bytes類型
      try:
        str = bytes(str,encoding="utf8")
      except BaseException as ex:
        raise ValueError("'%s'不可被轉(zhuǎn)換為bytes類型"%str)

    md5 = hashlib.md5()
    md5.update("天王蓋地虎erafe23".encode(encoding='utf-8'))
    md5.update(str)
    md5.update("992ksd上山打老虎da".encode(encoding='utf-8'))
    return md5.hexdigest()

  def build_token(self,message):
    """
    hax_message: 待加密字符串內(nèi)容 格式: '當(dāng)前時間戳:message:過期時間戳'
    :param message: 需要生成token的字符串
    :param time: 過期時間
    :return: token
    """
    hax_message = "%s:%s:%s"%(str(self.time()),message,
                    str(float(self.time())+float(self.out_time)))
    hax_res = self.hax(hax_message)
    token = base64.urlsafe_b64encode(("%s:%s"%(hax_message,hax_res)).encode(encoding='utf-8'))
    return token.decode("utf-8")

  def check_token(self,token):
    """

    :param token: 待檢驗(yàn)的token
    :return: False  or new token
    """
    try:
      hax_res = base64.urlsafe_b64decode(token.encode("utf8")).decode("utf-8")
      message_list = hax_res.split(":")
      md5 = message_list.pop(-1)
      message = ':'.join(message_list)
      if md5 != self.hax(message):
        # 加密內(nèi)容如果與加密后的結(jié)果不符即token不合法
        return False
      else:
        if self.time() - float(message_list.pop(-1)) >0:
          # 超時返回False
          return False
        else:
          # token驗(yàn)證成功返回新的token
          return self.build_token(message_list.pop(-1))
    except BaseException as ex:
      # 有異常表明驗(yàn)證失敗或者傳入?yún)?shù)不合法
      return False

以上就是Python用摘要算法生成token及檢驗(yàn)token的示例代碼的詳細(xì)內(nèi)容,更多關(guān)于Python用摘要算法生成token的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • yolov5 win10 CPU與GPU環(huán)境搭建過程

    yolov5 win10 CPU與GPU環(huán)境搭建過程

    這篇文章主要介紹了yolov5 win10 CPU與GPU環(huán)境搭建過程,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-04-04
  • Python圖像處理Pillow庫的基礎(chǔ)使用

    Python圖像處理Pillow庫的基礎(chǔ)使用

    Pillow庫是Python中最流行的圖像處理庫之一,它是PIL(Python Imaging Library)的一個分支,提供了豐富的圖像處理功能,使圖像處理變得簡單而高效,在這篇文章中,我們將探討Pillow庫的一些基本功能,感興趣的朋友可以參考下
    2023-09-09
  • 詳解Pytest測試用例的執(zhí)行方法

    詳解Pytest測試用例的執(zhí)行方法

    大家應(yīng)該都知道pytest是一個非常成熟的全功能的Python測試框架,接下來通過本文給大家分享Pytest測試用例的執(zhí)行方法,感興趣的朋友一起看看吧
    2021-05-05
  • 如何利用AJAX獲取Django后端數(shù)據(jù)詳解

    如何利用AJAX獲取Django后端數(shù)據(jù)詳解

    ajax一個前后臺配合的技術(shù),它可以讓javascript發(fā)送http請求,與后臺通信,獲取數(shù)據(jù)和信息。下面這篇文章主要介紹了如何利用AJAX獲取Django后端數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • 配置python連接oracle讀取excel數(shù)據(jù)寫入數(shù)據(jù)庫的操作流程

    配置python連接oracle讀取excel數(shù)據(jù)寫入數(shù)據(jù)庫的操作流程

    這篇文章主要介紹了配置python連接oracle,讀取excel數(shù)據(jù)寫入數(shù)據(jù)庫,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • Python學(xué)習(xí)之time模塊的基本使用

    Python學(xué)習(xí)之time模塊的基本使用

    這篇文章主要給大家介紹了關(guān)于Python學(xué)習(xí)之time模塊基本使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • python批量更改目錄名/文件名的方法

    python批量更改目錄名/文件名的方法

    這篇文章主要介紹了python批量更改目錄名/文件名的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-04-04
  • 在Python中使用NLTK庫實(shí)現(xiàn)對詞干的提取的教程

    在Python中使用NLTK庫實(shí)現(xiàn)對詞干的提取的教程

    這篇文章主要介紹了在Python中使用NLTK庫實(shí)現(xiàn)對詞干的提取的教程,其中還用到了Pandas和IPython,需要的朋友可以參考下
    2015-04-04
  • 基于Python編寫一個簡單的服務(wù)注冊發(fā)現(xiàn)服務(wù)器

    基于Python編寫一個簡單的服務(wù)注冊發(fā)現(xiàn)服務(wù)器

    我們都知道有很多的非常著名的注冊服務(wù)器,例如:?Consul、ZooKeeper、etcd,甚至借助于redis完成服務(wù)注冊發(fā)現(xiàn)。但是本篇文章我們將使用python?socket寫一個非常簡單的服務(wù)注冊發(fā)現(xiàn)服務(wù)器,感興趣的可以了解一下
    2023-04-04
  • pandas返回缺失值位置的方法實(shí)例教程

    pandas返回缺失值位置的方法實(shí)例教程

    當(dāng)我們用python進(jìn)行數(shù)據(jù)處理時會遇到很多缺失值,缺失值一般是由于我們所處理的數(shù)據(jù)本身的特性、當(dāng)初錄入的失誤或者其它原因?qū)е碌?下面這篇文章主要給大家介紹了關(guān)于pandas返回缺失值位置的方法,需要的朋友可以參考下
    2022-01-01

最新評論