<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
本文範例為大家分享了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 slots: void on_btn_login_clicked(); void on_btn_register_clicked(); private: Ui::Login *ui; }; #endif // WIDGET_H
2、login.cpp
#include "login.h" #include "ui_login.h" #include "register.h" #include "mainwindow.h" #include <QMessageBox> #include <QSqlQuery> #include <QFile> #include <QDebug> Login::Login(QWidget *parent) : QWidget(parent), ui(new Ui::Login) { ui->setupUi(this); ui->ledit_password->setEchoMode(QLineEdit::Password); } Login::~Login() { delete ui; } void Login::on_btn_login_clicked() { QString username = ui->ledit_username->text(); QString password = ui->ledit_password->text(); if(username == "" ||password == ""){ QMessageBox::information(this,"警告","輸入不能為空",QMessageBox::Ok); }else{ QSqlQuery query; query.prepare("select username,password from admin where username=:username and password = :password "); query.bindValue(":username", username); query.bindValue(":password", password); query.exec(); if(!query.next()) { //結果集為空 //執行某操作 QMessageBox::information(this,"警告","使用者名稱或密碼錯誤!",QMessageBox::Ok); } else { QMessageBox::information(this,"提醒","登入成功!",QMessageBox::Ok); MainWindow *m = new MainWindow; m->show(); this->close(); } } } void Login::on_btn_register_clicked() { Register *r = new Register; r->show(); }
3、register.h
#ifndef REGISTER_H #define REGISTER_H #include <QWidget> namespace Ui { class Register; } class Register : public QWidget { Q_OBJECT public: explicit Register(QWidget *parent = 0); ~Register(); private slots: void on_btn_logon_clicked(); private: Ui::Register *ui; }; #endif // REGISTER_H
4、register.cpp
#include "register.h" #include "ui_register.h" #include <QButtonGroup> #include <QMessageBox> #include <QRegExp> #include <QSqlQuery> Register::Register(QWidget *parent) : QWidget(parent), ui(new Ui::Register) { ui->setupUi(this); } Register::~Register() { delete ui; } void Register::on_btn_logon_clicked() { QString username = ui->ledit_username->text(); QString password = ui->ledit_pwd->text(); QString name = ui->ledit_name->text(); int age = ui->ledit_age->text().toInt(); QButtonGroup *bg=new QButtonGroup(this); bg->addButton(ui->rbtn_male,0);//一個值為0 bg->addButton(ui->rbtn_female,1);//一個值為1 int sel=bg->checkedId();//取到你所選的radioButton的值 QString gender; switch(sel) { case 0: gender="男"; break; case 1: gender="女"; break; default: gender=""; break; } QSqlQuery query; query.prepare("select username from patient where username=:username"); query.bindValue(":username", username); query.exec(); if(query.next()) { QMessageBox::information(this,"警告","使用者名稱已存在!",QMessageBox::Ok); } else { query.prepare("insert into patient(username,password,patientName,age,gender)" "values(:username,:password,:patientName,:age,:gender)"); query.bindValue(":username", username); query.bindValue(":password",password); query.bindValue(":patientName", name); query.bindValue(":age", age); query.bindValue(":gender", gender); query.exec(); QMessageBox::information(this,"警告","註冊成功!",QMessageBox::Ok); } }
5、資料庫連執行緒式碼
#ifndef CONNECTION #define CONNECTION #include <QSqlDatabase> #include <QStringList> #include <QString> #include <QDebug> #include <QSqlQuery> #include <QMessageBox> static bool createConnection() { //測試用例:連線mysql資料庫,做一個基本的sql語句操作 //1、對qt下資料庫的驅動進行遍歷檢視 QStringList drivers = QSqlDatabase::drivers(); foreach (QString driver, drivers) { qDebug()<<drivers; } //2、開啟資料庫過程 QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL"); //資料庫連線的資訊進行設定 db.setHostName("localhost");//設定主機名(資料庫所在電腦的名稱) db.setDatabaseName("medical_system");//設定資料庫名稱 db.setUserName("root"); db.setPassword("123456"); //db.setPort(3306);//因為是本機,該段程式碼可省略 if(!db.open()){ //開啟失敗的情況 qDebug()<<"Failed to connect"; //實際情況下我們應該使用圖形化視窗提示開啟失敗 QMessageBox::critical(0,"無法開啟資料庫","無法建立",QMessageBox::Yes); return false; } return true; } #endif // CONNECTION
執行結果
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援it145.com。
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45