当前位置: 首页 > news >正文

Qt—用SQLite实现简单的注册登录界面

1.实现目标

本次实现通过SQLite制作一个简易的登录窗口,当点击注册按钮时,登录窗口会消失,会出现一个新的注册界面;完成注册或退出注册时,注册窗口会消失,重新出现登录窗口。注册过的用户信息会出现在SQLite的表中。

 想要完成本次目标,我们需要完成以下步骤:

  1. 需要两个界面,登录界面:MainWindow(QMainWindow);注册界面:SIghUp(QWidget)
  2. 启动程序时,SQLite进行初始化、并创建表数据
  3. 点击注册按钮,登录窗口消失,从重新出现一个新的注册窗口
  4. 在注册界面中点击注册按钮时,初始化SQLite,并把当前界面的账户和密码插入到数据库表中,注册成功后注册界面消失,登陆界面出现;在注册界面中点击退出按钮,注册成功后注册界面消失,登陆界面出现
  5. 在登录界面上输入注册过的账户和密码,点击登录时,检查数据库表中的信息,如果正确则登录成功。

2.具体实现 

Mainwindow(登录界面)

首先展示头文件所需的槽函数和成员变量

接下来是登录界面,登录界面的ui如下,只需要记住其中的几个控件即可

 ui界面创建完毕后,我们需要设置显示密码初始化SQLite

 显示密码的槽函数

void MainWindow::on_checkBox_toggled(bool checked)
{if(checked)ui->passwd->setEchoMode(QLineEdit::Normal);elseui->passwd->setEchoMode(QLineEdit::Password);
}

初始化数据库 

void MainWindow::initSqlite()
{sqlite=QSqlDatabase::addDatabase("QSQLITE");//设置数据库名称sqlite.setDatabaseName("User.db");//检查数据库是否能打开if(!sqlite.open()){QMessageBox::critical(this,"数据库打开失败",sqlite.lastError().text());return;}qDebug()<<"SQLite连接成功,并创建 [User.db] 数据库!!!";//创建数据库QString sql=("CREATE TABLE  IF NOT EXISTS User(\id integer primary key autoincrement,\username ntext unique not NULL,\password ntext not NULL)");QSqlQuery query;if(!query.exec(sql)){QMessageBox::critical(this,"数据库创建失败",sqlite.lastError().text());return;}qDebug()<<"SQLite连接成功,并创建 [User.db] 数据库!!!";}

初始化完毕,点击登录按钮,获取其LineEdit上的字符串与数据库进行查找,查找成功跳转界面,失败则报错

登录按钮的槽函数 

void MainWindow::on_logIn_clicked()
{//获取界面上的用户和密码QString account=ui->account->text();QString passwd=ui->passwd->text();QString sql=QString("SELECT * FROM User where username='%1'and password='%2'").arg(account).arg(passwd);QSqlQuery query(sql);if(!query.next()){QMessageBox::critical(this,"登录失败","请重新检查账户和密码");}else{qDebug()<<"登录成功";QMessageBox::information(this,"登录认证","登录成功!");QWidget *w = new QWidget;w->show();this->close();}}

点击注册按钮,关闭当前界面,创建新的注册界面并显示 

 注册按钮的槽函数

void MainWindow::on_signUp_clicked()
{//关闭当前界面this->close();SignUp * signup=new SignUp;signup->show();}

SignUp(注册界面)

先展示头文件,只用到了两个槽函数

 接下来是ui界面

 点击注册按钮时,初始化数据库并把界面上的账户和密码插入进数据库中;注册成功后该界面关闭,重新显示登录界面

注册按钮的槽函数

void SignUp::on_signUp_clicked()
{MainWindow *w=new MainWindow;w->initSqlite();//获取lineEdit上的账户和密码QString account=ui->signUpAc->text();QString passwd=ui->signUpPs->text();QString sql=QString("insert into user(username,password) values('%1','%2');").arg(account).arg(passwd);QSqlQuery query;//判断执行结果if(!query.exec(sql)){qDebug()<<"insert into error";QMessageBox::information(this,"注册认证","注册失败!");}else{qDebug()<<"insert into success";QMessageBox::information(this,"注册认证","注册成功!");MainWindow *w = new MainWindow;w->show();this->close();}}

 点击退出按钮,没有注册,关闭当前界面并重新显示登录界面

退出按钮的槽函数 

void SignUp::on_quit_clicked()
{//关闭当前窗口this->close();MainWindow *w=new MainWindow;w->show();
}

 3.整体代码展示

MainWindow.

#ifndef MAINWINDOW_H
#define MAINWINDOW_H#include <QMainWindow>
#include <QSqlDatabase>
#include <QDebug>
#include <QMessageBox>
#include <QSqlError>
#include <QSqlQuery>QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACEclass MainWindow : public QMainWindow
{Q_OBJECTpublic:MainWindow(QWidget *parent = nullptr);~MainWindow();void initSqlite();private slots:void on_checkBox_toggled(bool checked);void on_signUp_clicked();void on_logIn_clicked();private:Ui::MainWindow *ui;QSqlDatabase sqlite;};
#endif // MAINWINDOW_H

MainWindow.cpp

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include "signup.h"MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{ui->setupUi(this);ui->passwd->setEchoMode(QLineEdit::Password);initSqlite();//初始化SQLite
}MainWindow::~MainWindow()
{delete ui;
}void MainWindow::initSqlite()
{sqlite=QSqlDatabase::addDatabase("QSQLITE");//设置数据库名称sqlite.setDatabaseName("User.db");//检查数据库是否能打开if(!sqlite.open()){QMessageBox::critical(this,"数据库打开失败",sqlite.lastError().text());return;}qDebug()<<"SQLite连接成功,并创建 [User.db] 数据库!!!";//创建数据库QString sql=("CREATE TABLE  IF NOT EXISTS User(\id integer primary key autoincrement,\username ntext unique not NULL,\password ntext not NULL)");QSqlQuery query;if(!query.exec(sql)){QMessageBox::critical(this,"数据库创建失败",sqlite.lastError().text());return;}qDebug()<<"SQLite连接成功,并创建 [User.db] 数据库!!!";}void MainWindow::on_checkBox_toggled(bool checked)
{if(checked)ui->passwd->setEchoMode(QLineEdit::Normal);elseui->passwd->setEchoMode(QLineEdit::Password);
}void MainWindow::on_signUp_clicked()
{//关闭当前界面this->close();SignUp * signup=new SignUp;signup->show();}void MainWindow::on_logIn_clicked()
{//获取界面上的用户和密码QString account=ui->account->text();QString passwd=ui->passwd->text();QString sql=QString("SELECT * FROM User where username='%1'and password='%2'").arg(account).arg(passwd);QSqlQuery query(sql);if(!query.next()){QMessageBox::critical(this,"登录失败","请重新检查账户和密码");}else{qDebug()<<"登录成功";QMessageBox::information(this,"登录认证","登录成功!");QWidget *w = new QWidget;w->show();this->close();}}

SignUp.h

#ifndef SIGNUP_H
#define SIGNUP_H#include <QWidget>namespace Ui {
class SignUp;
}class SignUp : public QWidget
{Q_OBJECTpublic:explicit SignUp(QWidget *parent = nullptr);~SignUp();private slots:void on_quit_clicked();void on_signUp_clicked();private:Ui::SignUp *ui;
};#endif // SIGNUP_H

SignUp.cpp

#include "signup.h"
#include "ui_signup.h"
#include "mainwindow.h"SignUp::SignUp(QWidget *parent) :QWidget(parent),ui(new Ui::SignUp)
{ui->setupUi(this);
}SignUp::~SignUp()
{delete ui;
}void SignUp::on_quit_clicked()
{//关闭当前窗口this->close();MainWindow *w=new MainWindow;w->show();
}void SignUp::on_signUp_clicked()
{MainWindow *w=new MainWindow;w->initSqlite();//获取lineEdit上的账户和密码QString account=ui->signUpAc->text();QString passwd=ui->signUpPs->text();QString sql=QString("insert into user(username,password) values('%1','%2');").arg(account).arg(passwd);QSqlQuery query;//判断执行结果if(!query.exec(sql)){qDebug()<<"insert into error";QMessageBox::information(this,"注册认证","注册失败!");}else{qDebug()<<"insert into success";QMessageBox::information(this,"注册认证","注册成功!");MainWindow *w = new MainWindow;w->show();this->close();}}

 4.总结

本次通过SQLite数据库制作了一个简单的登录注册窗口,因为比较简单所以没有用QSS进行美化,数据库的设计也比较简单。感兴趣的话大家可以在此基础上进行添加和改进。

 

相关文章:

  • 【解决分辨数字】2021-12-16
  • oracle linux 95 升级openssh 10 和openssl 3.5 过程记录
  • 基于matlab的D2D 功率控制仿真
  • 2025云智算技术白皮书
  • Go语言交替打印问题及多种实现方法
  • go-中间件的使用
  • 初识——QT
  • 第八节第三部分:认识枚举、枚举的作用和应用场景
  • React学习———CSS Modules(样式模块化)
  • CSS:三大特性
  • 黑马点评面试前复习
  • 事件驱动架构:从传统服务到实时响应的IT新风潮
  • MySQL 高可用
  • 光谱相机的空间分辨率和时间分辨率
  • 聊一聊接口测试的一致性如何处理?
  • h5,原生html,echarts关系网实现
  • 金融问答系统:如何用大语言模型打造高精度合规的金融知识引擎
  • 数据库故障排查指南:从入门到精通
  • 卡顿检测与 Choreographer 原理
  • 20250516使用TF卡将NanoPi NEO core开发板出厂的Ubuntu core22.04.3系统降级到Ubuntu core16.04.2
  • 收到延期付款利息,该缴纳增值税吗?
  • 《求是》杂志发表习近平总书记重要文章《锲而不舍落实中央八项规定精神,以优良党风引领社风民风》
  • 株洲一重病妇女被要求本人到银行取款时去世?当地警方:正在处理
  • 汕头违建豪宅“英之园”将强拆,当地:将根据公告期内具体情况采取下一步措施
  • 上海国际电影节纪录片单元,还世界真实色彩
  • 第78届戛纳电影节开幕,罗伯特·德尼罗领取终身成就奖