QT模仿QQ界面的简单小程序

本文介绍利用QT写一个简单的模仿QQ小程序。使用到的有数据库、scoket通信、ui布局的使用、数据库的增删改查等功能。
界面布局如下:
QT模仿QQ界面的简单小程序_第1张图片
QPushBotton的使用以及按钮使用可根据自己的喜欢设置颜色以及背景图片等功能。
创建连接数据库为:QT模仿QQ界面的简单小程序_第2张图片
数据库的相关代码为:

bool createConnection_SQLITE()

{
    db_sqlite = QSqlDatabase::addDatabase("QSQLITE");
    db_sqlite.setDatabaseName("user.dat");
    if(!db_sqlite.open())
    {
        return false;
    }
        return true;
}

void createFakeData_xinxi_SQLITE()
{
    QSqlQuery query;
    query.exec("DROP TABLE xinxi");
    query.exec("CREATE TABLE xinxi("
               "id INTEGER PRIMARY KEY AUTOINCREMENT, "     //键值默认的
               "time VARCHAR(40) NOT NULL, "                //表有几列
               "user VARCHAR(40) NOT NULL, "                 //NOT NULL不能为空
               "pwd VARCHAR(40) NOT NULL, "
               "iphone VARCHAR(40) NOT NULL) ");
    query.exec("INSERT INTO xinxi (time,user,pwd,iphone) ");

    query.exec(QString("INSERT INTO xinxi (time,user,pwd,iphone) "
                   "VALUES ('%1','%2','%3','%4')"));//插入一行数据,列的名称

}

创建数据库链表,这个链表大家可以根据自己需要的数据行列进行添加,具体查看sql数据库的操作指令即可使用。
用户注册界面:QT模仿QQ界面的简单小程序_第3张图片
需要将获取到的文本框字符串一条一条的插入数据库即可,用connect()函数连接。
注意:我们登录时候需要连接数据库,与数据库里的账号密码做判断,如果相等才可以进去聊天界面。代码为:
user=ui->lineEdit_name->text();
psd=ui->lineEdit_pwd->text();
if(user==""||psd==""){
QMessageBox::warning(this,tr(“Warning”),tr(“用户名或密码为空”),QMessageBox::Ok);
}
else {
QString s=QString(“select * from xinxi where user=’”+user+"’ and pwd=’"+psd+"’");
QSqlQuery query;
if(query.exec(s)&&query.next()){ //query.exec(s)是否执行成功,query.next()返回查询结果中的第一条
QMessageBox::information(nullptr, “Title”, “登录成功”, QMessageBox::Yes, QMessageBox::Yes);
this->hide();
myclient->show();
}
else {
QMessageBox::warning(this,tr(“Warning”),tr(“用户名或密码错误”),QMessageBox::Ok);
}
}
这就是简单的登录界面写好了。如果考虑到数据库信息安全问题,只需要在加一个登录界面即可。唯一标识只有你自己才可以打开数据库并且显示。有什么不足的地方还请大家指教。
以下是运行完整的QQ:QT模仿QQ界面的简单小程序_第4张图片

QT模仿QQ界面的简单小程序_第5张图片QT模仿QQ界面的简单小程序_第6张图片
对数据库进行了二次加密,只能自己查看数据库里注册的账号密码等信息:在这里插入图片描述QT模仿QQ界面的简单小程序_第7张图片
聊天界面正在逐步完善,完善成功后再来分享。

你可能感兴趣的:(qt,数据库,sql,mysql)