gtk3 + sqlite3实现登录注册(前后端分离)




import gi
gi.require_version("Gtk", "3.0")
from gi.repository import Gtk
import sqlite3
 
class LoginRegisterWindow(Gtk.Window):
    def __init__(self):
        super().__init__(title="Login and Register")
        self.set_default_size(400, 200)
 
        # 创建一个水平盒布局
        box = Gtk.Box(orientation=Gtk.Orientation.HORIZONTAL, spacing=10)
 
        # 创建登录面板
        self.login_panel = LoginPanel(self)
        box.pack_start(self.login_panel, True, True, 0)
 
        # 创建注册面板
        self.register_panel = RegisterPanel(self)
        box.pack_start(self.register_panel, True, True, 0)
 
        # 将盒布局添加到窗口
        self.add(box)
 
class LoginPanel(Gtk.Box):
    def __init__(self, parent):
        super().__init__(orientation=Gtk.Orientation.VERTICAL, spacing=10)
 
        # 用户名和密码输入
        self.entry_username = Gtk.Entry()
        self.entry_password = Gtk.Entry()
        self.entry_password.set_visibility(False)
 
        # 登录按钮
        self.button_login = Gtk.Button(label="Login")
        self.button_login.connect("clicked", self.on_login_clicked)
 
        # 添加到登录面板
        self.pack_start(Gtk.Label(label="Username"), False, False, 0)
        self.pack_start(self.entry_username, False, False, 0)
        self.pack_start(Gtk.Label(label="Password"), False, False, 0)
        self.pack_start(self.entry_password, False, False, 0)
        self.pack_start(self.button_login, False, False, 0)
 
        self.parent = parent
 
    def on_login_clicked(self, widget):
        username = self.entry_username.get_text()
        password = self.entry_password.get_text()
        if self.validate_login(username, password):
            self.parent.set_title("Welcome, %s!" % username)
            # 这里可以添加进入主界面的代码
 
    def validate_login(self, username, password):
        # 连接数据库并检查凭据
        conn = sqlite3.connect('users.db')
        cursor = conn.cursor()
        cursor.execute("SELECT * FROM users WHERE username=? AND password=?", (username, password))
        if cursor.fetchone():
            conn.close()
            return True
        else:
            conn.close()
            self.entry_username.set_text("")
            self.entry_password.set_text("")
            return False
 
class Regis
sql
最后修改于:2024年09月02日 09:58

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日