📄 passworddlg.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 + -