溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何實(shí)現(xiàn)Python sqlalchemy時(shí)間戳及密碼管理

發(fā)布時(shí)間:2020-08-03 09:20:46 來(lái)源:億速云 閱讀:350 作者:小豬 欄目:開發(fā)技術(shù)

這篇文章主要講解了如何實(shí)現(xiàn)Python sqlalchemy時(shí)間戳及密碼管理,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。

一、時(shí)間戳

實(shí)際開發(fā)中,我們一般希望create_time和update_time這兩個(gè)屬性能自動(dòng)設(shè)置,所以在建表的時(shí)候需要在model上特殊處理一下:

from sqlalchemy.sql import func

class User(db.Model):
  __tablename__ = 'user'
  id = db.Column(db.Integer, primary_key = True)
  email = db.Column(db.String(128))
  password_hash = db.Column(db.String(128))
  create_time = db.Column(db.DateTime, server_default = func.now())
  update_time = db.Column(db.DateTime, server_default = func.now(), onupdate = func.now())

關(guān)于datetime轉(zhuǎn)時(shí)間戳的方法,例如‘2020-07-09 14:15:31'(從數(shù)據(jù)庫(kù)讀取一般為字符串),首先需要將它轉(zhuǎn)換成timetuple:

import time
timetuple = time.strptime('2020-07-09 14:15:31', '%Y-%m-%d %H:%M:%S')

如果你拿到的是datetime對(duì)象,那么更簡(jiǎn)單:

now = datetime.datetime.now()
timetuple = now.timetuple()

然后將timetuple轉(zhuǎn)化為時(shí)間戳:

timestamp = int(time.mktime(timetuple))

那么,時(shí)間戳又要如何轉(zhuǎn)回datetime呢?方法如下:

last_time = datetime.datetime.fromtimestamp(timestamp)

二、密碼管理

在數(shù)據(jù)庫(kù)中一般不要明文存儲(chǔ)密碼,可以用散列值替換,修改model:

from sqlalchemy.sql import func
from werkzeug.security import generate_password_hash, check_password_hash

class User(db.Model):
  __tablename__ = 'user'
  id = db.Column(db.Integer, primary_key = True)
  email = db.Column(db.String(128))
  password_hash = db.Column(db.String(128))
  create_time = db.Column(db.DateTime, server_default = func.now())
  update_time = db.Column(db.DateTime, server_default = func.now(), onupdate = func.now())

  @property
  def password(self):
    raise AttributeError('password is not a readable attribute')

  @password.setter
  def password(self, password):
    self.password_hash = generate_password_hash(password)
  
  def verify_password(self, password):
    return check_password_hash(self.password_hash, password)

將password設(shè)置成只寫,使用verify_password來(lái)校驗(yàn)密碼。

看完上述內(nèi)容,是不是對(duì)如何實(shí)現(xiàn)Python sqlalchemy時(shí)間戳及密碼管理有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI