MFC多文档登录注册连接mysql数据库-登陆界面在主界面之前

1.新建一个多文档程序BusSim,在资源中新建登录DIALOG,其ID为IDD_LOGIN,其界面如下图所示:
登录界面
用户名编辑框设置其ID为IDC_USERNAME,密码框,即新建编辑框控件,在属性中将Password由false修改为true,设置其ID为IDC_PASSWORD。
属性页面
登录按钮的ID为IDC_LOGIN,注册按钮的ID为:IDC_LOGIN_REGISTER
再新建注册DIALOG,其ID为IDD_REGISTER,其界面如下图所示:
注册界面
2.选择登陆界面给该对话框添加类CLogin
添加类
再给用户名和密码的编辑框添加变量
选中对话框右击鼠标选择新建类向导,类向导中选择成员变量那一栏,然后选择IDC_USERNAME,IDC_PASSWORD分别添加变量value->CString->m_n_Username,value->CString->m_n_Password。
具体添加过程如下图所示:
类向导
添加变量
3.给登录按钮添加响应事件,有两种方法:
a.双击登录按钮即可
b.选中登录按钮右击鼠标选择添加事件处理程序即可
4.登陆界面实现代码:
Login.h

#pragma once
#include "afxwin.h"
#include "ToString.h"

// CLogin 对话框

class CLogin : public CDialogEx
{
    DECLARE_DYNAMIC(CLogin)

public:
    CLogin(CWnd* pParent = NULL);   // 标准构造函数
    virtual ~CLogin();

// 对话框数据
    enum { IDD = IDD_LOGIN };

protected:
    virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV 支持

    DECLARE_MESSAGE_MAP()
public:
    ToString tostr;
    CEdit m_username;
    CString m_n_Username;
    CEdit m_n_password;
    CString m_n_Password;
    afx_msg void OnBnClickedLogin();
    afx_msg void OnBnClickedLoginRegister();
    afx_msg void OnBnClickedCancel();
    afx_msg void OnBnClickedBtnModify();
};

Login.cpp : 实现文件

//

#include "stdafx.h"
#include "BusSim.h"
#include "Login.h"
#include "Register.h"
#include "afxdialogex.h"
#include "Mysql.h"
#include "ToString.h"//自己设置的字符串转换类
#include "SetDefine.h"




// CLogin 对话框

IMPLEMENT_DYNAMIC(CLogin, CDialogEx)

CLogin::CLogin(CWnd* pParent /*=NULL*/)
    : CDialogEx(CLogin::IDD, pParent)
    , m_n_Username(_T(""))
    , m_n_Password(_T(""))
{

}

CLogin::~CLogin()
{
}

void CLogin::DoDataExchange(CDataExchange* pDX)
{
    CDialogEx::DoDataExchange(pDX);
    DDX_Control(pDX, IDC_USERNAME, m_username);
    DDX_Text(pDX, IDC_USERNAME, m_n_Username);
    DDX_Control(pDX, IDC_PASSWORD, m_n_password);
    DDX_Text(pDX, IDC_PASSWORD, m_n_Password);
}


BEGIN_MESSAGE_MAP(CLogin, CDialogEx)
    ON_BN_CLICKED(IDC_LOGIN, &CLogin::OnBnClickedLogin)
    ON_BN_CLICKED(IDC_LOGIN_REGISTER, &CLogin::OnBnClickedLoginRegister)
    ON_BN_CLICKED(IDCANCEL, &CLogin::OnBnClickedCancel)
    ON_BN_CLICKED(IDC_BTN_MODIFY, &CLogin::OnBnClickedBtnModify)
END_MESSAGE_MAP()

// CLogin 消息处理程序

void CLogin::OnBnClickedLogin()
{
    // TODO: ÔÚ´ËÌí¼Ó¿Ø¼þ֪ͨ´¦Àí³ÌÐò´úÂë
    UpdateData();
    GetDlgItem(IDC_USERNAME)->GetWindowText(m_n_Username);
    GetDlgItem(IDC_PASSWORD)->GetWindowText(m_n_Password);

    if(m_n_Username.IsEmpty()||m_n_Password.IsEmpty())
    {
        MessageBox(_T("用户名或密码不能为空!"),_T("用户登录信息"));
        //m_n_Username.Empty();   //清空编辑框

       // m_n_Password.Empty();   //清空编辑框

        UpdateData(FALSE);
        return;
    }

    char *sql = tostr.tostring(m_n_Username);//字符串类型转换

    char  sql
  • 7
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MFC中实现登录界面连接数据库,可以使用ODBC来建立与数据库连接。首先需要在本机中配置ODBC数据源,然后使用AppWizard自动生成的代码框架通过ODBC连接数据库。 具体的步骤如下: 1. 首先,在本机的控制面板中找到ODBC数据源管理器,并打开。 2. 在ODBC数据源管理器中,选择“系统 DSN”选项卡,然后点击“添加”按钮。 3. 在新弹出的对话框中,选择对应的数据库驱动程序,然后点击“完成”按钮。 4. 填写数据源名称、描述和服务器等相关信息,然后点击“下一步”按钮。 5. 输入正确的数据库登录信息,然后点击“测试连接”按钮,确认连接成功后,点击“确定”按钮。 6. 现在你已经成功创建了一个ODBC数据源,可以在MFC应用程序中使用这个数据源连接数据库了。 请注意,以上步骤只是简要介绍了如何配置ODBC数据源,而具体的代码实现需要根据具体的情况来定。你可以在MFC应用程序中使用ODBC的API函数或者使用MFC封装的类库来实现数据库连接和操作。 以下是一个简单的示例代码,展示了如何使用MFC中的AppWizard生成的代码框架连接数据库: ```cpp // 在登录界面的按钮点击事件中实现数据库连接和操作 void CLoginDlg::OnBnClickedLogin() { // 声明数据库连接对象 CDatabase db; // 打开数据库连接 if (db.OpenEx("DSN=YourDataSourceName")) { CString strSQL; // 构造SQL语句 strSQL.Format("SELECT * FROM Users WHERE Username='%s' AND Password='%s'", m_strUsername, m_strPassword); // 执行SQL查询 CRecordset rs(&db); rs.Open(CRecordset::forwardOnly, strSQL); if (!rs.IsEOF()) { // 登录成功 AfxMessageBox("登录成功!"); } else { // 登录失败 AfxMessageBox("用户名或密码错误!"); } // 关闭记录集和数据库连接 rs.Close(); db.Close(); } else { // 连接数据库失败 AfxMessageBox("无法连接数据库!"); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值