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, 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設置成只寫,使用verify_password來校驗密碼。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM