亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

合理應用用戶登錄界面,用戶登錄時不必創建其他窗體

2019-11-18 18:14:48
字體:
來源:轉載
供稿:網友

/////////////////////  (一)項目文件  test.dPR //////////////////////
program SerialGet;

uses
  Forms,
  UMain in 'UMain.pas' {frmMain},
  ULogin in 'ULogin.pas' {frmLogin},
  UDataModule in 'UDataModule.pas' {DataModule1: TDataModule},

{$R *.res}

begin
  application.Initialize;

  if CreateMutex then                 //創建句柄,判斷此應用程序是否在運行
  begin
    //調用全局函數,創建并顯示登陸界面
    if doLogin then                   //登陸成功
    begin
      Application.CreateForm(TfrmMain, frmMain);
      //數據模塊文件不須在這兒創建,因為 ULogin.pas 中已創建
      //Application.CreateForm(TDataModule1, DataModule1);
      Application.Run;
    end else                          //登陸不成功
    begin
      try
        DataModule1.free;
        Application.terminate;
      except
      end;
    end;
  end else
  begin
    DestroyMutex;                     //釋放句柄
  end;
end.

////////////////  (二)登陸窗體 ULogin.pas  ULogin.dfm //////////////////
unit ULogin;

interface
uses ......
type
  ... ... ...
  private
    function checkPsw:integer;
  public
  end;

var
  frmLogin: TfrmLogin;

  function doLogIn:boolean;          // 全項目公用函數
  function CreateMutex: Boolean;     // 全項目公用函數
  procedure DestroyMutex;            // 全項目公用函數

implementation
uses UDataModule;  //引用數據模塊
var Mutex: hWnd;

{$R *.dfm}

function doLogIn:boolean;                 //由項目文件調用此函數
begin
  with TfrmLogin.create(application) do   //創建并顯示登陸界面
  begin
    //窗體的ShowModal屬性
    if ShowModal = mrok then result := true else result := false;
    free;
  end;
end;

procedure DestroyMutex;
begin
  if Mutex <> 0 then CloseHandle(Mutex);
end;

function CreateMutex: Boolean;
var
  PrevInstHandle: THandle;
  APPTitle: PChar;
begin
  AppTitle := StrAlloc(100);
  StrPCopy(AppTitle, Application.Title);
  Result := True;
  Mutex := Windows.CreateMutex(nil, False, AppTitle);
  if (GetLastError = ERROR_ALREADY_EXISTS) or (Mutex = 0) then begin
    Result := False;
    SetWindowText(Application.Handle, '');
    PrevInstHandle := FindWindow(nil, AppTitle);
    if PrevInstHandle <> 0 then begin
      if IsIconic(PrevInstHandle) then
        ShowWindow(PrevInstHandle, SW_RESTORE)
      else
        BringWindowToTop(PrevInstHandle);
      SetForegroundWindow(PrevInstHandle);
    end;
    if Mutex <> 0 then Mutex := 0;
  end;
  StrDispose(AppTitle);
end;

// -1: 密碼不對  1:數據庫不對  2:沒有此用戶  3:合法
function TfrmLogin.checkPsw:integer;
var name,sPsw,SQL,sValue:string;
begin
  Application.CreateForm(TDataModule1, DataModule1);  //此處創建了數據模塊
  if not DataModule1.ConnOK then
  begin result := 1;   exit;  end;

  name := lowercase(editName.text);  //文本框
  sPsw := lowercase(editPass.text);  //文本框
  sql := 'select * from maker where name="'+name+'"';
  if openSQL(SQL,DataModule1.dsDataSet) <=0 then
  begin result := 2; exit;  end;

  DataModule1.dsDataSet.First ;
  sValue := lowercase(DataModule1.dsDataSet.fieldbyName('loginPsw').asString);
  if sValue<>sPsw then result := -1 else result := 3;
end;

/////////////////////  (三)數據模塊 UDataModule.pas //////////////////////
... ... ... ...
type
  public
    ConnOK:boolean;
  end;
var
  DataModule1: TDataModule1;
  function OpenSQL(s: string;query:TADODataSet):integer;
  function DoSQL(s: string;query:TADOQuery):boolean;
 
implementation

{$R *.dfm}

procedure TDataModule1.DataModuleCreate(Sender: TObject); //連接ADOConnection
var SQL,pwd:string;
begin
  try
    pwd := 'deliSerial';
    SQL := 'Provider=Microsoft.Jet.OLEDB.4.0;Data Source='+
         extractfilepath(paramstr(0))+'SerialInfo.mdb'+
         ';Persist Security Info=False;'  +
         'Jet OLEDB:Database PassWord="'+pwd+'"';
    ADOConnection1.Connected := false;
    ADOConnection1.ConnectionString := SQL;
    ADOConnection1.Connected := true;
    ConnOK:=true;
  except
    ConnOK:=false;
  end;
end;

function OpenSQL(s: string;query:TADODataSet):integer; //查詢SQL
var old_Cursor:TCursor;
begin
  old_Cursor:=screen.cursor;
  screen.cursor:=crSQLWait;
  try
    try
      with query do
      begin
        close; commandtext:=s; open;
        result:=query.recordcount;       //返回結果集記錄數
      end;
    except
     result:=0;
    end;
  finally
    screen.cursor:=old_Cursor;
  end;
end;

function DoSQL(s: string;query:TADOQuery):boolean;  //運行 SQL
var old_Cursor:TCursor;
begin
  result:=true;
  old_Cursor:=screen.cursor;
  screen.cursor:=crSQLWait;
  try
    try
      with query do
      begin
        close; SQL.Clear; SQL.Add(s); ExecSQL;
      end;
    except
      result:=false;
    end;
  finally
    screen.cursor:=old_Cursor;
  end;
end;


上一篇:ADO帶密碼的數據連接、查詢一個記錄集、執行一SQL語句

下一篇:選擇一個網路鄰居

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
學習交流
熱門圖片

新聞熱點

疑難解答

圖片精選

網友關注

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲第一福利网| 国产精品自拍小视频| 日韩av中文字幕在线播放| 欧美激情亚洲自拍| 国产精品伦子伦免费视频| 欧美老少做受xxxx高潮| 色噜噜国产精品视频一区二区| 国产91精品久久久久久| 亚洲理论在线a中文字幕| 91在线国产电影| 欧美午夜精品久久久久久久| 欧美亚洲在线播放| 成人精品视频99在线观看免费| 国产精品黄色影片导航在线观看| 91手机视频在线观看| 2021久久精品国产99国产精品| 欧美性xxxx在线播放| 国产精品一区av| 欧美亚洲国产视频小说| 欧美理论电影在线观看| 国产美女主播一区| 日韩精品免费观看| 亚洲深夜福利网站| 久久精品国产免费观看| 国产精品亚洲自拍| 精品无人区乱码1区2区3区在线| 另类美女黄大片| 日韩欧美黄色动漫| 55夜色66夜色国产精品视频| 欧美日产国产成人免费图片| 亚洲精品电影在线观看| 国产精品jizz在线观看麻豆| 97久久伊人激情网| 国产一区二区三区视频在线观看| 91av视频在线免费观看| 久久国产加勒比精品无码| 日韩视频第一页| 日韩美女视频免费看| 在线观看成人黄色| 国产成人精品免高潮在线观看| 日本韩国欧美精品大片卡二| 97在线视频一区| 久久久久久久久久久国产| 91精品国产91久久久久福利| 欧美日韩人人澡狠狠躁视频| 国产一区二区丝袜高跟鞋图片| 美女视频黄免费的亚洲男人天堂| 欧美黑人巨大精品一区二区| 亚洲国产精品人人爽夜夜爽| 日韩电影在线观看永久视频免费网站| 欧美日韩亚洲视频一区| 亚洲999一在线观看www| 久久久久久久久爱| 韩国精品美女www爽爽爽视频| 97在线精品国自产拍中文| 亚洲成人性视频| 欧美在线视频观看| 久久久久亚洲精品国产| 成人黄色大片在线免费观看| 亚洲男人天堂久| 亚洲欧美色图片| 欧美性在线观看| 成人免费看黄网站| 美女福利视频一区| 日韩av在线网| 精品亚洲一区二区三区四区五区| 日韩av男人的天堂| 51视频国产精品一区二区| 精品国产乱码久久久久久天美| 久久中国妇女中文字幕| 国产精品一区=区| 亚洲国产成人av在线| 韩剧1988在线观看免费完整版| 国产成人精品视频在线| 欧美激情精品久久久久| 精品中文字幕在线| 国产成人免费av| 中文日韩在线观看| 久久精品亚洲国产| 国产丝袜一区视频在线观看| 国产精品久久久久久影视| 欧美美最猛性xxxxxx| 亚洲欧美精品一区| 日韩欧美在线视频观看| 最近2019中文免费高清视频观看www99| 亚洲国产精品成人一区二区| 亚洲国产精品一区二区久| 亚洲丁香婷深爱综合| 91精品视频观看| 国产精品久久久久久影视| 亚洲男人天堂古典| 欧美亚洲国产成人精品| 亚洲国产另类久久精品| 久久久影视精品| 91成人免费观看网站| 国产不卡av在线免费观看| 正在播放欧美一区| 亚洲一区二区三区乱码aⅴ蜜桃女| 久久视频国产精品免费视频在线| 欧美猛交ⅹxxx乱大交视频| 中文字幕亚洲欧美日韩在线不卡| 97精品欧美一区二区三区| 国产精品久久久久久久久借妻| 国产国产精品人在线视| 国产福利成人在线| 日韩电影中文字幕av| 亚洲在线第一页| 日韩美女av在线| 久久亚洲国产精品| 亚洲第一福利视频| 久久99视频精品| 久久久精品国产亚洲| 久久中国妇女中文字幕| 日韩av黄色在线观看| 亚洲美女久久久| 日韩免费精品视频| 91精品国产91久久久久福利| 中文字幕国内精品| 在线播放国产一区中文字幕剧情欧美| 精品亚洲国产视频| 国产亚洲精品日韩| 这里只有精品视频| 91嫩草在线视频| 热久久美女精品天天吊色| 在线观看日韩专区| 国产精品久久久久国产a级| 国产精品永久免费视频| 日韩有码在线电影| 日本久久亚洲电影| 欧美激情精品久久久久| 久久久国产在线视频| 久久精品最新地址| 亚洲欧美激情在线视频| 91国内精品久久| 亚洲美女又黄又爽在线观看| 69av视频在线播放| 亚洲精品色婷婷福利天堂| 国产在线视频不卡| 久久综合免费视频影院| 久久电影一区二区| 国产精品网址在线| 亚洲美女在线看| 国产精品一区久久久| 91在线高清视频| 亚洲第一中文字幕| 蜜臀久久99精品久久久无需会员| 久久久久九九九九| 国产精品人成电影| 欧美精品电影免费在线观看| 91九色精品视频| 欧美猛交ⅹxxx乱大交视频| 久久久久久噜噜噜久久久精品| 色哟哟入口国产精品| 色无极亚洲影院| 色播久久人人爽人人爽人人片视av| 91精品啪aⅴ在线观看国产| 国产精品久久久久久久7电影| 国产精品小说在线| 夜夜嗨av色一区二区不卡| 国产z一区二区三区| 精品久久久国产| 亚洲高清不卡av| 日韩av不卡在线| 国产精品网站大全|