Ruslan Polupan
Ruslan Polupan19. Juli 2019 10:25

IMpos-Projekt. Teil 005. Anwendungseinstellungen lesen. Implementierung des Benutzer-Login-Dialogs zum System.

Anwendungseinstellungen lesen

Anwendungseinstellungen werden in der Optionstabelle der SQLite-Datenbank iMpos.opt gespeichert.
Um Optionswerte zu erhalten und festzulegen, erstellen wir die Options-Klasse und implementieren die entsprechenden Methoden darin.


Optionen.h

#ifndef OPTIONS_H
#define OPTIONS_H

#include <QObject>
#include <QSqlQuery>
#include <QSqlError>
#include <QVariant>

class Options : public QObject
{
    Q_OBJECT
public:
    explicit Options(QObject *parent = nullptr);
    QVariant getOption(int optionID);              //Получение значения опции
    void setOption(int optionID, QString value);    //Установка значения опции

signals:

public slots:

private:
    QSqlDatabase db;        //База Данных
};

#endif // OPTIONS_H

options.cpp

#include "options.h"
#include "LoggingCategories/loggingcategories.h"

Options::Options(QObject *parent) : QObject(parent)
{
    //используем соедиенеие с базой данных options
    db = QSqlDatabase::database("options");
}

QVariant Options::getOption(int optionID)
{
    QSqlQuery q = QSqlQuery(db);
    q.prepare("SELECT value FROM options WHERE option_id=:optionID");
    q.bindValue(":optionID",optionID);
    if(!q.exec()) {
        qCritical(logCritical()) << "Не удалось получить значение опции" << optionID << ".Причина" << q.lastError().text();
        return QVariant();
    }
    q.next();
    return q.value(0);
}

void Options::setOption(int optionID, QString value)
{
    QSqlQuery q = QSqlQuery(db);
    q.prepare("UPDATE options SET value = :value WHERE option_ID = :optionID");
    q.bindValue(":optionID", optionID);
    q.bindValue(":value", value);
    if(!q.exec()) {
        qCritical(logCritical()) << "Не удалось обновить опцию" << optionID << "Причина" << q.lastError().text();
    }
}

Wir binden die Header-Dateien options.h und logindialog.h in main.cpp ein und fügen den folgenden Code hinzu, bevor wir das Hauptfenster aufrufen.

    Options opt;
    //Проверяем значение опции 1000 
    if(opt.getOption(1000).toBool()){
        //Создаем диалогвое окно
        LoginDialog *loginDlg = new LoginDialog();
        loginDlg->exec();
        //Если вход не состоялся завершаем работу программы
        if(loginDlg->result() == QDialog::Rejected){
            QMessageBox::critical(nullptr,"Ошибка входа",
                                  "Не выполнен вход в систему!<br>Дальнейшая работа не возможна.");
            qCritical(logCritical()) << "Не выполнен вход в систему. Закрытие программы.";
            return 1;
        }
    }

Wir setzen den Wert der Option 1000 auf true, um die Optionstabelle zu überprüfen. Wir starten das Programm.

Der Dialog wird aufgerufen, und wenn er geschlossen wird, endet das Programm.

Implementierung des Benutzer-Login-Dialogs.

Ich möchte auf die Erstellung einer Reihe von Signal-Slot-Steuerelementen mit Qt Designer achten.
Öffnen Sie unser Formular, klicken Sie mit der rechten Maustaste auf das comboBoxUser-Objekt, wählen Sie Go to Slot... . Wählen Sie das aktivierte (int) Signal.

Und sofort bekommen wir die Implementierung des Slots. Alle anderen Manipulationen werden für uns durchgeführt.

void LoginDialog::on_comboBoxUser_activated(int index)
{

}

logindialog.h

#ifndef LOGINDIALOG_H
#define LOGINDIALOG_H

#include <QDialog>
#include <QSqlTableModel>
#include <QSqlRecord>
#include <QSqlError>

namespace Ui {
class LoginDialog;
}

class LoginDialog : public QDialog
{
    Q_OBJECT

public:
    explicit LoginDialog(QWidget *parent = nullptr);
    ~LoginDialog();

private slots:
    void on_comboBoxUser_activated(int idx);
    void on_buttonBox_rejected();
    void on_buttonBox_accepted();

private:
    void createUI();        //Первоначальные настройки приложения
    void createModel();     //Создание модели пользователей
private:
    Ui::LoginDialog *ui;
    QSqlTableModel *modelUsers;         //Модель данных пользователей
    int userID;                         //ID выбранного пользователя
    QString userPass;                   //Пароль выбранного пользователя из базы данных
};

#endif // LOGINDIALOG_H

logindialog.cpp

#include "logindialog.h"
#include "ui_logindialog.h"
#include "LoggingCategories/loggingcategories.h"

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

    createModel();
    createUI();
}

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

void LoginDialog::createUI()
{
    //Очишаем информационное сообщение
    ui->labelInfo->clear();

    //Связываем модель и comboBox
    ui->comboBoxUser->setModel(modelUsers);
    //Устанавливаем отображение в comboBox столбца с номером 1
    ui->comboBoxUser->setModelColumn(1);
    //Текущий индекс -1 т.е. ничего не выбрано
    ui->comboBoxUser->setCurrentIndex(-1);

}

void LoginDialog::createModel()
{
    //Используем соединение с базой данный options
    QSqlDatabase db = QSqlDatabase::database("options");
    modelUsers = new QSqlTableModel(this,db);

    modelUsers->setTable("users");
    modelUsers->select();

}

void LoginDialog::on_comboBoxUser_activated(int idx)
{
    userPass.clear(); //Очищаем переменную с паролем...

    //Получаем данные из модели
    userID = modelUsers->data(modelUsers->index(idx,0)).toInt();
    userPass = modelUsers->data(modelUsers->index(idx,2)).toString();
}

void LoginDialog::on_buttonBox_rejected()
{
    this->reject();
}

void LoginDialog::on_buttonBox_accepted()
{
    if(ui->comboBoxUser->currentIndex()>=0) {
        if(userPass==ui->lineEditPass->text().trimmed()) {
            qInfo(logInfo()) << QString("Пользователь: %1. Успешный вход в систему.").arg(ui->comboBoxUser->currentText());
            this->accept();
        } else {
            ui->labelInfo->setText("Не верный пароль!");
            qWarning(logInfo()) << QString("Пользователь: %1. Не верный пароль!.").arg(ui->comboBoxUser->currentText());
            ui->lineEditPass->clear();
        }
    }
}

Wir starten die Anwendung. Der Anmeldedialog erscheint. Wenn das Passwort nicht korrekt ist, wird eine Meldung angezeigt. Wenn Sie das richtige Passwort eingeben, wird das Hauptprogrammfenster gestartet.

Projektarchiv
iMposCh005.zip iMposCh005.zip

Aktueller Projektstatus hier.

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

Kommentare

Nur autorisierte Benutzer können Kommentare posten.
Bitte Anmelden oder Registrieren
Letzte Kommentare
A
ALO1ZE19. Oktober 2024 08:19
Fb3-Dateileser auf Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Игорь Максимов5. Oktober 2024 07:51
Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas55. Juli 2024 11:02
QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
k
kmssr8. Februar 2024 18:43
Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Jetzt im Forum diskutieren
J
JacobFib17. Oktober 2024 03:27
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
JW
Jhon Wick1. Oktober 2024 15:52
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Кирилл Гусарев27. September 2024 09:09
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
F
Fynjy22. Juli 2024 04:15
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

Folgen Sie uns in sozialen Netzwerken