MFC連接mysql 實現登錄驗證


首先創建一個MFC對話框程序,添加相應組件

1. MFC連接mysql數據庫

   將這里下載的文件放到與項目文件相同的目錄

    鏈接:http://pan.baidu.com/s/1geX5X7P 密碼:jbe6

   在對話框程序對應的.cpp文件頭添加如下代碼

#include <winsock2.h> //定義socket 

#include "mysql.h" //連接mysql的接口

#pragma comment(lib,"libmysql.lib")//附加依賴項

 

2. 登錄實例

 

void LoginDlg::OnOK() 
{
    // TODO: Add extra validation here
    GetDlgItem(IDC_EDIT1)->GetWindowText(user_name); //獲得輸入的用戶名
    GetDlgItem(IDC_EDIT2)->GetWindowText(user_passwd); //獲得輸入的密碼

    const char user[]="mysql的用戶名";
    const char pswd[]="密碼";
    const char host[]="localhost";
    const char table[]="要連接的數據庫名";
    unsigned int port = 3306;

    MYSQL_RES *res;
    MYSQL_ROW row;
    MYSQL mysqlCon;

    if(user_name.IsEmpty()||user_passwd.IsEmpty())
    {
        MessageBox(_T("用戶名或密碼不能為空!"),_T("用戶登錄信息"));
        return;
    }

    mysql_init(&mysqlCon);
    if (!mysql_real_connect(&mysqlCon,host,user,pswd,table,port,NULL,0))
    {
        AfxMessageBox(_T("訪問數據庫失敗!"));
    }
    else
    {
        // mysql_query(&mysqlCon,"SET USER GBK"); 設置字符集
    
    } 
    CString select_sql_by_user;
    select_sql_by_user.Format("select user,passwd from users where user = \'%s\'",user_name);
    int ress=mysql_query(&mysqlCon,(char*)(LPCSTR)select_sql_by_user);
    if(ress==0) //檢測查詢成功
    {
        res = mysql_store_result(&mysqlCon);
        if(mysql_num_rows(res)==0) //查詢結果為空
        {
            AfxMessageBox("用戶不存在");
        }
        else
        {
            
            row=mysql_fetch_row(res);
            if(user_passwd==row[1])
            {
                mysql_free_result(res);
                MessageBox("登錄成功!");
            }
            else
            {
                AfxMessageBox("密碼錯誤!");
            }
        }
        
        
    }
    
    mysql_close(&mysqlCon);
}
View Code

 

 

 

 

 

 

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM