Qt 通过Sqlite数据库登录,账号密码无法正确验证,永远登陆成功。

 QString user;
        QString pwd;
        user = usrLineEdit->text();//获取用户名
        pwd = pwdLineEdit->text();//获取密码
        if(user == "")
            QMessageBox::warning(this,"","用户名不能为空!");
        else if(pwd == "")
            QMessageBox::warning(this,"","密码不能为空!");
        else
        {
 
            QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
            db.setDatabaseName("passwd.db");
            //sql语句在数据库中进行查询验证
            if(db.open())
            {
                 QSqlQuery query =QSqlQuery(db);
                 QString S =QString("select * from passwd where name='%1' AND pswd='%2' ").arg(user).arg(pwd);
                 qDebug()<<query.exec(S);
                 if(query.exec(S))
                 {
                     accept();
                 }
                 else
                    QMessageBox::warning(NULL,"Error","用户名或密码错误!");
 
            }
            else
                QMessageBox::warning(NULL,"Error","加载错误!");
 
        }

先打印user,pwd的值看看,确保SQL语句的值是否准确。

"select * from passwd where name='%1' AND pswd='%2' "

你将这条sql语句与数据组合起来在Sqlite上运行一下,看看是否可以测试通过。

看看是不是哪里写错了。

您好,我是有问必答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

速戳参与调研>>>https://t.csdnimg.cn/Kf0y