MFC连接mysql 实现登录验证

2018-06-17 21:32:34来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

首先创建一个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

 

 

 

 

 

 

  

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:设计模式----单例模式

下一篇:字符数组函数,连接strcat 复制函数strcpy 比较函数strcmp 长度