基于tkinter+mysql登录界面系统

时间: 2023-07-30 15:10:25 浏览: 43
基于tkinter+mysql登录界面系统的开发可以分为以下几步: 1. 安装MySQL数据库和Python的MySQL驱动程序。 2. 创建一个MySQL数据库和一张用户表,用于存储用户信息。 3. 使用Python连接MySQL数据库,并编写SQL语句实现用户信息的查询、插入、更新和删除等操作。 4. 使用Tkinter创建登录窗口,包括输入用户名和密码的文本框、登录按钮和注册按钮等控件。 5. 在登录按钮的事件处理函数中,获取用户名和密码,使用Python查询用户信息,判断用户是否存在并且密码是否正确。如果验证通过,则跳转到主界面,否则提示用户登录失败。 6. 在注册按钮的事件处理函数中,弹出一个注册窗口,包括输入用户名、密码和确认密码的文本框、注册按钮和取消按钮等控件。在注册按钮的事件处理函数中,获取用户输入的信息,使用Python插入新的用户信息到数据库中。 下面是一个基于tkinter+mysql登录界面系统的代码示例: ```python import tkinter as tk import tkinter.messagebox import pymysql class LoginWindow: def __init__(self): self.win = tk.Tk() self.win.title('登录') self.win.geometry('300x200') tk.Label(self.win, text='用户名:').grid(row=0, column=0) self.username_entry = tk.Entry(self.win) self.username_entry.grid(row=0, column=1) tk.Label(self.win, text='密码:').grid(row=1, column=0) self.password_entry = tk.Entry(self.win, show='*') self.password_entry.grid(row=1, column=1) tk.Button(self.win, text='登录', command=self.login).grid(row=2, column=0) tk.Button(self.win, text='注册', command=self.register).grid(row=2, column=1) self.conn = pymysql.connect(host='localhost', user='root', password='root', database='test', charset='utf8') self.cursor = self.conn.cursor() def login(self): username = self.username_entry.get() password = self.password_entry.get() sql = f"SELECT * FROM user WHERE username='{username}' AND password='{password}'" self.cursor.execute(sql) result = self.cursor.fetchone() if result: tk.messagebox.showinfo('登录成功', f'欢迎回来,{username}!') self.win.destroy() MainWindow() else: tk.messagebox.showerror('登录失败', '用户名或密码错误!') def register(self): RegisterWindow(self.cursor) def __del__(self): self.cursor.close() self.conn.close() class RegisterWindow: def __init__(self, cursor): self.win = tk.Toplevel() self.win.title('注册') self.win.geometry('300x200') tk.Label(self.win, text='用户名:').grid(row=0, column=0) self.username_entry = tk.Entry(self.win) self.username_entry.grid(row=0, column=1) tk.Label(self.win, text='密码:').grid(row=1, column=0) self.password_entry = tk.Entry(self.win, show='*') self.password_entry.grid(row=1, column=1) tk.Label(self.win, text='确认密码:').grid(row=2, column=0) self.confirm_password_entry = tk.Entry(self.win, show='*') self.confirm_password_entry.grid(row=2, column=1) tk.Button(self.win, text='注册', command=self.register).grid(row=3, column=0) tk.Button(self.win, text='取消', command=self.win.destroy).grid(row=3, column=1) self.cursor = cursor def register(self): username = self.username_entry.get() password = self.password_entry.get() confirm_password = self.confirm_password_entry.get() if password != confirm_password: tk.messagebox.showerror('注册失败', '两次输入的密码不一致!') return sql = f"SELECT * FROM user WHERE username='{username}'" self.cursor.execute(sql) result = self.cursor.fetchone() if result: tk.messagebox.showerror('注册失败', '用户名已存在!') else: sql = f"INSERT INTO user (username, password) VALUES ('{username}', '{password}')" self.cursor.execute(sql) tk.messagebox.showinfo('注册成功', '注册成功!') self.win.destroy() class MainWindow: def __init__(self): self.win = tk.Tk() self.win.title('主界面') self.win.geometry('300x200') tk.Label(self.win, text='欢迎使用本系统!').pack() if __name__ == '__main__': LoginWindow() ``` 这个程序中,LoginWindow类表示登录窗口,RegisterWindow类表示注册窗口,MainWindow类表示主界面。程序使用pymysql模块连接MySQL数据库,使用tkinter模块创建GUI界面。在登录按钮的事件处理函数中,通过SQL语句查询用户信息,判断用户是否存在并且密码是否正确。在注册按钮的事件处理函数中,弹出一个注册窗口,等待用户输入用户名和密码,并将新的用户信息插入到数据库中。如果登录成功,则跳转到主界面。

相关推荐

最新推荐

recommend-type

基于python的Tkinter编写登陆注册界面

主要为大家详细介绍了基于python的Tkinter编写登陆注册界面,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

Python3.7+tkinter实现查询界面功能

主要介绍了Python3.7+tkinter实现查询界面功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
recommend-type

解决python tkinter界面卡死的问题

今天小编就为大家分享一篇解决python tkinter界面卡死的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

Python实现在tkinter中使用matplotlib绘制图形的方法示例

主要介绍了Python实现在tkinter中使用matplotlib绘制图形的方法,结合实例形式分析了Python使用tkinter与matplotlib进行正弦曲线图形绘制的相关操作技巧,需要的朋友可以参考下
recommend-type

Python前端 Tkinter开发登录界面

Python GUI界面开发的入门,是从tkinter开始的。(小程序,附带吗) 首先先介绍一下Tkinter吧 Tkinter模块(“Tk 接口”)是Python的标准Tk GUI工具包的接口. Tk和Tkinter可以在大多数的Unix平台下使用,同样可以应用在...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

如何用python编写api接口

在Python中编写API接口可以使用多种框架,其中比较流行的有Flask和Django。这里以Flask框架为例,简单介绍如何编写API接口。 1. 安装Flask框架 使用pip命令安装Flask框架: ``` pip install flask ``` 2. 编写API接口 创建一个Python文件,例如app.py,编写以下代码: ```python from flask import Flask, jsonify app = Flask(__name__) @app.route('/api/hello', methods=['GET']) def hello():
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。