python管理系统秘钥真的很简单

一、思考❓❔

1.应用系统中你的秘钥是如何处理的呢?

  • 将秘钥直接写在程序中
  • 放在环境变量中
  • 随心处理

2.让你揪心的地方?

  • 直接写入程序中不够安全
  • 环境变量中为加密,还是不够安全
  • 没有统一的秘钥管理中心

本文的主角keyring, 可以解决这些问题。



二、安装keyring🔨🔨

# 默认官方源
pip install keyring

# 使用豆瓣源
pip install -i https://pypi.douban.com/simple keyring


三、基本用法💪🏽💪🏽

1.在py文件中使用

创建base_use.py文件

# 1. 导入keyring模块
import keyring

# 2. 设置密码
# 第一个参数为: 应用名(指定在哪一个应用中来使用)
# 第二个参数为: 用户名
# 第三个参数为: 密码
keyring.set_password('api', 'user1', 'keyou520')

# 3. 获取密码
# 第一个参数为: 应用名(指定在哪一个应用中来使用)
# 第二个参数为: 用户名
my_password = keyring.get_password('api', 'user1')
print(my_password)

2.在命令行中使用


四、高阶用法🐙🐙

1.生成随机密码并存储

  • 可以生成任意位数的随机密码(包含数字、字母、符号)
  • 可以生成任意位数的仅数字密码
  • 可以生成任意位数的仅字母密码
  • 可以获取所有应用名
  • 可以获取指定应用名下的所有账号
  • 可以通过用户名获取所有应用下的账号
  • 可以获取某个应用下指定用户名的密码
  • 可以删除某个应用下指定用户名的账号
  • 其他功能, 读者可以在我的基础上再添加新的功能, 一起来完善这个有意思的小程序
import random
import string

import keyring


class MyPasswd:
    """
    生成随机密码
    """
    app_names = {}

    @classmethod
    def _set_password(cls, servicename, username, sample_content, passwd_num):
        """
        设置密码
        :param servicename: 应用名
        :param username: 用户名
        :param sample_content: 用于生成随机密码的样本字符
        :param passwd_num: 生成密码位数
        :return:
        """
        # 密码的位数必须为正整数
        if isinstance(passwd_num, int) and passwd_num > 0:
            one_list = random.choices(sample_content, k=passwd_num)
            password = ''.join(one_list)

            # 设置密码
            keyring.set_password(servicename, username, password)
            names_list = cls.app_names.get(servicename, [])
            names_list.append(username)
            cls.app_names[servicename] = names_list
        else:
            raise TypeError('密码的位数必须为正整数!')

    @classmethod
    def generate_random_passwd(cls, servicename, username, passwd_num=6):
        """
        生成随机密码, 可以为数字、字母、标点符号
        :param servicename: 应用名
        :param username: 用户名
        :param passwd_num: 密码位数, 为int类型
        :return:
        """
        sample_content = string.ascii_letters + string.digits + string.punctuation
        cls._set_password(servicename, username, sample_content, passwd_num)

    @classmethod
    def generate_digit_passwd(cls, servicename, username, passwd_num=6):
        """
        生成随机的仅数字密码
        :param servicename: 应用名
        :param username: 用户名
        :param passwd_num: 密码位数, 为int类型
        :return:
        """
        sample_content = string.digits
        cls._set_password(servicename, username, sample_content, passwd_num)

    @classmethod
    def generate_letter_passwd(cls, servicename, username, passwd_num=6):
        """
        生成随机的仅字母密码
        :param servicename: 应用名
        :param username: 用户名
        :param passwd_num: 密码位数, 为int类型
        :return:
        """
        sample_content = string.ascii_letters
        cls._set_password(servicename, username, sample_content, passwd_num)

    @classmethod
    def generate_digit_letter_passwd(cls, servicename, username, passwd_num=6):
        """
        生成随机的仅字母和数字密码
        :param servicename: 应用名
        :param username: 用户名
        :param passwd_num: 密码位数, 为int类型
        :return:
        """
        sample_content = string.ascii_letters + string.digits
        cls._set_password(servicename, username, sample_content, passwd_num)

    @staticmethod
    def get_password(servicename, username):
        """
        获取某个应用下指定用户名的密码
        :param servicename: 应用名
        :param username: 用户名
        :return:
        """
        return keyring.get_password(servicename, username)

    @staticmethod
    def delete_password(self, servicename, username):
        """
        删除账号
        :param self:
        :param servicename: 应用名
        :param username: 用户名
        :return:
        """
        return keyring.delete_password(servicename, username)

    @classmethod
    def get_all_servicenames(cls):
        """
        获取所有的应用
        :return: 所有应用组成的列表
        """
        return list(cls.app_names.keys())

    @classmethod
    def get_all_acount_by_servicename(cls, servicename):
        """
        获取指定应用下的所有账户名
        :return: 指定应用下的所有账户名组成的列表
        """
        return cls.app_names.get(servicename)

    @classmethod
    def get_password_by_username(cls, username):
        """
        通过用户名获取密码
        :return: 获取这个用户的所有密码
        """
        one_list = []
        for service_name in cls.get_all_servicenames():
            for name in cls.app_names[service_name]:
                if name == username:
                    try:
                        passwd = keyring.get_password(service_name, name)
                    except Exception:
                        continue
                    one_list.append({
                        service_name: passwd
                    })
        return one_list


if __name__ == '__main__':
    MyPasswd.generate_random_passwd('myapi', 'user1', 10)
    MyPasswd.generate_random_passwd('myapi', 'user2', 20)
    MyPasswd.generate_digit_passwd('apitest', 'user1', 8)
    MyPasswd.generate_digit_passwd('apitest', 'user2', 13)
    MyPasswd.generate_digit_letter_passwd('myapi', 'user3', 15)
    MyPasswd.generate_digit_letter_passwd('apitest', 'user4', 18)
    print(MyPasswd.get_password_by_username('user1'))
    print(MyPasswd.app_names)



六、总结💡💡

  • 本文介绍了一种易用的密码管理方法
  • 提供了一个生成随机密码并管理的程序
  • 各位读者可以在随机密码管理程序的基础上添加新的功能
  • 本文为可优原创,有不足之处,请多指教!

posted @ 2019-12-26 11:04  可优  阅读(1909)  评论(0编辑  收藏  举报