Python sqlalchemy时间戳及密码管理实现代码详解
一、时间戳
实际开发中,我们一般希望create_time和update_time这两个属性能自动设置,所以在建表的时候需要在model上特殊处理一下:
fromsqlalchemy.sqlimportfunc classUser(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-0914:15:31'(从数据库读取一般为字符串),首先需要将它转换成timetuple:
importtime
timetuple=time.strptime('2020-07-0914: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:
fromsqlalchemy.sqlimportfunc
fromwerkzeug.securityimportgenerate_password_hash,check_password_hash
classUser(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
defpassword(self):
raiseAttributeError('passwordisnotareadableattribute')
@password.setter
defpassword(self,password):
self.password_hash=generate_password_hash(password)
defverify_password(self,password):
returncheck_password_hash(self.password_hash,password)
将password设置成只写,使用verify_password来校验密码。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。