📄 ulogin.pas
字号:
unit uLogin;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, InvokeRegistry, StdCtrls, DB, DBClient, ExtCtrls, Grids,
DBGrids, ADODB, main, kxiancommon;
type
TLoginDlg = class(TForm)
Label1: TLabel;
Label2: TLabel;
edtPassword: TEdit;
edtAccount: TEdit;
Panel1: TPanel;
btnOK: TButton;
btnCancel: TButton;
adoqUser: TADOQuery;
procedure btnOKClick(Sender: TObject);
procedure FormCreate(Sender: TObject);
procedure btnCancelClick(Sender: TObject);
private
public
//验证帐号匹配,具体实现应不同的存储方式而不同,将在以下各实现细节中说明
function VerifyAccount: Boolean;
//一个类方法,以便在Project主程序中调用此方法来执行登录,
//如果登录成功返回True,否阿返回False。
class function Execute(var AUserID: string; var AUserName: string): Boolean;
end;
implementation
{$R *.dfm}
{ TLoginDlg }
class function TLoginDlg.Execute(var AUserID: string; var AUserName: string): Boolean;
begin
RESULT := FALSE;
with TLoginDlg.Create(nil) do
try
Result := ShowModal = mrOk;
AUserID := adoqUser.FieldByName('UserID').Asstring;
AUserName := adoqUser.FieldByName('UserName').Asstring;
sTrueName := adoqUser.FieldByName('TrueName').Asstring;
finally
Free;
end;
end;
function TLoginDlg.VerifyAccount: Boolean;
begin
Result := False;
with adoqUser do
begin
Parameters.ParamByName('userName').Value := edtAccount.Text;
Parameters.ParamByName('Password').Value := edtPassword.Text;
if Active then Close;
Open;
if RecordCount > 0 then ModalResult := mrOk;
end;
Result := ModalResult = mrOk;
end;
procedure TLoginDlg.btnOKClick(Sender: TObject);
begin
if not VerifyAccount then ShowMessage('用户或密码错误,请重新输入!');
end;
procedure TLoginDlg.FormCreate(Sender: TObject);
begin
adoquser.Connection := adocwdkz;
end;
procedure TLoginDlg.btnCancelClick(Sender: TObject);
begin
// APPLICATION.Terminate;
end;
end.
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -