QT实现用户登录注册

本文实例为大家分享了QT实现用户登录注册的具体代码,供大家参考,具体内容如下

#include "widget.h"
#include "ui_widget.h"

//窗口设置
#include <QStyle>

//数据库连接
#include <QtSql/QSqlQuery>//数据库操作函数
#include <QtSql/QSqlError>//输出错误信息

#include <QMessageBox>//
#include <QSettings>//读写配置文件
#include <QtDebug>

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

//窗口设置
    //设置窗口不显示标题,无边框
     setWindowFlags(Qt::Window|Qt::FramelessWindowHint);

//设置最小化、关闭按钮

     //获取最小化、关闭按钮图标

      QPixmap minPix = style()->standardPixmap(QStyle::SP_TitleBarMinButton);
      QPixmap closePix = style()->standardPixmap(QStyle::SP_TitleBarCloseButton);

      ui->mintoolButton->setIcon(minPix);
      ui->closetoolButton->setIcon(closePix);
      ui->mintoolButton->setStyleSheet("bakground-color:tranparent:");
      ui->closetoolButton->setStyleSheet("bakground-color:tranparent:");

      connect(ui->mintoolButton,&QPushButton::clicked,this,&Widget::showMinimized);
      connect(ui->closetoolButton,&QPushButton::clicked,this,&Widget::close);

//数据库连接
      //连接数据库
         //查看当前支持的数据库的驱动
          qDebug()<<QSqlDatabase::drivers();

          QSqlDatabase DB;//创建一个数据库的文件
         //加载数据库的文件
          QString aFile="./dataBase.db";
          if(aFile.isEmpty())
          {
              qDebug()<<" 数据库文件加载失败 " ;
              return ;
          }
          //打开数据库
          DB=QSqlDatabase::addDatabase("QSQLITE");//创建QSQLITE数据库连接
          DB.setDatabaseName(aFile); //数据库名
          if(!DB.open())
          {
              //没有数据库文件则创建文件
              qDebug()<<"数据库文件打开失败";
              qDebug()<<DB.lastError().text();//输出错误信息
           }
          qDebug()<< " 打开数据库文件成功 " ;

      //从配置文件中读取用户名和密码:
          QSettings setting("config.ini",QSettings::IniFormat);
          QString account = setting.value("section/account").toString();
          QString password = setting.value("section/password").toString();
          ui->accountEdit->setText(account);
          ui->passwordEdit->setText(password);

         //用户注册,向数据库插入数据
          connect(ui->registerButton,&QPushButton::clicked,this,[=](){

          //接受用户输入:
              QString account = ui->accountEdit->text();//用户账号
              QString password = ui->passwordEdit->text();//密码

          //创建自己需要使用的表格
              QSqlQuery query(DB);
              if(!query.exec("create table user(account varchar(255) primary key, password varchar(255))"))
              {
                  qDebug() << "Error: Fail to create table."<< query.lastError();
              }
              else
              {
                  qDebug() << "Table created!";
              }

          //插入数据
              QString qs = QString("insert into user(account,password) values('%1','%2')")
                      .arg(account).arg(password);

              if(query.exec(qs)) //如果插入成功
              {
                  QMessageBox::information(this,"注册","注册成功");
              }
              else
              {
                  QMessageBox::information(this,"注册","注册失败");
                  qDebug()<<query.lastError().text();//输出错误信息
                  //return;
              }

          //查看数据
              //查看数据库中有的表格的名字
              qDebug()<<"查看数据库中所有的表:";
              QStringList str_table=DB.tables();
              qDebug()<<str_table;
              //查询数据库中的数据
              qDebug()<<"查看数据库中数据";
              query.prepare ("SELECT * FROM user");
              query.exec();
              while(query.next())
              {
                  qDebug()<<QString("account:%1,password:%2").
                            arg(query.value("account").toString()).arg(query.value("password").toString());
              }

          });

      //用户登录:查询数据

          connect(ui->loginButton,&QPushButton::clicked,this,[=](){

              //接受用户输入:
               QString account = ui->accountEdit->text();//用户账号
               QString password = ui->passwordEdit->text();//密码

              //查询数据
               QSqlQuery query;//操作数据库
               QString qs = QString("select * from user where account ='%1' and password='%2'").
                       arg(account).arg(password);

               if(!query.exec(qs))//如果没有查到记录
               {
                   qDebug() << query.lastError().text();//输出错误信息
                   return;
               }

               //获取查询的数据
               if(query.next())//获取到数据
               {
                   QMessageBox::information(this,"登录","登录成功");

                   connect(tw,&TestWidget::testSigna,this,&Widget::show);//显示主窗口

                   //在配置文件中记录用户账号密码
                   if(ui->checkBox->isChecked())//选中,也就是用户已经登录
                   {
                       //创建配置文件
                       QSettings setting("config.ini",QSettings::IniFormat);//配置文件在工程目录下
                       //把用户账号密码写到配置文件中
                       setting.beginGroup("section");//节开始
                       setting.setValue("account",account);
                       setting.setValue("password",password);
                       setting.endGroup();//结束
                   }
               }
               else
               {
                   QMessageBox::information(this,"登录","登录失败");
               }
          });

}

Widget::~Widget()
{
    delete ui;
}

#按钮的ui实现

结果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 手把手教你实现漂亮的Qt 登录界面

    前言 最近在使用Qt5,Qt Creator做一个管理系统类的项目,自然需要用到登录界面,故记录一下登录界面的制作.其中一些功能的实现也得益于之前Qt5基础视频不规则窗口部分的学习. 手把手教你实现漂亮的登录界面 首先看一下成品. 第一步.新建一个Qwidget项目 没必要用qmainwindow,不需要那些菜单,一般用qwidget就可以,注意勾选ui. 第二步.添加界面组件 1.添加容器 调整容器为合适大小,同时调整整个画布为合适大小. 2.添加按钮,标签,文字组件 构思: 账号密码部分使用

  • QT连接Oracle数据库并实现登录验证的操作步骤

    目的: 本文实现QT登录界面,输入账号和密码后,系统连接Oracle数据进行判断账号和密码(MD5加密)是否和数据库一致,如果一致则提示登录成功. 开发环境:Windows10+QT5.14.2+Oracle11G R2 操作步骤: 1.打开QT软件,创建一个新的Application项目 2.设计界面并修改代码: 2.1修改项目配置文件,添加sql字符串表示要对数据库进行操作. 2.2登录界面LoginForm设计 2.3编写登录界面代码 LoginForm.h代码如下: #ifndef LO

  • QT实现用户登录注册

    本文实例为大家分享了QT实现用户登录注册的具体代码,供大家参考,具体内容如下 #include "widget.h" #include "ui_widget.h" //窗口设置 #include <QStyle> //数据库连接 #include <QtSql/QSqlQuery>//数据库操作函数 #include <QtSql/QSqlError>//输出错误信息 #include <QMessageBox>//

  • QT实现用户登录注册功能

    本文实例为大家分享了QT实现用户登录注册的具体代码,供大家参考,具体内容如下 1.login.h #ifndef LOGIN_H #define LOGIN_H #include <QWidget> namespace Ui { class Login; } class Login : public QWidget {     Q_OBJECT public:     explicit Login(QWidget *parent = 0);     ~Login(); private slot

  • JavaWeb实现用户登录注册功能实例代码(基于Servlet+JSP+JavaBean模式)

    下面通过通过图文并茂的方式给大家介绍JavaWeb实现用户登录注册功能实例代码,一起看看吧. 一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBean模式(MVC)适合开发复杂的web应用,在这种模式下,servlet负责处理用户请求,jsp负责数据显示,javabean负责封装数据. Servlet+JSP+JavaBean模式程序各个模块之间层次清晰,web开发推荐采用此种模式. 这里以一个最常用的用户登录注册程序来讲解Servlet+JS

  • 基于IO版的用户登录注册实例(Java)

    今天学的是用户登录注册功能. 4个包: itcast.cn.user包 User.java 用户类,描述用户基本信息,包括成员变量,无参构造函数,带参构造(可有可无).get和set方法 package itcast.cn.day22; /* * 用户基本描述包类 */ public class User { private int userName; private int passWord; public User(){ super(); } public User(int userName

  • Node.js+Express+MySql实现用户登录注册功能

    本文实例为大家分享了Node.js实现用户登录注册的具体代码,供大家参考,具体内容如下 IDE:WebStorm 工程目录: 数据库表 Login.js: /** * Created by linziyu on 2017/7/8. */ /** * express接收html传递的参数 */ var express=require('express'); var app=express(); var mysql=require('mysql'); /** * 配置MySql */ var con

  • JavaWeb简单用户登录注册实例代码(有验证码)

    需求 编写login登录界面(用户名,密码,验证码,登陆按钮,注册按钮) 设计关系数据库(编号,用户名,密码) 编写注册功能,将数据存储在数据库中.(姓名不能重复,设为主键,重复会注册失败) 编写登录功能 .首先获取验证码,先判断验证码是否正确,不正确则显示验证码错误.验证码正确后再获取用户名和密码,进行数据库的搜索比对,若正确则重定向到成功的界面,并且将用户名显示. jar包 技术选型 Servlet + JSP + Mysql + JDBCTemplate + Druid + BeanUti

  • 基于PHP实现用户登录注册功能的详细教程

    教程前先给大家看看小编的实现成果吧! 图1: 图2: 图3: 教程: 实现这个功能我们需要五个php文件: login.php (登录界面,如图2) <!DOCTYPE html> <html><head> <title>登录</title> <meta name="content-type"; charset="UTF-8"> </head><body> <div

  • 使用JSP实现简单的用户登录注册页面示例代码解析

    实验要求: 将实验2中的系统用户登录和注册页面改为JSP页面,并部署自己的Web应用于Tomcat服务器中 具体要求: 完成登录JSP页面设计和注册页面设计 在登录页面表单中使用request对象获取用户信息,建立新的JSP页面完成登录验证(用户名和密码自己指定即可). 验证结果显示(如登录成功/用户名密码错误,可以使用JavaScript,也可以使用新的JSP页面). 在注册页面表单中使用request对象获取用户注册信息(注册项目由自己指定),在新的JSP页面显示用户注册信息,并提示注册成功

  • Python实现用户登录注册

    简单的Python代码:用户登录注册 利用业余时间,写了一个用户进行登录注册的代码,非常简单.主要实现的功能是: 1.可以进行用户登录,在用户进行登录之前,对用户名进行检查,查看是否是已经注册的用户,如果是已经注册的用户,则直接登录:如果是未注册的用户,需要进行注册才可以登录 2.用户名检查:用户名长度为8~18位,不在这个数字范围内的用户名不可以进行登录,字符不限 3.用户密码检查:密码长度为8~18位,不在这个范围内的用户名也是不可以进行注册的,字符不限(其实用户名和密码的长度都是可以自己改

  • IOS开发用户登录注册模块所遇到的问题

    最近和另外一位同事负责公司登录和用户中心模块的开发工作,开发周期计划两周,减去和产品和接口的协调时间,再减去由于原型图和接口的问题,导致强迫症纠结症状高发,情绪不稳定耗费的时间,能在两周基本完成也算是个不小的奇迹了.本文就总结一下如何满足产品需要的情况下,高效开发一个登录注册模块. 1.利用继承解决界面重复性功能.通常登录注册会有一个独立的设计,而模块内部会有有相似的背景,相似的导航栏样式,相似返回和退出行为,相似的输入框,按钮样式等. 比如上面的的注册和登录模块,就有相同的返回按钮,相同的背景

随机推荐