为了账号安全,请及时绑定邮箱和手机立即绑定

Python-web系统初始化的设计与实现

标签:
Python

简介


本文针对后端服务初始化时,用户表的创建流程与具体实现做介绍。

Motor是一个异步非阻塞的MongoDB驱动程序,很好地支持了Tornado和asyncio的应用。
基于Tornado开发的后端server,为了提供优秀的系统性能通常会大量使用异步编程,因此Motor是此类系统操作MongoDB时的不二之选。
下面基于特定的场景,介绍系统初始化时涉及到的Motor操作MongoDB的方法:

设计


对于一个系统初始化,我设计为在首次访问系统时会自动创建一个admin用户用于后面的登录。

流程图:

首次访问系统的流程


这里面涉及到:

  1. 连接数据库

  2. 查询数据库是否有Users表

  3. 插入一条数据(插入数据时会自动创建表)

实现


下面分点介绍实现过程:

连接数据库

首先写一个异步连接数据库方法,使用Motor库的AsyncIOMotorClient类初始化连接:

from motor.motor_asyncio import AsyncIOMotorClient as MotorClientasync def conn_mongo():
    conn = MotorClient('localhost', 27017)
    db = conn.qaadmin    return db

注意:

  • 连接数据库的配置以你本人的环境为准;

  • 需要提前创建一个qaadmin数据库。

查询数据库是否有Users表

使用MotorDatabase类的list_collection_names方法来获取数据库中的所有collection名的列表,再判断Users是否在列表中来判断是否创建过用户:

async def user_check(self):
    collections = await conn_mongo.list_collection_names()    if 'Users' in collections:        return True
    else:        return False

插入用户数据

对于用户密码,在数据库中需要加密后存储。原始密码加盐后,使用md5加密:

import hashlibdef encrypt_password(origin: str, salt: int) -> str:
    """
    md5随机数加密用户密码
    :param origin: 原始密码
    :param salt:
    :return:
    """
    string = origin + str(salt)    return hashlib.md5(string.encode(encoding='utf-8')).hexdigest()

使用MotorColletion类的insert_one方法实现数据的插入,整个系统初始化部分对数据库的操作代码如下:

from libs.crypto import encrypt_passwordimport randomasync def user_check(self):
    collections = await conn_mongo.list_collection_names()    if 'Users' in collections:        return
    else:
        salt = random.randint(10, 99)
        new_user = {            'salt': salt,            'username': 'admin',            "password": encrypt_password('admin', salt)}
        result = await conn_mongo.Users.insert_one(new_user)
        print('Create user: admin, inserted id: %s' % repr(result.inserted_id))

参考


[1] MotorDatabase.list_collection_names
[2] inserting-a-document



作者:严北
链接:https://www.jianshu.com/p/e6c574ee3a95


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消