项目介绍

使用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

最新文章

  1. JavaScript学习总结(四)——jQuery插件开发与发布
  2. [已招满,谢谢关注]Sogou招聘C#开发人员,有意者请进
  3. hibernate笔记--继承映射关系的三种实现方式
  4. Bootstrap_Javascript
  5. 第六百一十八天 how can I 坚持
  6. [ASP.NET]配置使用SQL Server保存会话状态
  7. [SAP ABAP开发技术总结]OPEN SQL
  8. div 布局2
  9. 『邪恶のWIFI』搭建假冒WIFI热点等女神来蹭网啊 - -。
  10. 解决android4.0系统中菜单(Menu)添加Icon无效问题
  11. Java中volatile的作用以及用法
  12. [LeetCode] ZigZag Conversion [9]
  13. webpack2系列step1
  14. Java禁止浏览器有缓存的源码
  15. 虚拟机配置Linux上网环境
  16. 使用Linux的Crontab定时执行PHP脚本
  17. Inception介绍(MySQL自动化运维工具)
  18. ref 参数与out参数
  19. jquery 获取子元素的限制jquery
  20. 比较有用的sql语句

热门文章

  1. RabbitMQ.Client.Exceptions.BrokerUnreachableException:“None of the specified endpoints were reachabl
  2. Spring(Spring的读取外部资源- p 命名空间)
  3. appium连接手机 adb调试 app自动化
  4. What?JMeter做UI自动化!
  5. CCRD_TOC_2008年第3期
  6. DevOps 与 FinOps:二者可以协同吗?
  7. 《HelloTester》第2期
  8. PACS系统各个功能介绍--九五小庞
  9. [引擎开发] 深入GPU和渲染优化(基础篇)
  10. 树莓派lite安装桌面