亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Qt實現(xiàn)驗證碼相關功能的代碼示例

 更新時間:2024年01月28日 09:31:36   作者:做一個AC夢  
驗證碼的原理基于人類視覺和計算機視覺的差異性,通過給用戶顯示一些難以被機器識別的圖形或文字,讓用戶進行人機交互,確認自己的身份,這樣可以有效保護網(wǎng)站安全,所以本給大家介紹了Qt實現(xiàn)驗證碼相關功能的代碼示例,感興趣的朋友可以參考下

驗證碼的原理

驗證碼的原理基于人類視覺和計算機視覺的差異性。通過給用戶顯示一些難以被機器識別的圖形或文字,讓用戶進行人機交互,確認自己的身份。這樣可以防止機器大規(guī)模注冊、機器暴力破解數(shù)據(jù)密碼等危害,保護網(wǎng)站安全。

Qt實現(xiàn)驗證碼的原理

  • 隨機性:驗證碼必須是隨機生成的,以確保每次顯示的內(nèi)容都不同。
  • 安全性:驗證碼的生成過程需要考慮到安全性,例如使用不同的算法生成驗證碼,避免被惡意程序破解。
  • 用戶交互:驗證碼生成后,需要由用戶進行識別和填寫,通過用戶的操作來判斷用戶的有效性。
  • 圖形界面:在Qt中,可以使用圖形界面組件來顯示驗證碼,例如QLabel或QPushButton等。
  • 圖像處理:為了增加驗證碼的識別難度,可以在驗證碼中添加噪聲、扭曲等效果,這需要使用圖像處理技術來實現(xiàn)。

實現(xiàn)步驟

  • 創(chuàng)建UI界面:首先,在QT Designer中創(chuàng)建一個UI界面,添加一個Label標簽,兩個Button按鈕以及一個lineEdit輸入框,并且將這些組件均放入widget樣式表當中,并將widget樣式表放入centralwidget樣式表中。(在UI設計師界面可以使用SHIFT+ALT+R進行預覽布局效果)

  • 設置Label標簽:將Label標簽設置為顯示驗證碼。你可以使用QLabel類來創(chuàng)建標簽,并設置其文本屬性。
  • 實現(xiàn)驗證碼邏輯:編寫代碼以生成驗證碼。這通常涉及到一個隨機數(shù)生成器,用于生成一個唯一的驗證碼字符串。
  • 刷新驗證碼:當用戶點擊按鈕時,重新生成一個新的驗證碼,并更新Label標簽的文本屬性。
  • 驗證驗證碼:當用戶提交表單時,驗證你所輸入的驗證碼是否與Label標簽上顯示的驗證碼匹配。

具體代碼

  • mainwindow.h
#ifndef MAINWINDOW_H
#define MAINWINDOW_H
 
#include <QMainWindow>
#include <QTimer>
#include <QMessageBox>
#include <QPainter>
#include <QDebug>
QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE
 
class MainWindow : public QMainWindow
{
    Q_OBJECT
 
public:
    MainWindow(QWidget *parent = nullptr);
    QString m_captcha;
    QColor m_color;
    void paintEvent(QPaintEvent* evt);
    QString getCaptcha();
    QColor generateRandomColor() ;
    ~MainWindow();
private slots:
    void on_pushButton_clicked();
    void on_pushButton_2_clicked();
private:
    Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H
  • main.cpp
#include "mainwindow.h"
 
#include <QApplication>
 
int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    MainWindow w;
    w.show();
    return a.exec();
}
  • mainwindow.cpp
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QRandomGenerator>
MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    // 設置UI界面
    m_captcha = getCaptcha();
    // 獲取驗證碼
    m_color = generateRandomColor();
    // 生成隨機顏色
}
 
 
MainWindow::~MainWindow()
{
    delete ui;
}
 
void MainWindow::on_pushButton_clicked()//驗證按鈕的槽函數(shù)
{
    QString captcha = ui->lineEdit->text().replace(" ", "");
    // 獲取用戶輸入的驗證碼并去除空格
 
    if(captcha.toLower() == m_captcha.toLower())
    // 將用戶輸入的驗證碼和生成的驗證碼進行比較(忽略大小寫)
    {
        QMessageBox::warning(this, "Warning", "Captcha is macthed");
        // 如果驗證碼匹配,顯示匹配提示框
    }
    else
    {
        QMessageBox::warning(this, "Warning", "Captcha is not macthed");
        // 如果驗證碼不匹配,顯示不匹配提示框
        m_captcha = getCaptcha();
        // 獲取新的驗證碼
    }
}
 
 
void MainWindow::on_pushButton_2_clicked()//刷新按鈕的槽函數(shù)
{
    m_captcha = getCaptcha(); // 獲取新的驗證碼
    m_color = generateRandomColor(); // 生成隨機顏色
    repaint(); // 重新繪制窗口
    update(); // 更新窗口顯示
}
 
 
void MainWindow::paintEvent(QPaintEvent *evt)
{
    QPainter painter(this);
 
    // 填充背景為白色
    painter.fillRect(ui->label->x()+ui->widget->x(), ui->label->y()+ui->widget->y(), ui->label->width(), ui->label->height(), Qt::white);
 
    // 設置字體樣式
    painter.setFont(QFont("Lucida Console", 18,QFont::Bold));
 
    // 繪制驗證碼字符
    for(int i = 0; i < 4; i++)
    {
        QColor color = generateRandomColor();
        // 生成隨機顏色
        QPen pen(color);
        pen.setWidth(1);
        painter.setPen(pen);
        painter.drawText(ui->label->x() +ui->widget->x()+ 30*i, ui->label->y()+ui->widget->y(), 30, ui->label->height(), Qt::AlignCenter,
                         QString(m_captcha[i]));
                         // 繪制驗證碼字符
    }
 
    // 繪制噪點
    for(int i=0; i<1500; i++)
    {
        QColor color = generateRandomColor();
        // 生成隨機顏色
        QPen pen(color);
        pen.setWidth(1);
        painter.setPen(pen);
        painter.drawPoint(ui->label->x()+ui->widget->x()+ (qrand() % ui->label->width()), ui->label->y()+ui->widget->y() + (qrand() % ui->label->height()));
    }
 
    // 繪制干擾線
    for(int i = 0;i < 10;++i)
    {
        painter.drawLine(ui->label->x()+ui->widget->x()+qrand()%ui->label->width(),ui->label->y()+ui->widget->y()+qrand()%ui->label->height(),
                         ui->label->x()+ui->widget->x()+qrand()%ui->label->width(),ui->label->y()+ui->widget->y()+qrand()%ui->label->height());
    }
}
 
 
QString MainWindow::getCaptcha()
{
    const QString possibleCharacters = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
    const int captchaLength = 4;
    QString result = "";
 
    // 生成驗證碼字符串
    for (int i = 0; i < captchaLength; ++i) {
        int index = QRandomGenerator::global()->bounded(possibleCharacters.length());
        // 生成一個0到possibleCharacters長度之間的隨機整數(shù)
        result.append(possibleCharacters.at(index));
        // 將隨機位置的字符添加到結果字符串中
    }
 
    return result; // 返回生成的驗證碼字符串
}
 
 
QColor MainWindow::generateRandomColor() {
    int red = QRandomGenerator::global()->bounded(256);
    // 生成0到255之間的隨機整數(shù)作為紅色通道的值
    int green = QRandomGenerator::global()->bounded(256);
    // 生成0到255之間的隨機整數(shù)作為綠色通道的值
    int blue = QRandomGenerator::global()->bounded(256);
    // 生成0到255之間的隨機整數(shù)作為藍色通道的值
    return QColor(red, green, blue);
    // 使用生成的RGB值創(chuàng)建并返回一個QColor對象
}
 

相關代碼的注解

fillRect的相關用法

  • 在Qt的QPainter類中,fillRect()函數(shù)用于填充矩形。它需要兩個參數(shù):一個QRect對象和QBrush對象。
  • QRect對象定義了矩形的位置和大小,而QBrush對象則定義了矩形的填充方式。我們可以將QColor對象作為刷子傳遞給這個函數(shù),以指定實填充模式。
  • 如果顏色不是完全的不透明(即alpha通道值小于255),則先繪制白色背景,然后使用fillRect()函數(shù)填充矩形。因此,fillRect()函數(shù)的參數(shù)含義為:第一個參數(shù)是一個QRect對象,表示要填充的矩形區(qū)域。它包含了矩形的左上角坐標(x, y)和其寬度和高度(width, height)。第二個參數(shù)是一個QBrush對象,表示填充矩形的樣式??梢詫Color對象作為刷子傳遞給這個函數(shù),以指定實填充模式。

示例代碼

void MyWidget::paintEvent(QPaintEvent *event)
{
    QPainter painter(this);
    QRect rect(10, 10, 100, 50); // 定義一個矩形區(qū)域
    QColor color(255, 0, 0); // 定義紅色
    painter.fillRect(rect, color); // 填充矩形
}

在上述示例中,我們定義了一個矩形區(qū)域 rect,左上角坐標為 (10, 10),寬度為 100,高度為 50。然后,我們使用 fillRect 方法填充該矩形區(qū)域為紅色。

 對于上述代碼mainwindow.cpp中的painter.fillRect(ui->label->x()+ui->widget->x(), ui->label->y()+ui->widget->y(), ui->label->width(), ui->label->height(), Qt::white);解釋

如圖所示

相當于求A點相當于C點的坐標,也就是將B點相對于C點的坐標+A點相對于B點的坐標 即A點相當于C點的坐標為(ui->label->x()+ui->widget->x(), ui->label->y()+ui->widget->y())

效果圖

  • 初始界面

  • 驗證成功

  • 驗證失敗

  • 刷新驗證碼

最后

以上就是Qt實現(xiàn)驗證碼相關功能的代碼示例的詳細內(nèi)容,更多關于Qt實現(xiàn)驗證碼功能的資料請關注腳本之家其它相關文章!

相關文章

  • 用C語言實現(xiàn)猜數(shù)字游戲

    用C語言實現(xiàn)猜數(shù)字游戲

    這篇文章主要為大家詳細介紹了用C語言實現(xiàn)猜數(shù)字游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • C++基礎入門教程(八):函數(shù)指針

    C++基礎入門教程(八):函數(shù)指針

    這篇文章主要介紹了C++基礎入門教程(八):函數(shù)指針,本文講解了函數(shù)原型和函數(shù)定義、const限定符與指針、函數(shù)的指針參數(shù)、為什么要使用指針參數(shù)等內(nèi)容,需要的朋友可以參考下
    2014-11-11
  • opencv實現(xiàn)像素統(tǒng)計的示例代碼

    opencv實現(xiàn)像素統(tǒng)計的示例代碼

    本文介紹了OpenCV中統(tǒng)計圖像像素信息的常用方法和函數(shù),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2025-01-01
  • C++虛函數(shù)表深入研究

    C++虛函數(shù)表深入研究

    這篇文章主要介紹了C++的虛函數(shù)表,內(nèi)容非常詳細,思路清晰,需要的朋友可以參考下,希望能夠給你帶來幫助
    2021-10-10
  • 簡單掌握桶排序算法及C++版的代碼實現(xiàn)

    簡單掌握桶排序算法及C++版的代碼實現(xiàn)

    桶排序是將要排序的算法按桶分組排序之后再遍歷匯總的一種線性排序算法,下面就讓我們來通過小例子簡單掌握桶排序算法及C++版的代碼實現(xiàn)^^
    2016-07-07
  • C++中關于互斥量的全面認知

    C++中關于互斥量的全面認知

    線程的主要優(yōu)勢在于,能夠通過全局變量來共享信息。不過,這種便捷的共享是有代價的:必須確保多個線程不會同時修改同一變量,或者某一線程不會讀取正由其他線程修改的變量。為了防止出現(xiàn)線程某甲試圖訪?問一共享變量時,線程某乙正在對其進行修改。引入了互斥量
    2022-05-05
  • 詳細總結C++的排序算法

    詳細總結C++的排序算法

    趁空閑時間,小編決定把C++的排序算法分析并總結下,以便溫故知新。也方便需要的朋友可以參考學習。
    2016-07-07
  • C語言開發(fā)實現(xiàn)貪吃蛇游戲

    C語言開發(fā)實現(xiàn)貪吃蛇游戲

    這篇文章主要為大家詳細介紹了C語言開發(fā)實現(xiàn)貪吃蛇游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • C++學習之算術運算符使用詳解

    C++學習之算術運算符使用詳解

    運算符是計算機語言提供的能對數(shù)據(jù)進行基本運算操作的功能體。而算術運算符用來對數(shù)字型數(shù)據(jù)進行數(shù)學語義上的加、減、乘、除。本文通過講解清楚算術運算符,讓大家了解使用C++運算符時應該注意的事項
    2022-06-06
  • C/C++ Qt 基本文件讀寫的基本使用(2種實現(xiàn))

    C/C++ Qt 基本文件讀寫的基本使用(2種實現(xiàn))

    文件的讀寫是很多應用程序具有的功能,本文主要介紹了兩種實現(xiàn)方法,第一種使用QFile類的IODevice讀寫功能直接讀寫,第二種是利用 QFile和QTextStream結合起來,用流的方式進行文件讀寫
    2021-11-11

最新評論