2023/09/21 day5 qt

将注册的账号密码存储到数据库中

登录的账号密码与数据库中的账号密码进行匹配

头文件

#ifndef DENGLU_H
#define DENGLU_H
#include <QMainWindow>
#include <QDebug>
#include <QIcon>
#include <QLabel>
#include <QLineEdit>
#include <QPushButton>
#include "second.h"
#include <QMessageBox>  //消息对话框类
#include "third.h"
#include <QSqlDatabase>   //数据库管理类
#include <QSqlQuery>      //执行sql语句的类
#include <QSqlRecord>     //数据库记录的类QT_BEGIN_NAMESPACE
namespace Ui { class denglu; }
QT_END_NAMESPACEclass denglu : public QMainWindow
{Q_OBJECTpublic:denglu(QWidget *parent = nullptr);~denglu();
signals:void jump();    //自定义跳转信号函数void jump1();
private slots:void b1_clicked();void b2_clicked();void b3_clicked();private:Ui::denglu *ui;QLabel *lab1;QLabel *lab2;QLabel *lab3;QLineEdit *edit1;QLineEdit *edit2;QPushButton *b1;QPushButton *b2;QPushButton *b3;Second *s1;third *s2;QSqlDatabase db;
};
#endif // DENGLU_H
#ifndef THIRD_H
#define THIRD_H#include <QWidget>
#include <QMessageBox>
#include <QDebug>
#include <QIcon>
#include <QLabel>
#include <QLineEdit>
#include <QPushButton>
#include <QSqlDatabase>   //数据库管理类
#include <QSqlQuery>      //执行sql语句的类
#include <QSqlRecord>     //数据库记录的类
namespace Ui {
class third;
}class third : public QWidget
{Q_OBJECTpublic:explicit third(QWidget *parent = nullptr);~third();public slots:void jump_slot1();
private slots:void on_btn1_clicked();private:Ui::third *ui;//声明一个数据库的类对象QSqlDatabase db;
};#endif // THIRD_H

源文件

#include "denglu.h"
#include "ui_denglu.h"
denglu::denglu(QWidget *parent): QMainWindow(parent), ui(new Ui::denglu)
{ui->setupUi(this);this->setFixedSize(430,360); //设置固定主界面尺寸this->setWindowTitle("Widget"); //设置窗口标题this->setWindowIcon(QIcon(":/Image/icon/wodepeizhenshi.png"));//实例化一个标签lab1 = new QLabel(this);lab1->resize(430,180); //设置占窗体一半尺寸lab1->setPixmap(QPixmap(":/Image/icon/jinx.bmp"));lab1->setScaledContents(1);//实例化第二个标签lab2 = new QLabel(this);lab2->resize(45,30);  //设置尺寸lab2->move(this->x()+65,this->y()+200); //移动位置lab2->setPixmap(QPixmap(":/Image/icon/userName.jpg"));//填充图片lab2->setScaledContents(1);//实例化第三个标签lab3 = new QLabel(this);lab3->resize(45,30);  //设置尺寸lab3->move(lab2->x(),lab2->y()+60); //移动位置lab3->setPixmap(QPixmap(":/Image/icon/passwd.jpg"));//填充图片lab3->setScaledContents(1);//实例化行编辑器1edit1 = new QLineEdit(this);edit1->resize(200,32); //设置尺寸edit1->move(lab2->x()+55,lab2->y()); //移动位置edit1->setPlaceholderText("admin"); //设置默认值,占位文本edit1->setMaxLength(20); //设置最大文本容量//实例化行编辑器2edit2 = new QLineEdit(this);edit2->resize(200,32); //设置尺寸edit2->move(lab3->x()+55,lab3->y()); //移动位置edit2->setEchoMode(QLineEdit::Password); //设置回显模式edit2->setMaxLength(20); //设置最大文本容量//实例化按钮1b1 = new QPushButton(QIcon(":/Image/icon/login.png"),"登录",this);b1->resize(80,32); //设置尺寸b1->move(this->x()+100,lab3->y()+50); //移动位置//实例化按钮2b2 = new QPushButton(QIcon(":/Image/icon/cancel.png"),"取消",this);b2->resize(80,32); //设置尺寸b2->move(this->x()+230,b1->y()); //移动位置//实例化按钮3b3 = new QPushButton(this);b3->resize(80,32); //设置尺寸b3->setText("注册");b3->move(edit1->x()+220,edit1->y()+40); //移动位置//将当前界面的信号,与登录消息对话框函数连接connect(b1,&QPushButton::clicked,this,&denglu::b1_clicked);//将当前界面的信号,与取消消息对话框函数连接connect(b2,&QPushButton::clicked,this,&denglu::b2_clicked);//将当前界面的信号,与取消消息对话框函数连接connect(b3,&QPushButton::clicked,this,&denglu::b3_clicked);//将当前界面的信号,与s1界面的槽函数进行连接s1 = new Second;connect(this,&denglu::jump,s1,&Second::jump_slot);s2 = new third;connect(this,&denglu::jump1,s2,&third::jump_slot1);
}denglu::~denglu()
{delete ui;
}//登录按钮,如果账号密码和数据库中存储的账号密码一直就登录成功,否则登陆失败
void denglu::b1_clicked()
{//判断自己的数据库对象中是否包含了要处理的数据库,如果没有包含则添加一个数据库,//如果包含了,就可以打开了if(!db.contains("mydb1.db")){db = QSqlDatabase::addDatabase("QSQLITE");//设置数据库名字db.setDatabaseName("mydb1.db");}//此时已经有了一个名为mydatabase的数据//打开数据库if(!db.open()){QMessageBox::information(this,"失败","打开数据库失败");return ;}//查找名为user_info的数据表的内容QString username = this->edit1->text();QString sql = QString("select * from user_info where user_id = '%1'").arg(username);//语句执行者QSqlQuery q;if(!q.exec(sql)){QMessageBox::information(this,"提示","显示失败");return ;}QString dbpassword;while(q.next()){dbpassword = q.value("password").toString();}if(this->edit1->text() == "" ||this->edit2->text()== ""){QMessageBox::information(this,"提示","用户名或密码不能为空");return ;}else if(this->edit2->text()==dbpassword){//直接调用静态成员函数完成对话框的实现int ret = QMessageBox::information(this,"信息","登录成功",QMessageBox::Ok);if(ret ==QMessageBox::Ok){//关闭登录界面this->hide();//跳转到其他页面emit jump();}}else{QMessageBox box(QMessageBox::Critical,"出错","账号密码不匹配,是否重新登录",QMessageBox::Ok|QMessageBox::Cancel,this);   //父组件box.setDefaultButton(QMessageBox::Ok); //设置默认//调用exec函数允许对话框int ret = box.exec();//对结果进行判断if(ret == QMessageBox::Ok){this->edit2->clear();}else if(ret == QMessageBox::Cancel){this->hide();}}}void denglu::b2_clicked()
{int ret = QMessageBox::information(this,"退出","是否确定要退出登录",QMessageBox::Yes|QMessageBox::No);if(ret == QMessageBox::Yes){this->close();}else if(ret == QMessageBox::No){//不做操作}
}void denglu::b3_clicked()
{emit jump1();
}

注册界面

#include "third.h"
#include "ui_third.h"third::third(QWidget *parent) :QWidget(parent),ui(new Ui::third)
{ui->setupUi(this);//判断自己的数据库对象中是否包含了要处理的数据库,如果没有包含则添加一个数据库,//如果包含了,就可以打开了if(!db.contains("mydb1.db")){db = QSqlDatabase::addDatabase("QSQLITE");//设置数据库名字db.setDatabaseName("mydb1.db");}//此时已经有了一个名为mydatabase的数据//打开数据库if(!db.open()){QMessageBox::information(this,"失败","打开数据库失败");return ;}//数据库已经打开,需要创建一个数据表//准备sql语句QString sql = "create table if not exists user_info(user_id varchar(20) primary key,password varchar(20))";//准备语句执行者QSqlQuery q;//调用QSqlQuery类下的成员函数exec执行sql语句if(!q.exec(sql)){QMessageBox::information(this,"失败","创建数据表失败");return ;}}third::~third()
{delete ui;
}
void third::jump_slot1()
{this->show();
}//注册按钮对应的槽函数
void third::on_btn1_clicked()
{//获取ui界面中要录入的数据//账号QString user_id = ui->ledit1->text();//密码QString password = ui->ledit2->text();//判断要确保每个编辑器下都有数据if(user_id.isEmpty() || password.isEmpty()){QMessageBox::information(this,"提示","请将信息填写完整");return ;}//准备sql语句向表中添加数据QString sql = QString("insert into user_info(user_id,password)""values('%1','%2')").arg(user_id).arg(password);qDebug()<<sql;//准备语句执行者QSqlQuery querry;if(!querry.exec(sql)){QMessageBox::information(this,"失败","添加失败");return ;}else{QMessageBox::information(this,"成功","添加成功");}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/86997.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据库——理论基础

目录 1.1 什么是数据库 1.2 数据库管理系统&#xff08;DBMS&#xff09; 1.3 数据库和文件系统的区别 1.4 数据库的发展史 1.5常见的数据库 1.5.1关系型数据库 1.5.2 非关系型数据库 1.6 DBMS支持的数据模型 1.1 什么是数据库 数据&#xff1a;描述事物的符号记录 数…

李宏毅机器学习2023作业(目录)

2023.09.20更新 作业01的一键式执行Strong Baseline完整代码已整理好&#xff0c;提取码统一设置2023 【深度解析→博文总结】李宏毅机器学习2023作业01Regression(COVID-19 Cases Prediction) 【2023作业01一键式执行Strong Baseline完整代码】 【深度解析→博文总结】李宏毅机…

【精通嵌入式Linux编程】引导加载程序详解bootloader

必须做两件事情&#xff1a; 引导加载程序必须传递一个指针&#xff0c;指向保护硬件配置信息的结构&#xff0c; 必须传递一个指向内核命令行的指针 SRAM&#xff1a;不需要内存控制器的静态随机存储器 阶段一&#xff1a;ROM代码 复位或上电后立即运行的代码必须存再soc的片…

基于springboot+vue的客户关系管理系统(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容&#xff1a;毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 项目介绍…

MySQL备份与恢复

MySQL备份与恢复一、备份1、数据备份的重要性2、数据备份分类2.1 物理备份2.2 逻辑备份 3、数据库备份策略4、常用的备份方法和工具5、数据库上云迁移 二、数据库完全备份1、简介2、物理冷备份与恢复2.1 物理冷备份2.2 备份恢复2.3 补充知识date 3、mysqldump备份与恢复3.1 完全…

文件系统之程序是怎么打开文件进行操作的

本篇文章自顶向下&#xff0c;从文件系统的上层出发讲到磁盘&#xff0c;帮助理解程序是如何打开文件并进行后序的读写操作的&#xff0c;读到后面&#xff0c;前面的一些疑惑就得到解决 介绍相关概念 注意&#xff0c;目录也是文件 文件描述符 每个进程都有一个指针*files…

【深度学习】BLIP: 用于统一的视觉-语言理解和生成的引导式语言图像预训练

BLIP: Bootstrapping Language-Image Pre-training for Unified Vision-Language Understanding and Generation BLIP&#xff1a;用于统一的视觉-语言理解和生成的引导式语言图像预训练 论文&#xff1a;https://arxiv.org/abs/2201.12086 代码&#xff1a;https://github.…

NotePad++ 在行前/行后添加特殊字符内容方法

我们在处理数据时&#xff0c;会遇到需要在每行数据前面、后面、开头、结尾添加各种不一样的字符 如果数据不多&#xff0c;我们可以自己手动的去添加&#xff0c;但如果达到了成百上千行&#xff0c;此时再机械的手动添加是不现实的 这里教给大家如何快速的在数据每行的前后…

QT 绘画功能的时钟

.h #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QPaintEvent> #include <QDebug> //信息调试类 #include <QPainter> #include <QPixmap> //图像引擎类 #include <QTime> #include <QTimer> …

秋招准备--基础知识复习--系统编程

lab1 进程 定义 进程的定义是操作系统中资源分配的基本单位&#xff0c;是程序的执行实体。具体地来分析这个定义的一体两面&#xff1a; 在资源分配方面&#xff0c;每个进程都有虚拟的进程空间&#xff0c;其中包括代码区&#xff0c;全局静态区&#xff0c;BSS区&#xff…

一文读懂 Redis 缓存系统

【摘要】本文介绍了Redis缓存原理、详细解析了缓存模型、缓存一致性和缓存异常场景。 【作者】李杰&#xff0c;专注于Java虚拟机技术、云原生技术领域的探索与研究。 尽管&#xff08;关系型&#xff09;数据库系统 (SQL) 带来了许多出色的属性&#xff0c;例如 ACID&#x…

Spring Boot Actuator使用指南

什么是 Spring Boot Actuator&#xff1f; Spring Boot Actuator 是 Spring Boot 提供的一种生产级别的特性&#xff0c;它可以帮助我们监控和管理 Spring Boot 应用&#xff0c;比如健康检查、审计、统计和 HTTP 追踪等。所有这些特性可以通过 JMX 或者 HTTP endpoints 来访问…

Linux系统编程——总结初识Linux(常用命令、特点、常见操作系统)

文章目录 UNIX操作系统&#xff08;了解&#xff09;Linux操作系统主要特征Linux和unix的区别和联系什么是操作系统常见的操作系统Ubuntu操作系统Ubuntu安装linux下的目录的类型(掌握)shell指令shell指令的格式文件操作相关指令系统相关命令网络相关命令其他命令软件安装相关的…

duilib 进阶 之 list 容器使用 及扩展

目录 一、list控件 1、选中事件的例子 2、子项目为简单容器时赋值 1)、直接样式文件里赋值

leetcode Top100(16)缺失的第一个正数

给你一个未排序的整数数组 nums &#xff0c;请你找出其中没有出现的最小的正整数。 * * 请你实现时间复杂度为 O(n) 并且只使用常数级别额外空间的解决方案。 * * * 示例 1&#xff1a; * * 输入&#xff1a;nums [1,2,0] * 输出&#xff1a;3 * 示例 2&#xff1a; * * 输入…

【算法】排序——插入排序及希尔排序

目录 前言 一、排序的概念及其应用 1.1排序的概念 1.2排序的应用 1.3常见的排序算法 二、插入排序的实现 基于插入排序的优化——希尔排序&#xff08;缩小增量排序 个人主页 代码仓库 C语言专栏 初阶数据结构专栏 Linux专栏 LeetCode刷题 算法专栏 前言 这…

js for循环设置循环变量和循环体内部是两个单独作用域

参考文章 for 循环设置循环变量的那部分是一个父作用域&#xff0c;而循环体内部是一个单独的子作用域。 for (let i 0; i < 3; i) {let i abc;console.log(i); } // abc // abc // abc上面代码正确运行&#xff0c;输出了 3 次abc。这表明函数内部的变量i与循环变量i不…

多进程编程- POSIX命名信号量(named semaphore)

POSIX命名信号量是POSIX标准下的一个进程间同步原语&#xff0c;允许多个进程共享同一个信号量&#xff0c;从而实现进程间的同步和通信。这与无名信号量不同&#xff0c;无名信号量主要用于线程之间的同步&#xff0c;而不是进程之间。 命名信号量是“命名”的&#xff0c;因…

工作、生活常用免费api接口大全

手机号码归属地&#xff1a;提供三大运营商的手机号码归属地查询。全国快递物流查询&#xff1a;1.提供包括申通、顺丰、圆通、韵达、中通、汇通等600快递公司在内的快递物流单号查询。2.与官网实时同步更新。3.自动识别快递公司。IP归属地-IPv4区县级&#xff1a;根据IP地址查…

Kubernetes集群+Keepalived+Nginx+防火墙 实例

目录 实验前期规划 1.拓扑图结构 2.实验要求 3.实验环境规划 一.kubeadm 部署 K8S 集群架构 1.环境准备 2.三个节点安装docker 3.三个节点安装kubeadm&#xff0c;kubelet和kubectl 4.部署K8S集群 &#xff08;1&#xff09;初始化 4.部署K8S集群 &#xff08;1&am…