📄 modpsward.cpp
字号:
// ModPsward.cpp : implementation file
//
#include "stdafx.h"
#include "DMS2.h"
#include "ModPsward.h"
#include "LoginSet.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CModPsward dialog
CModPsward::CModPsward(CWnd* pParent /*=NULL*/)
: CDialog(CModPsward::IDD, pParent)
{
//{{AFX_DATA_INIT(CModPsward)
m_newps = _T("");
m_confirmps = _T("");
m_formerps = _T("");
//}}AFX_DATA_INIT
}
void CModPsward::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CModPsward)
DDX_Text(pDX, IDC_PASSWORD2, m_newps);
DDX_Text(pDX, IDC_PASSWORD3, m_confirmps);
DDX_Text(pDX, IDC_PASSWORD1, m_formerps);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CModPsward, CDialog)
//{{AFX_MSG_MAP(CModPsward)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CModPsward message handlers
void CModPsward::OnOK()
{
// m_database.Close();
// if(!m_database.IsOpen()){
// m_database.Open(_T("DMS"));
// }
// TODO: Add extra validation here
UpdateData(TRUE);//读入用户输入的信息
CDBVariant varValue; //CDBUariant类可用于表示MFC ODBC的变体(variant)数据类型
CLoginSet m_recordset(&m_database);
CString strSQL;
strSQL.Format("select * from USER where USER='%s'",user); //在数据库中查找当前用户的密码
m_recordset.Open(AFX_DB_USE_DEFAULT_TYPE,strSQL);
// m_recordset.GetFieldValue(1,varValue);//在当前记录中获取域数据 varValue用于保存CDBUariant对象的索引
/* //如果输入的原密码和数据库中的不一致,提示old passward wrong!
if(m_formerps.Compare(varValue.m_pstring->GetBuffer(1))!=0)//Copmare()比较两个CString字符串
//GetBuffer()返回一个指向CString对象的内部字符缓冲区的指针
{
MessageBox("旧密码错!");
m_formerps.Empty();//将原密码长度强制为0
m_newps.Empty();
m_confirmps.Empty();
UpdateData(FALSE);//变量数据传给控件
}
else{
//确认密码,如果两遍新密码不一致,提示
if(m_newps.Compare(m_confirmps)!=0){
MessageBox("新密码错!");
m_formerps.Empty();
m_newps.Empty();
m_confirmps.Empty();
UpdateData(FALSE);
}
//如果一切正确,更新数据库,提示修改成功
else{
strSQL.Format("delete from USER where USER='%s'",user);
m_database.ExecuteSQL(strSQL);
strSQL.Format("insert into PSWD values(\'%s\',\'%s\')",user,m_newps);
m_database.ExecuteSQL(strSQL);
MessageBox("密码修改成功");
CDialog::OnOK();
}
}*/
if(m_formerps.Compare(m_recordset.m_PSWD)!=0)//Copmare()比较两个CString字符串
//GetBuffer()返回一个指向CString对象的内部字符缓冲区的指针
{
MessageBox("旧密码错!");
m_formerps.Empty();//将原密码长度强制为0
m_newps.Empty();
m_confirmps.Empty();
UpdateData(FALSE);//变量数据传给控件
}
else{
//确认密码,如果两遍新密码不一致,提示
if(m_newps.Compare(m_confirmps)!=0){
MessageBox("新密码错!");
m_formerps.Empty();
m_newps.Empty();
m_confirmps.Empty();
UpdateData(FALSE);
}
//如果一切正确,更新数据库,提示修改成功
else{
strSQL.Format("delete from USER where USER='%s'",user);
m_database.ExecuteSQL(strSQL);
strSQL.Format("insert into USER values(\'%s\',\'%s\')",user,m_newps);
m_database.ExecuteSQL(strSQL);
MessageBox("密码修改成功");
CDialog::OnOK();
}
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -