⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 passworddlg.cpp

📁 student manage system
💻 CPP
字号:
// PasswordDlg.cpp : implementation file
//

#include "stdafx.h"
#include "StudentScore.h"
#include "PasswordDlg.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CPasswordDlg dialog


CPasswordDlg::CPasswordDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CPasswordDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CPasswordDlg)
		// NOTE: the ClassWizard will add member initialization here
	//}}AFX_DATA_INIT
}


void CPasswordDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CPasswordDlg)
		// NOTE: the ClassWizard will add DDX and DDV calls here
	//}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CPasswordDlg, CDialog)
	//{{AFX_MSG_MAP(CPasswordDlg)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CPasswordDlg message handlers

void CPasswordDlg::OnOK() 
{
	//定义4个CEdit变量
	CEdit* pUsername=(CEdit*) this->GetDlgItem(IDC_EDIT_USERNAME);
    CEdit* pPassword=(CEdit*) this->GetDlgItem(IDC_EDIT_PASSWORD);
	CEdit* pNew=(CEdit*) this->GetDlgItem(IDC_EDIT_NEW);
	CEdit* pConfirm=(CEdit*) this->GetDlgItem(IDC_EDIT_CONFIRM);
	//分别将文本框的值赋给4个字符串 
	CString username,password,newPassword,confirmPassword;
	pUsername->GetWindowText(username);
	pPassword->GetWindowText(password);
	pNew->GetWindowText(newPassword);
	pConfirm->GetWindowText(confirmPassword);
	//定义数据库对象和记录集对象
	CDatabase m_database;
	CRecordset m_recordSet;
	//判断新密码是是为空
	if(newPassword.IsEmpty()||confirmPassword.IsEmpty())
	{
         MessageBox("密码不为空");	
	}
	else
	{
		if(newPassword!=confirmPassword)//判断两次输入的新密码是否相同
		{
			MessageBox("两次输入密码不一致,请重新输入新密码");
			pNew->SetWindowText("");//清空新密码文本框
			pConfirm->SetWindowText("");//清空确认密码文本框
			pNew->SetFocus();//设置新密码文本框为焦点
		}
		else
		{
			if(!m_database.IsOpen()){//如果数据没有打开,则打开数据库
				if(m_database.Open(_T("studentscore")))//如果正确打开数据库
				{   				    
					m_recordSet.m_pDatabase=&m_database;//将m_database对象赋给m_pDatabase
					CString strSQL;
					strSQL.Format("select * from userinfo where user_name='%s' and user_password='%s' and active_status='Y'",username,password);
					m_recordSet.Open(CRecordset::forwardOnly,strSQL);//打开记录集
					if(m_recordSet.GetRecordCount()==0)//如果找不到记录
					{
						MessageBox("密码错误,请重新输入","密码错误",MB_OK|MB_ICONWARNING);//提示密码错误
						pPassword->SetWindowText("");//清空密码文本框
						pNew->SetWindowText("");//清空新密码文本框
						pConfirm->SetWindowText("");//清空确认密码文本框
						pPassword->SetFocus();//设置用户名文本框为当前的焦点
					}
					else//如果找到记录
					{   
						//更新密码的sql语句
						strSQL.Format("update userinfo set user_password='%s' where user_name='%s'",newPassword,username);
                        m_database.ExecuteSQL(strSQL);//执行sql 
						MessageBox("修改密码成功!");
                        CDialog::OnOK();
					}
					m_recordSet.Close();//关闭记录集
					m_database.Close();//关闭数据库
				}
				else//如果没有正确打开数据库
				{
					MessageBox("不能打开数据库");
				}
			}
		}
	}
}

void CPasswordDlg::OnCancel() 
{
	// TODO: Add extra cleanup here
	CDialog::OnCancel();
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -