📄 dlgchangepwd.cpp
字号:
// DlgChangePwd.cpp : implementation file
//
#include "stdafx.h"
#include "Project.h"
#include "DlgChangePwd.h"
#include "DlgLogin.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CDlgChangePwd dialog
CDlgChangePwd::CDlgChangePwd(CWnd* pParent /*=NULL*/)
: CDialog(CDlgChangePwd::IDD, pParent)
{
//{{AFX_DATA_INIT(CDlgChangePwd)
m_Account = _T("");
m_InitPwd = _T("");
m_NewPwd = _T("");
m_ConfirmPwd = _T("");
//}}AFX_DATA_INIT
}
void CDlgChangePwd::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CDlgChangePwd)
DDX_Text(pDX, IDC_USER, m_Account);
DDX_Text(pDX, IDC_INITPSW, m_InitPwd);
DDX_Text(pDX, IDC_NEWPSW, m_NewPwd);
DDX_Text(pDX, IDC_CONPSW, m_ConfirmPwd);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CDlgChangePwd, CDialog)
//{{AFX_MSG_MAP(CDlgChangePwd)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
void CDlgChangePwd::OnOK()
{
CDlgLogin dlgLogin;
try
{ //连接数据源
_bstr_t Conn = "DSN="+_bstr_t(dlgLogin.m_LoginDSN)+";"; //使用在DlgLogin中获取的DSN名
pConn.CreateInstance(__uuidof(Connection));
HRESULT hr=pConn->Open(Conn,_bstr_t(""),_bstr_t(""),adModeUnknown);
}
catch(_com_error& ex)
{
AfxMessageBox(ex.Description());
}
UpdateData(TRUE);
try
{
CString sql;
sql.Format("SELECT AccountNo FROM TableAccount WHERE AccountNo='%s' AND Pswd='%s'",
m_Account, m_InitPwd); //选取当前帐户和密码的记录
_RecordsetPtr pRst;
pRst = pConn->Execute(_bstr_t(sql), NULL, adCmdText);
if (pRst->End) //若没有查到记录
{
AfxMessageBox("用户名或密码错误!");
m_Account = m_InitPwd = m_NewPwd =m_ConfirmPwd = "";
this->UpdateData(false);
}
else
{
if(m_NewPwd== m_ConfirmPwd)
{
sql.Format("UPDATE TableAccount SET Pswd=\'%s\' WHERE AccountNo=\'%s\'",m_NewPwd,m_Account);
pConn->Execute(_bstr_t(sql), NULL, adCmdText);
AfxMessageBox("密码修改成功,重新登陆!");
CDialog::OnOK();
}
else
AfxMessageBox("两次输入密码不一致!");
}
pRst.Release();
pConn.Release(); //释放连接
}
catch(_com_error& e)
{
AfxMessageBox(e.ErrorMessage());
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -