Python sqlalchemy時(shí)間戳及密碼管理實(shí)現(xiàn)代碼詳解
一、時(shí)間戳
實(shí)際開發(fā)中,我們一般希望create_time和update_time這兩個(gè)屬性能自動(dòng)設(shè)置,所以在建表的時(shí)候需要在model上特殊處理一下:
from sqlalchemy.sql import funcclass 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 timetimetuple = 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 funcfrom werkzeug.security import generate_password_hash, check_password_hashclass 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來校驗(yàn)密碼。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. Docker與iptables及實(shí)現(xiàn)bridge方式網(wǎng)絡(luò)隔離與通信操作2. HTML <!DOCTYPE> 標(biāo)簽3. python中scrapy處理項(xiàng)目數(shù)據(jù)的實(shí)例分析4. 基于PHP與XML的PDF文檔生成技術(shù)5. WWDC總結(jié):開發(fā)者需要知道的iOS 9 SDK新特性6. Python requests庫(kù)參數(shù)提交的注意事項(xiàng)總結(jié)7. 將properties文件的配置設(shè)置為整個(gè)Web應(yīng)用的全局變量實(shí)現(xiàn)方法8. ASP基礎(chǔ)入門第三篇(ASP腳本基礎(chǔ))9. jsp文件下載功能實(shí)現(xiàn)代碼10. AJAX的跨域問題解決方案
