1. 程式人生 > 程式設計 >Python sqlalchemy時間戳及密碼管理實現程式碼詳解

Python sqlalchemy時間戳及密碼管理實現程式碼詳解

一、時間戳

實際開發中,我們一般希望create_time和update_time這兩個屬效能自動設定,所以在建表的時候需要在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())

關於datetime轉時間戳的方法,例如‘2020-07-09 14:15:31'(從資料庫讀取一般為字串),首先需要將它轉換成timetuple:

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

如果你拿到的是datetime物件,那麼更簡單:

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

然後將timetuple轉化為時間戳:

timestamp = int(time.mktime(timetuple))

那麼,時間戳又要如何轉回datetime呢?方法如下:

last_time = datetime.datetime.fromtimestamp(timestamp)

二、密碼管理

在資料庫中一般不要明文儲存密碼,可以用雜湊值替換,修改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,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設定成只寫,使用verify_password來校驗密碼。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。