LoginFrm.pas 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354
  1. {*******************************************************************************
  2. 单元名称: ScLoginFrm.pas
  3. 单元说明: 网络版PHP Web页面登录方式。
  4. 作者时间: Chenshilong, 2012-5-13
  5. *******************************************************************************}
  6. unit LoginFrm;
  7. interface
  8. uses
  9. Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  10. Dialogs, JimCombos, ExtCtrls, StdCtrls, cxLookAndFeelPainters,
  11. cxTextEdit, cxButtons, cxControls, cxEdit,
  12. cxMaskEdit, cxDropDownEdit, HookEdit, cxContainer, XPMenu, cslLabel,
  13. IdBaseComponent, IdComponent, IdTCPConnection, IdTCPClient, IdHTTP,
  14. CslButton, OleCtrls, SHDocVw, DB, ADODB, Menus;
  15. type
  16. TLoginFrm = class(TForm)
  17. edtPW: TEdit;
  18. lblForgetPW: TcslLabel;
  19. lblVer: TLabel;
  20. shpAccount: TShape;
  21. imgBG: TImage;
  22. btnLogin: TCslButton;
  23. lblReg: TCslLabel;
  24. btnClose: TCslButton;
  25. lblProductName: TLabel;
  26. shpPW: TShape;
  27. wbLogin: TWebBrowser;
  28. pnlLocalServer: TPanel;
  29. btnLocalLogin: TCslButton;
  30. lblLocalHelp: TCslLabel;
  31. lblLocalServer: TCslLabel;
  32. cbUser: TcxComboBox;
  33. pmLogin: TPopupMenu;
  34. nClearAccount: TMenuItem;
  35. lblHint: TLabel;
  36. procedure edtPWKeyDown(Sender: TObject; var Key: Word;
  37. Shift: TShiftState);
  38. procedure FormCreate(Sender: TObject);
  39. procedure btnLoginClick(Sender: TObject);
  40. procedure img1Click(Sender: TObject);
  41. procedure shpAccountMouseDown(Sender: TObject; Button: TMouseButton;
  42. Shift: TShiftState; X, Y: Integer);
  43. procedure shpPWMouseDown(Sender: TObject; Button: TMouseButton;
  44. Shift: TShiftState; X, Y: Integer);
  45. procedure btnCloseClick(Sender: TObject);
  46. procedure FormDestroy(Sender: TObject);
  47. procedure cbUserKeyDown(Sender: TObject; var Key: Word;
  48. Shift: TShiftState);
  49. procedure nClearAccountClick(Sender: TObject);
  50. private
  51. { Private declarations }
  52. FUsersCon: TADOConnection;
  53. FUsersQry: TADOQuery;
  54. procedure ReadCloudUser;
  55. procedure WriteCloudUser;
  56. public
  57. { Public declarations }
  58. end;
  59. function LoginForm: Boolean;
  60. implementation
  61. uses
  62. ScUtils, ShellAPI, IniFiles, ScConfig, Md5, PHPWebDm, ConstUnit;
  63. {$R *.dfm}
  64. function LoginForm: Boolean;
  65. var
  66. Form: TLoginFrm;
  67. begin
  68. Result := False;
  69. Form := TLoginFrm.Create(nil);
  70. try
  71. if Form.ShowModal = mrOK then
  72. begin
  73. Result := True;
  74. Form.WriteCloudUser;
  75. end;
  76. finally
  77. Form.Free;
  78. end;
  79. end;
  80. { TLoginFrm }
  81. procedure TLoginFrm.edtPWKeyDown(Sender: TObject; var Key: Word;
  82. Shift: TShiftState);
  83. begin
  84. if Key = VK_Return then
  85. btnLoginClick(Sender);
  86. end;
  87. procedure TLoginFrm.FormCreate(Sender: TObject);
  88. var SL: TStringList;
  89. ini: TIniFile;
  90. begin
  91. lblHint.Caption := '';
  92. SetClassLong(Handle, GCL_STYLE, GetClassLong(Handle, GCL_STYLE) or CS_DROPSHADOW);
  93. Set8087CW(Default8087CW or $0004);
  94. Set8087CW(Longword($133f));
  95. ini := TIniFile.Create(ExtractFilePath(Application.ExeName) + 'Cloud.ini');
  96. try
  97. G_Server := ini.ReadString('URL', 'Server', '');
  98. G_ServerType := ini.ReadString('URL', 'ServerType', '');
  99. G_CompanyName := ini.ReadString('URL', 'CompanyName', '');
  100. G_GuideURL := ini.ReadString('URL', 'GuideURL', '');
  101. G_MeasureURL := 'http://' + G_Server + ini.ReadString('URL', 'MeasureURL', '');
  102. finally
  103. ini.Free;
  104. end;
  105. if Trim(G_CompanyName) <> '' then
  106. lblProductName.Caption := G_CompanyName
  107. else
  108. lblProductName.Caption := G_ProductName;
  109. // 服务器:1公有 2私有
  110. if G_ServerType = '2' then
  111. begin
  112. pnlLocalServer.Visible := True;
  113. lblLocalServer.URL := G_Server;
  114. lblLocalServer.Hint := G_Server;
  115. lblLocalHelp.URL := G_GuideURL;
  116. lblLocalHelp.Hint := G_GuideURL;
  117. end
  118. else if G_ServerType = '1' then
  119. begin
  120. pnlLocalServer.Visible := False;
  121. end;
  122. lblReg.URL := PHPWeb.RegURL;
  123. lblForgetPW.URL := PHPWeb.PwdURL;
  124. lblVer.Caption := G_ProductName + ' ' + ScGetVersion;
  125. // lblVer.Left := lblProductName.Left + lblProductName.Width + 7;
  126. ReadCloudUser;
  127. SL := TStringList.Create;
  128. try
  129. SL.Clear;
  130. SL.Add('about: <body><font size=4 color=Green>') ;
  131. SL.Add('正在打开网页请稍候...');
  132. SL.Add('</font></body>');
  133. wbLogin.Navigate(SL.Text);
  134. wbLogin.Navigate(PHPWeb.LoginBannerURL);
  135. finally
  136. end;
  137. if G_IsTest then
  138. begin
  139. cbUser.Text := '1971614655@qq.com';
  140. edtPW.Text := '357134933..';
  141. end;
  142. end;
  143. procedure TLoginFrm.btnLoginClick(Sender: TObject);
  144. var sInfo, sURL, sCheckCode, sMD5PW: string;
  145. begin
  146. lblHint.Caption := '';
  147. lblHint.Update;
  148. if Trim(cbUser.Text) = '' then
  149. begin
  150. lblHint.Caption := '请您输入账号后再登录';
  151. lblHint.Update;
  152. cbUser.SetFocus;
  153. Exit;
  154. end;
  155. if Trim(edtPW.Text) = '' then
  156. begin
  157. lblHint.Caption := '请您输入密码后再登录';
  158. lblHint.Update;
  159. edtPW.SetFocus;
  160. Exit;
  161. end;
  162. case PHPWeb.Login(cbUser.Text, edtPW.Text, 1, sInfo, sCheckCode) of
  163. ltCon:
  164. begin
  165. if Trim(sInfo) <> '' then
  166. Application.MessageBox(PChar(sInfo), '新版本提示', MB_OK + MB_ICONINFORMATION);
  167. ModalResult := mrOk;
  168. end;
  169. ltLoginFail:
  170. begin
  171. lblHint.Caption := sInfo;
  172. lblHint.Update;
  173. edtPW.SetFocus;
  174. edtPW.SelectAll;
  175. ModalResult := mrNone;
  176. end;
  177. ltUpdate:
  178. begin
  179. // 无法对PHP返回的字符串进行排版。这里使用Delphi自身的字符串。
  180. sInfo := '尊敬的用户:' + #13#13 +
  181. '系统检测出您是通过SmartCost旧版本程序注册了本帐户(' + Trim(cbUser.Text) +
  182. '),因系统升级,为保障您的帐户安全和更好的为您服务,' + #13#13 +
  183. '我们需要对您的邮箱进行有效性验证,并需要您重置该帐户的密码以保证您的帐号在新程序上能够正常使用。' + #13#13 +
  184. '请点击“确定”按钮打开密码重置页面。';
  185. Application.MessageBox(PChar(sInfo), '升级提示', MB_OK + MB_ICONINFORMATION);
  186. edtPW.SetFocus;
  187. edtPW.SelectAll;
  188. ModalResult := mrNone;
  189. Screen.Cursor := crHourGlass;
  190. try
  191. sURL := ConfigInfo.OldUserResetPwdURL + '?CheckCode=' + sCheckCode;
  192. ShellExecute(Application.Handle, 'open', PChar(sURL), nil, nil, SW_SHOWNORMAL);
  193. finally
  194. Screen.Cursor := crDefault;
  195. end;
  196. end;
  197. ltIncomplete:
  198. begin
  199. Application.MessageBox(PChar(sInfo), '系统提示', MB_OK + MB_ICONINFORMATION);
  200. ModalResult := mrNone;
  201. Screen.Cursor := crHourGlass;
  202. try
  203. sMD5PW := GetMD5(edtPW.Text);
  204. sURL := Format('%s?Account=%s&Pwd=%s', [ConfigInfo.WebLoginURL,
  205. cbUser.Text, sMD5PW]);
  206. ShellExecute(Application.Handle, 'open', PChar(sURL), nil, nil, SW_SHOWNORMAL);
  207. finally
  208. Screen.Cursor := crDefault;
  209. end;
  210. end;
  211. ltDisCon:
  212. begin
  213. Application.MessageBox('网络错误,请稍后重试!', '操作提醒', MB_OK + MB_ICONWARNING);
  214. ModalResult := mrNone;
  215. end;
  216. end;
  217. end;
  218. procedure TLoginFrm.img1Click(Sender: TObject);
  219. begin
  220. Close;
  221. end;
  222. procedure TLoginFrm.shpAccountMouseDown(Sender: TObject; Button: TMouseButton;
  223. Shift: TShiftState; X, Y: Integer);
  224. begin
  225. cbUser.SetFocus;
  226. end;
  227. procedure TLoginFrm.shpPWMouseDown(Sender: TObject; Button: TMouseButton;
  228. Shift: TShiftState; X, Y: Integer);
  229. begin
  230. edtPW.SetFocus;
  231. end;
  232. procedure TLoginFrm.btnCloseClick(Sender: TObject);
  233. begin
  234. Close;
  235. end;
  236. procedure TLoginFrm.FormDestroy(Sender: TObject);
  237. begin
  238. FUsersCon.Close;
  239. FUsersCon.Free;
  240. FUsersQry.Free;
  241. end;
  242. procedure TLoginFrm.ReadCloudUser;
  243. var s: string;
  244. begin
  245. FUsersCon := TADOConnection.Create(nil);
  246. FUsersCon.LoginPrompt := False;
  247. s := 'Provider=Microsoft.Jet.OLEDB.4.0;Data Source=CloudUser.dat;Persist Security Info=False';
  248. FUsersCon.ConnectionString := s;
  249. FUsersQry := TADOQuery.Create(nil);
  250. FUsersQry.Connection := FUsersCon;
  251. FUsersQry.SQL.Text := 'Select Top 15 * From Users Order by LoginTimes Desc';
  252. FUsersQry.Open;
  253. cbUser.Properties.Items.Clear;
  254. if FUsersQry.RecordCount > 0 then
  255. begin
  256. FUsersQry.First;
  257. while not FUsersQry.Eof do
  258. begin
  259. cbUser.Properties.Items.Add(FUsersQry.FieldByName('Account').AsString);
  260. FUsersQry.Next;
  261. end;
  262. end;
  263. FUsersQry.Close;
  264. end;
  265. procedure TLoginFrm.WriteCloudUser;
  266. begin
  267. FUsersQry.Close;
  268. FUsersQry.SQL.Text := Format('Select * From Users where UserID = %d', [PHPWeb.UserID]);
  269. FUsersQry.Open;
  270. if FUsersQry.RecordCount > 0 then
  271. begin
  272. FUsersQry.Close;
  273. FUsersQry.SQL.Text := Format('Update Users Set LoginTimes=LoginTimes+1 where UserID = %d', [PHPWeb.UserID]);
  274. FUsersQry.ExecSQL;
  275. end
  276. else
  277. begin
  278. FUsersQry.Close;
  279. FUsersQry.SQL.Text := Format('Insert into Users(UserID,Account,RealName,LoginTimes) Values(%d,''%s'',''%s'',1)',
  280. [PHPWeb.UserID, PHPWeb.Account, PHPWeb.RealName]);
  281. FUsersQry.ExecSQL;
  282. end;
  283. FUsersQry.Close;
  284. end;
  285. procedure TLoginFrm.cbUserKeyDown(Sender: TObject; var Key: Word;
  286. Shift: TShiftState);
  287. begin
  288. if Key = VK_Return then
  289. begin
  290. edtPW.SetFocus;
  291. edtPW.SelectAll;
  292. end;
  293. end;
  294. procedure TLoginFrm.nClearAccountClick(Sender: TObject);
  295. begin
  296. if Application.MessageBox('确定要清空所有记录的帐户信息吗?', '询问', MB_YESNO + MB_ICONQUESTION) = ID_No then
  297. Exit;
  298. FUsersQry.Close;
  299. FUsersQry.SQL.Text := 'Delete * From Users';
  300. FUsersQry.ExecSQL;
  301. FUsersQry.Close;
  302. cbUser.Properties.Items.Clear;
  303. end;
  304. end.