简单的密码管理器(Python)(待完善)

Posted wzzdeblog

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了简单的密码管理器(Python)(待完善)相关的知识,希望对你有一定的参考价值。

需要使用的库:pymssql(用于连接SQL Server), PyQt5(用于窗口的制作)

 

首先编写DOS界面的密码生成器,以及将程序与数据库相连接,用于存储和查询

PasswordDOS.py

 1 from random import randint
 2 import pymssql
 3 
 4 
 5 def connect_to_sql():
 6     print(连接中...)
 7     connect = pymssql.connect((local), sa, 123456789, Password)
 8     if connect:
 9         print(连接成功...)
10     else:
11         print(未连接)
12         exit()
13     return connect
14 
15 
16 def rand_password():
17     whole_char = rabcdefghijklmnopqrstuvwxyzABCDEFJHIJKLMNOPQRSTUVWXYZ._!@#$%^&*
18     char_number = len(whole_char)
19     password_length = input(please input password lenght: )
20     password = []
21     for _ in range(0, int(password_length)):
22         password.append(whole_char[randint(0, char_number - 1)])
23     return password
24 
25 
26 def inquiry_password(cursor):
27     name = input(please input password for use: )
28     if name == ‘‘:
29         sql = r"select * from password"
30     else:
31         sql = r"select * from password where id =‘" + name + ""
32     cursor.execute(sql)
33     result = cursor.fetchall()
34     if len(result) == 0:
35         print(不存在该密码)
36     else:
37         for value in result:
38             print(value[0]+的密码是:+value[1])
39 
40 
41 def add_password(connect, cursor):
42     name = input(please input password for use: )
43     pwd = input(please input password: )
44     if pwd == ‘‘:
45         pwd = ‘‘.join(rand_password())
46     sql = r"insert into password values(‘" + name + "‘, ‘" + pwd + "‘)"
47     cursor.execute(sql)
48     connect.commit()
49     print(name + 的密码是: + pwd)
50 
51 
52 def delete_password(connect, cursor):
53     name = input(please input password for use: )
54     sql = r"delete from password where id=‘" + name + ""
55     cursor.execute(sql)
56     connect.commit()
57 
58 
59 def change_password(connect, cursor):
60     name = input(please input password for use: )
61     pwd = input(please input password: )
62     if pwd == ‘‘:
63         pwd = ‘‘.join(rand_password())
64     sql = r"update password set pwd=‘" + pwd + "‘where id=‘" + name + ""
65     cursor.execute(sql)
66     connect.commit()
67     print(name + 的密码是: + pwd)
68 
69 
70 def run():
71     connect = connect_to_sql()
72     cursor = connect.cursor()
73     while True:
74         flag = input(please input (A/D/C/I/Eadd,delete,change,inquiry,exit): )
75         if flag == A or flag == a:
76             add_password(connect, cursor)
77         elif flag == D or flag == d:
78             delete_password(connect, cursor)
79         elif flag == C or flag == c:
80             change_password(connect, cursor)
81         elif flag == I or flag == i:
82             inquiry_password(cursor)
83         elif flag == E or flag == e:
84             break
85     connect.close()
86 
87 
88 if __name__ == __main__:
89     run()

 

将DOS界面的程序进行稍微修改,用于窗口界面的导入文件

password.py

  1 from random import randint
  2 import pymssql
  3 
  4 
  5 def connect_to_sql():
  6     print(连接中...)
  7     connect = pymssql.connect((local), sa, 123456789, Password)
  8     if connect:
  9         print(连接成功)
 10     else:
 11         print(未连接)
 12         exit()
 13     return connect
 14 
 15 
 16 def rand_password(password_length):
 17     whole_char = rabcdefghijklmnopqrstuvwxyzABCDEFJHIJKLMNOPQRSTUVWXYZ._!@#$%^&*
 18     char_number = len(whole_char)
 19     # password_length = input(‘please input password lenght: ‘)
 20     password = []
 21     for _ in range(0, int(password_length)):
 22         password.append(whole_char[randint(0, char_number - 1)])
 23     return password
 24 
 25 
 26 def inquiry_password(cursor, name):
 27     # name = input(‘please input password for use: ‘)
 28     if name == all or name == ALL:
 29         sql = r"select * from password"
 30     elif name == ‘‘:
 31         return 请输入账号
 32     else:
 33         sql = r"select * from password where id =‘" + name + ""
 34     cursor.execute(sql)
 35     result = cursor.fetchall()
 36     if len(result) == 0:
 37         # print(‘不存在该密码‘)
 38         return 不存在该密码
 39     else:
 40         _: str = ‘‘
 41         for value in result:
 42             # print(value[0]+‘的密码是:‘+value[1])
 43             _ += value[0]+的密码是:+value[1]+\n
 44         return _
 45 
 46 
 47 def add_password(connect, cursor, name, pwd, length=16):
 48     # name = input(‘please input password for use: ‘)
 49     # pwd = input(‘please input password: ‘)
 50     if pwd == ‘‘:
 51         pwd = ‘‘.join(rand_password(length))
 52     sql = r"select id from password where id = ‘" + name + ""
 53     cursor.execute(sql)
 54     PasswordId = cursor.fetchone()
 55     if PasswordId == (name, ):
 56             return 密码已存在,请使用修改
 57     sql = r"insert into password values(‘" + name + "‘, ‘" + pwd + "‘)"
 58     cursor.execute(sql)
 59     connect.commit()
 60     # print(name + ‘的密码是:‘ + pwd)
 61     result = name + 的密码是: + pwd
 62     return result
 63 
 64 
 65 def delete_password(connect, cursor, name):
 66     # name = input(‘please input password for use: ‘)
 67     if name == ‘‘:
 68         return 请输入账号
 69     sql = r"select id from password where id = ‘" + name + ""
 70     cursor.execute(sql)
 71     PasswordId = cursor.fetchone()
 72     if PasswordId is None:
 73         return 不存在 + name + 账号
 74     sql = r"delete from password where id=‘" + name + ""
 75     cursor.execute(sql)
 76     connect.commit()
 77     return 已删除 + name + 账号
 78 
 79 
 80 def change_password(connect, cursor, name, pwd, length=16):
 81     # name = input(‘please input password for use: ‘)
 82     # pwd = input(‘please input password: ‘)
 83     if pwd == ‘‘:
 84         pwd = ‘‘.join(rand_password(length))
 85     sql = r"update password set pwd=‘" + pwd + "‘where id=‘" + name + ""
 86     cursor.execute(sql)
 87     connect.commit()
 88     # print(name + ‘的密码是:‘ + pwd)
 89     result = name + 的密码是: + pwd
 90     return result
 91 
 92 
 93 # noinspection PyArgumentList
 94 def run():
 95     connect = connect_to_sql()
 96     cursor: connect.cursor = connect.cursor()
 97     while True:
 98         flag = input(please input (A/D/C/I/Eadd,delete,change,inquiry,exit): )
 99         if flag == A or flag == a:
100             add_password(connect, cursor)
101         elif flag == D or flag == d:
102             delete_password(connect, cursor)
103         elif flag == C or flag == c:
104             change_password(connect, cursor)
105         elif flag == I or flag == i:
106             inquiry_password(cursor)
107         elif flag == E or flag == e:
108             break
109     connect.close()
110 
111 
112 if __name__ == __main__:
113     run()

 

使用PyQt5库编写窗口程序

IPassword.py

  1 # import os
  2 import sys
  3 from PyQt5.QtGui import QIcon, QFont
  4 from PyQt5.QtWidgets import QApplication, QWidget, QToolTip, QDesktopWidget, QLabel, QLineEdit, QPushButton,  5     QVBoxLayout, QHBoxLayout, QTextEdit
  6 from password import *
  7 
  8 
  9 class Window(QWidget):
 10     def __init__(self, **kwargs):
 11         # noinspection PyArgumentList
 12         super().__init__()
 13         self.Label = []
 14         self.LineEdit = []
 15         self.Button = []
 16         self.TextEdit = []
 17         self.connect = kwargs[connect]
 18         self.cursor = kwargs[cursor]
 19         self.initUi()
 20         self.setFixedSize(self.width(), self.height())  # 固定窗口的大小为其初始大小
 21 
 22     # noinspection PyArgumentList
 23     def initUi(self):
 24         # noinspection PyCallByClass
 25         QToolTip.setFont(QFont("SansSerif", 10))
 26         self.resize(240, 360)
 27         self.frameGeometry().moveCenter(QDesktopWidget().availableGeometry().center())
 28         self.setWindowTitle("IPassword")
 29         self.setWindowIcon(QIcon(r"src/IPassword.svg"))
 30         self.Label.append(QLabel(self))
 31         self.Label[0].setText(账  号:)
 32         self.Label.append(QLabel(self))
 33         self.Label[1].setText(密  码:)
 34         self.LineEdit.append(QLineEdit())
 35         self.LineEdit[0].setText(‘‘)
 36         self.LineEdit.append(QLineEdit())
 37         self.LineEdit[1].setText(‘‘)
 38         # self.LineEdit[0].setHidden(True)
 39         # self.LineEdit[0].setVisible(False)
 40         self.Button.append(QPushButton(增加, self))
 41         self.Button.append(QPushButton(删除, self))
 42         self.Button.append(QPushButton(修改, self))
 43         self.Button.append(QPushButton(查询, self))
 44         self.Button[0].clicked.connect(lambda: self.addInfo())
 45         self.Button[1].clicked.connect(lambda: self.deleteInfo())
 46         self.Button[2].clicked.connect(lambda: self.changeInfo())
 47         self.Button[3].clicked.connect(lambda: self.getInfo())
 48         self.TextEdit.append(QTextEdit(self))
 49         self.TextEdit[0].setPlainText(......)
 50 
 51         hbox1 = QHBoxLayout()
 52         hbox1.addWidget(self.Label[0])
 53         hbox1.addStretch(1)
 54         hbox1.addWidget(self.LineEdit[0])
 55         hbox2 = QHBoxLayout()
 56         hbox2.addWidget(self.Label[1])
 57         hbox2.addStretch(1)
 58         hbox2.addWidget(self.LineEdit[1])
 59         hbox3 = QHBoxLayout()
 60         hbox3.addWidget(self.TextEdit[0])
 61         hbox4 = QHBoxLayout()
 62         hbox4.addWidget(self.Button[0])
 63         hbox4.addWidget(self.Button[1])
 64         hbox5 = QHBoxLayout()
 65         hbox5.addWidget(self.Button[2])
 66         hbox5.addWidget(self.Button[3])
 67 
 68         vbox = QVBoxLayout()
 69         vbox.addLayout(hbox1)
 70         vbox.addLayout(hbox2)
 71         vbox.addLayout(hbox3)
 72         vbox.addLayout(hbox4)
 73         vbox.addLayout(hbox5)
 74 
 75         self.setLayout(vbox)
 76         self.show()
 77 
 78     def addInfo(self):
 79         PasswordInfo = add_password(self.connect, self.cursor, self.LineEdit[0].text(), self.LineEdit[1].text())
 80         self.LineEdit[0].setText(‘‘)
 81         self.LineEdit[1].setText(‘‘)
 82         self.TextEdit[0].setPlainText(PasswordInfo)
 83 
 84     def deleteInfo(self):
 85         PasswordInfo = delete_password(self.connect, self.cursor, self.LineEdit[0].text())
 86         self.LineEdit[0].setText(‘‘)
 87         self.LineEdit[1].setText(‘‘)
 88         self.TextEdit[0].setPlainText(PasswordInfo)
 89 
 90     def changeInfo(self):
 91         PasswordInfo = change_password(self.connect, self.cursor, self.LineEdit[0].text(), self.LineEdit[1].text())
 92         self.LineEdit[0].setText(‘‘)
 93         self.LineEdit[1].setText(‘‘)
 94         self.TextEdit[0].setPlainText(PasswordInfo)
 95 
 96     def getInfo(self):
 97         PasswordInfo = inquiry_password(self.cursor, self.LineEdit[0].text())
 98         self.LineEdit[0].setText(‘‘)
 99         self.LineEdit[1].setText(‘‘)
100         self.TextEdit[0].setPlainText(PasswordInfo)
101 
102     def closeEvent(self, CloseEvent):
103         print(断开中...)
104         self.connect.close()
105         print(已断开)
106         print(关闭中...)
107         CloseEvent.accept()
108 
109 
110 def run():
111     print(启动中...)
112     connect = connect_to_sql()
113     cursor = connect.cursor()
114     application = QApplication(sys.argv)
115     _ = Window(connect=connect, cursor=cursor)
116     print(启动成功)
117     try:
118         sys.exit(application.exec())
119     except SystemExit as _:
120         print(退出成功)
121 
122 
123 if __name__ == __main__:
124     run()

 

暂时可以实现密码的生成、存储、修改、查询、删除的功能。

时间:2019-08-20
状态:未完成(半成品)
作者:Wzz

 

以上是关于简单的密码管理器(Python)(待完善)的主要内容,如果未能解决你的问题,请参考以下文章

密码管理器上海道宁为您提供存储和使用强密码的简单方法工具软件——1Password

Qt WebEngine 密码管理器 - 如何检测网站上何时使用用户名/密码

2后台超级管理员完善密码修改功能

什么是密码管理器?有什么作用?

python能不能修改Win7的凭据管理里面的密码么?

系统批量运维管理器pexpect详解