python sqlsever 时间_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來校驗密碼。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持我們。
本文標題: Python sqlalchemy時間戳及密碼管理實現代碼詳解
本文地址: http://www.cppcns.com/jiaoben/python/329600.html
總結
以上是生活随笔為你收集整理的python sqlsever 时间_Python sqlalchemy时间戳及密码管理实现代码详解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 矩阵键盘程序_独立按键与矩阵按键
- 下一篇: 驱动人生2008_驱动人生致敬深圳经济特