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

 

 

 

 

 

 

  

转载于:https://www.cnblogs.com/cfxin/p/7889362.html

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值