使用tkinter开发的一款登录和注册图形化界面
项目介绍
使用tkinter开发的一款登录和注册图形化界面
使用tkinter开发的一款登录和注册图形化界面,并且使用 ttkbootstrap 进行界面美化。
项目以学校选课系统为参考,将登陆身份设置为:管理员、教师、学生。登录时可根据登录的身份自动打开对应的界面【空白界面暂未开发】。
项目中用户的信息全部保存在 sqlite 数据库中,数据表有:users表保存账号密码信息,remember_psw表保存上次登录信息。
该项目还有其他小功能:左上角图标根据内容改变、根据输入有误信息准确提示;更多功能欢迎体验。
项目管理员手机号为:admin
项目管理员密码为:admin
登录功能
登录界面包含:输入手机号、密码,记住密码选项框组件,输入正确信息后登录成功!输入错误信息及未输入完整信息均有提示框。
登录界面展示

登录主要功能
- 输入密码不显示明文,以 * 代替
- 账号密码不正确或未输入,有不同弹窗提示
- 记住密码功能,勾选后下次直接登录
- 可以根据登录的身份不同,打开对应的界面【空白界面暂未开发】
登录部分源码
登录界面部分代码展示:
def login_window(self, frame=None):
# 用户名输入框
username_label = Label(frame, text="手机号:")
username_label.grid(row=1, column=1, padx=5, pady=20)
self.login_phone = tk.StringVar()
username_entry = Entry(frame, bootstyle=INFO, textvariable=self.login_phone, width=30)
username_entry.grid(row=1, column=2, padx=5, pady=10)
# 密码输入框
psw_label = Label(frame, text="密 码:")
psw_label.grid(row=2, column=1, padx=5, pady=10)
self.login_psw = tk.StringVar()
psw_entry = Entry(frame, bootstyle=INFO, textvariable=self.login_psw, show="*", width=30)
psw_entry.grid(row=2, column=2, padx=5, pady=10)
# 记住密码选项
self.remember_psw = tk.IntVar()
pwd_check_button = Checkbutton(frame, text="记住密码", variable=self.remember_psw)
pwd_check_button.grid(row=3, column=1, padx=5, pady=5, columnspan=2, sticky="w")
# 登录按钮
login_button = Button(frame, text="登 录", bootstyle=PRIMARY, width=40, command=self.login)
login_button.grid(row=4, column=1, padx=5, pady=10, columnspan=2)
# 查看是否记住密码
remember_select_sql = """SELECT phone,password,is_remember FROM remember_psw WHERE id=1;"""
is_remember = self.execute_sql(remember_select_sql)
if is_remember:
if is_remember[0][2] == "1":
self.login_phone.set(is_remember[0][0])
self.login_psw.set(is_remember[0][1])
self.remember_psw.set(int(is_remember[0][2]))
登录功能部分代码展示:
def login(self):
phone = self.login_phone.get()
password = self.login_psw.get()
remember = self.remember_psw.get()
if phone and password:
md5_password = self.encryption(password)
select_sql = f"""select 1 from users where phone='{phone}' AND password_md5='{md5_password}';"""
if self.execute_sql(select_sql):
create_time = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
# 更新记住密码操作
update_sql = f"""UPDATE remember_psw SET phone='{phone}',password='{password}',is_remember='{remember}',create_time='{create_time}' WHERE id=1;"""
self.execute_sql(update_sql)
# showinfo(title="登录", message="登录成功!")
self.register_login.destroy()
# 根据登录的身份打开不同的界面
select_id_sql = f"""SELECT name,identity FROM users WHERE phone='{phone}';"""
select_id_result = self.execute_sql(select_id_sql)
if select_id_result[0][1] == "管理员":
self.admin_window()
elif select_id_result[0][1] == "教师":
self.teacher_window()
elif select_id_result[0][1] == "学生":
self.student_window()
else:
showerror(title="失败", message="账号密码输入错误!")
else:
showerror(title="失败", message="账号密码输入有误!")
注册功能
注册界面主要包括:输入用户名、手机号、密码、身份下拉框组件。输入信息有误均有不同弹窗提示输入错误信息及未输入完整信息均有提示框。
注册界面展示

注册主要功能
- 信息未填写完整,有弹窗提示
- 手机号格式不正确,有弹窗提示
- 注册密码以md5格式保存在数据库
- 密码至少6位数且由数字、字母组成
- 身份必须选择一项,否则有弹窗提示
- 注册的手机号已存在,有弹窗提示
- 注册成功有弹窗提示
- 注册成功后,自动清空注册内容
注册部分源码
注册界面部分代码展示:
def register_window(self, frame=None):
padx = 5
pady = 5
# 用户名输入框
username_label = Label(frame, text="用户名:")
username_label.grid(row=1, column=1, padx=padx, pady=pady)
self.register_username = tk.StringVar()
self.register_username_entry = Entry(frame, bootstyle=INFO, textvariable=self.register_username, width=30)
self.register_username_entry.grid(row=1, column=2, padx=padx, pady=pady)
# 手机号输入框
username_label = Label(frame, text="手机号:")
username_label.grid(row=2, column=1, padx=padx, pady=pady)
self.register_pone = tk.StringVar()
self.register_phone_entry = Entry(frame, bootstyle=INFO, textvariable=self.register_pone, width=30)
self.register_phone_entry.grid(row=2, column=2, padx=padx, pady=pady)
# 密码输入框
psw_label = Label(frame, text="密 码:")
psw_label.grid(row=3, column=1, padx=padx, pady=pady)
self.register_psw = tk.StringVar()
self.register_psw_entry = Entry(frame, bootstyle=INFO, textvariable=self.register_psw, show="*", width=30)
self.register_psw_entry.grid(row=3, column=2, padx=padx, pady=pady)
# 身份
psw_label = Label(frame, text="身 份:")
psw_label.grid(row=4, column=1, padx=padx, pady=pady)
self.register_id = tk.StringVar()
self.register_combox = Combobox(frame, bootstyle=PRIMARY, textvariable=self.register_id, state="readonly",
width=28)
self.register_combox["value"] = ("下拉选择身份:", "教师", "学生")
self.register_combox.current(0)
self.register_combox.grid(row=4, column=2, padx=padx, pady=pady)
# 登录按钮
login_button = Button(frame, text="注 册", bootstyle=PRIMARY, width=40, command=self.register)
login_button.grid(row=5, column=1, padx=padx, pady=pady, columnspan=2)
注册功能部分代码展示:
def register(self):
user_name = self.register_username.get()
phone = self.register_pone.get()
password = self.register_psw.get()
identity = self.register_id.get()
if user_name and phone and password and (identity in ("教师", "学生")):
if not re.match(r"^1[356789]\d{9}$", phone):
showerror(title="失败", message="手机号填写有误!")
elif not (password.isalnum() and len(password) >= 6):
showerror(title="失败", message="密码至少6位且由数字、字母组成!")
else:
# 判断手机号是否存在
select_sql = f"""select 1 from users where phone='{phone}' LIMIT 1;"""
if self.execute_sql(select_sql):
# 手机号已注册
showerror(title="失败", message="该手机号已注册!")
else:
md5_password = self.encryption(password)
create_time = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
insert_users_sql = f"""
INSERT INTO users (name,phone,password,password_md5,identity,create_time) VALUES ('{user_name}','{phone}','{password}','{md5_password}','{identity}','{create_time}');
"""
self.execute_sql(insert_users_sql)
insert_remember_psw_sql = f"""
INSERT INTO remember_psw (phone,password,is_remember,create_time) VALUES ('{phone}','{password}','0','{create_time}');
"""
self.execute_sql(insert_remember_psw_sql)
showinfo(title="注册", message="注册成功!")
self.register_username_entry.delete(0, "end")
self.register_phone_entry.delete(0, "end")
self.register_psw_entry.delete(0, "end")
self.register_combox.current(0)
else:
showerror(title="失败", message="信息未填写完整!")
源码地址
链接:https://pan.baidu.com/s/1hn9sj4YLieyMgp6RlyLEOA?pwd=cebp
提取码:cebp
使用tkinter开发的一款登录和注册图形化界面的更多相关文章
- windows API 开发飞机订票系统 图形化界面 (一)
去年数据结构课程设计的作品,c语言实现,图形化界面使用windows API实现. 首发在我csdn博客:http://blog.csdn.net/u013805360/article/details ...
- windows API 开发飞机订票系统 图形化界面 (三)
来吧,接下来是各个功能的函数的实现代码. 首先,程序运行时加载读入账户信息和航班信息.接下来就该读取文件了. 我把账户资料和航班信息储存在了.txt文件里 那么问题就来了,挖掘机...额,不对,应该怎 ...
- 如何使用IDEA开发工具中右键中的Git图形化工具
首先,你的项目一定是git服务器上面down下来的,下面来演示如何使用IntelliJ IDEA 开发中在鼠标右键中提供的一个非常方便的图形化Git管理工具: 这里使用的IDEA开发工具的版本是 In ...
- 如何开发自己的搜索帝国之ES图形化Kibana安装与使用
在如何开发自己的搜索帝国之Elasticsearch中已经介绍安装好了ES,下面就Kibana对ES的查询监控作介绍,就是常提到的大数据日志处理组件ELK里的K. 什么是Kibana?现引用园友的一段 ...
- java实现登录的验证码和猜数字游戏_图形化界面
实验任务四 1,出现设计思想 (1)先定义文本框.密码框和验证码框的组件 (2)定义面板和按钮的个数 (3)定义公有的虚构方法,通过对象实例化来调用 (4)利用Random类来实现生成0-9的随机数 ...
- python——Tkinter图形化界面及threading多线程
Tkinter模块("Tk 接口")是Python的标准Tk GUI工具包的接口.Tk和Tkinter可以在大多数的Unix平台下使用,同样可以应用在Windows和Macinto ...
- 家庭记账本app进度之对于登录和注册两个界面点击按钮的相互跳转
这次主要完成了两个两个android页面之间的跳转.从登录页面点击注册就会跳转到注册页面.在注册页面点击返回登录,这样就可以返回到登录界面.主要是这样的操作.其中遇到了一个困难主要是当点击按钮的时候, ...
- windows API 开发飞机订票系统 图形化界面 (四)
接下来的是录入航班.修改航班信息功能的实现: //录入航班 BOOL EntryFlight(HWND hEntryDlg){ TCHAR szDiscount[]; TCHAR szFare[],s ...
- windows API 开发飞机订票系统 图形化界面 (二)
首先,用到的数据结构的定义.以及全局变量和函数的声明如下: // Flight.c : 定义应用程序的入口点. // #include "stdafx.h" //订单 typede ...
- java工程开发之图形化界面之(第一课)
下面我们先上代码: package 一个事例图形小应用程序; import javax.swing.JApplet; import java.awt.Graphics; public class 绘制 ...
随机推荐
- mysql 错误解决大法 Specified key was too long; max key length is 767 bytes
高版本mysql向低版本(5.7以下)导入sql时可能会发生此问题 开启索引最大长度 SET GLOBAL INNODB_LARGE_PREFIX = ON; 将表改为动态表SET GLOBAL in ...
- 环形链表I、II(含代码以及证明)
环形链表 解题思路 定义两个指针,一个快指针,一个慢指针,快指针每次移动两个节点,慢指针每次移动一个节点. 从头节点开始,让快慢指针同时移动,如果链表中有环,那么快慢指针一定会在某个节点相遇. 如果快 ...
- Vue23 ref属性
1 简介 在js中,我们获取一个元素可以通过document.getElementById()去获取,在vue中,使用了ref属性来替代id,通过ref属性可以获取html元素以及vue组件实例对象 ...
- python导入和导出excel,以文件流形式返回前端
一.导入excel 1. 安装依赖包 pip install xlrd 2. 读取excel getColIndex(colList:list,colName:str): try: return co ...
- RocketMQ - 生产者启动流程
生产者启动流程 DefaultMQProducer是RocketMQ中默认的生产者实现 核心属性: namesrvAddr: 继承自 ClientConfig,表示 RocketMQ 集群的Names ...
- 题解 [SHOI2002] 百事世界杯之旅
其实做这道题还蛮难受的...因为这个每一次有无限种可能我有钱我可以去买无限瓶可乐啊但是不是可口我不是很赞同┓( ´∀` )┏ 然后参考了这篇题解发现错位相减这样的方法,让我们一起膜拜 Butterfl ...
- 好用的liunx可视化管理工具
官网: https://www.terminal.icu/ 本地连接需要点击软件右上角切换线路到本地连接
- K8S Pod Sidecar 应用场景之一-加入 NGINX Sidecar 做反代和 web 服务器
Kubernetes Pod Sidecar 简介 Sidecar 是一个独立的容器,与 Kubernetes pod 中的应用容器一起运行,是一种辅助性的应用. Sidecar 的常见辅助性功能有这 ...
- Word 段落首行缩进
描述 使 Word 段落第一行左突出两个字符的位置,即段落首行缩进的方式有两种. "视图"选项卡--"显示"组--标尺 "开始"选项卡--& ...
- sqlit 自增id为null
CREATE TABLE proejct( id UNSIGNED INTEGER AUTO_INCREMENT, name VARCHAR(50) NOT NULL, type CHAR(10) N ...