国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:2日期:2022-07-15 14:01:19

一、時間戳

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

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

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 江孜县| 武隆县| 拉萨市| 惠州市| 桂东县| 万山特区| 桃园市| 法库县| 朝阳区| 布尔津县| 嫩江县| 磴口县| 革吉县| 巴彦淖尔市| 浏阳市| 崇义县| 安多县| 淮安市| 从化市| 莒南县| 永州市| 青州市| 龙海市| 当阳市| 湘阴县| 什邡市| 天门市| 阳春市| 沾化县| 宽城| 全椒县| 静海县| 神木县| 赤壁市| 祁门县| 松溪县| 安化县| 周口市| 南岸区| 五原县| 长子县|