基於指紋考勤機的真實的PHP操作Access數據庫成功案例(最終實現) 2011-11-2v


聽了我的建議,我們單位的食堂准備使用一台指紋考勤機統計吃飯人次,這樣院里好給食堂的承包人以相應飯補。以前買過一台彩屏指紋機,數據庫是access的,今兒又買了一台准備放到食堂里,而且考慮到停電,還特地配備了電池盒。

 
    這台不是彩屏的,但更加靈敏,反應速度比原來買的那台快,而且快不少。看看參數把:
 
 
 
 
    但有一樣,使用U盤下載考勤數據時,是加密的.txt文檔,用他們公司的軟件才能把數據導入為Access表中。當然也可以自己弄.txt到.mdb的過程,但極為痛苦,極度難受,還很耗時。對於本周就上線運行的食堂管理系統而言,這是顯然不合適的。
    但是是可以實現的,這里是ocx,說下實現思路:
    首先只能使用IE瀏覽器,通過調用ocx實現相關功能,就和一卡通里的IC卡模塊一樣。接着實例化一個類,使用GetGeneralLogData()方法獲取記錄,麻煩的就在這了,得到的結果不是想當然的數組或是比較容易處理的類型。這塊很耗時。
    可以看一下函數的原型:
  1. long GetGeneralLogData(long *apnEnrollNumber, long *apnVerifyMode,long *apnInOutMode, DATA *apnDateTime)
 
    執行成功返回1,失敗返回對應的錯誤代碼。要先用LoadGeneralLogData或USBLoadDataFromFile指令,不然該指令會執行失敗。
    不多說了,附件里是ocx,呵呵,有興趣的自己研究去吧。這個思路都是浮雲,在規定的時間里完不成的。涉及到調試ocx插件等等潛在問題,而且不是一個OCX或DLL的FKAttend就能搞定。我的方案是,使用他們給的工具導成mdb文檔,再導入到我這個一卡通的大數據庫里,這樣所有記錄都能得到妥善保存。而且領導也能一個頁面,足不出戶,查看到食堂消費情況。
 
    所以要通過PHP,讀取mdb並寫入mysql。
    這次用的不是ThinkPHP,而是叫做DoitPHP的框架,也是頭一次使用,還以為比TP好用,看官網說數據處理特別快,但是不太容易掌握,總體還是略顯青澀。
    這是MDB文件上傳模塊:
  1. //數據庫文件上傳
  2.     public function uploadAction(){
  3.         //保存目錄檢測
  4.         $dirurl = MDBDIR;
  5.         $dir = $this->instance('file_list');
  6.         $dir->make_dir($dirurl);
  7.         
  8.         
  9.         $fileupload = $this->instance('file_upload');
  10.         
  11.         $new_file = $dirurl.MDBFILE;
  12.         
  13.         $result = $fileupload->upload($_FILES['upload'], $new_file);
  14.         if(!$result){
  15.             $this->assign('msg','文件上傳失敗!');
  16.             $this->saveAction();
  17.         }
  18.         
  19.         if(!$this->inputDBAction()){
  20.             $this->assign('msg','文件導入數據庫失敗!');
  21.         }else{
  22.             $this->assign('msg',"文件已成功導入至數據庫,請您在)."' >這里查詢記錄!");
  23.         }
  24.         
  25.         $this->set_layout('usual');
  26.         $this->assign('load_js_name','canteen');
  27.         
  28.         //display page
  29.         $this->display('save');
  30.     }
 
  1. //access數據庫信息導入
  2.     public function inputDBAction(){
  3.         if(file_exists(MDBDIR.MDBFILE)){
  4.                     
  5.             $access = $this->module('access');
  6.     //注意mdb是有密碼,但沒有用戶名
  7.             $access->connect(MDBDIR.MDBFILE, '','2002', '', 0);
  8.             
  9.             $execarr = array();
  10.             $result = $access->query("select * from ".mb_convert_encoding("考勤流水表", "GBK", "UTF-8")." where Used = No");
  11.             while($arr = $access->fetch_array($result))
  12.             {
  13.              $execarr[] = $arr;
  14.             }
  15.             
  16.             //現在寫入數據庫
  17.              $att = $this->model('att_attendance');
  18.              $flag = TRUE;
  19.              foreach($execarr as $value){
  20.                  $data = $att->createRow();
  21.                  $data->userid = trim($value['UserID']);
  22.                  $data->flowtime = strtr(trim($value['FlowTime']),'/','-');
  23.                 
  24.                  $result = $att->save($data);
  25.                  if($result < 0){$flag = FALSE;break;}
  26.              }
  27.             
  28.             return $flag;
  29.         }
  30.     }
  1. public function queryAction(){
  2.         //權限驗證
  3.         $checkauth = $this->module('Checkauth');
  4.         $checkauth->checkAuth(CANTEEN);
  5.         
  6.         //設定日期
  7.         if(!isset($_POST['start']) && !isset($_POST['end'])){
  8.             //默認返回最近1周的記錄
  9.             $now = getdate();
  10.             //********根據今天來確定本周的日期,開始************
  11.             if($now['wday']==0)$foo = -7;
  12.             else $foo = 1-$now['wday'];
  13.             $start = $now['year'].'-'.$now['mon'].'-'.($now['mday']+$foo);
  14.             
  15.             if($now['wday']==0)$foo = 0;
  16.             else $foo = 7-$now['wday'];
  17.             $end = $now['year'].'-'.$now['mon'].'-'.($now['mday']+$foo);
  18.              //********根據今天來確定本周的日期,結束************
  19.             $result = $this->model('att_attendance');
  20.             //求出分組統計
  21.             $att = $result->execute("select att_attendance.userid,att_member.name,count(att_attendance.userid) as total from att_attendance,att_member WHERE att_attendance.userid = att_member.userid GROUP BY userid");
  22.             
  23.             //求得總數,使用Mysql嵌套查詢
  24.             $sum = $result->execute("select sum(total) from (select att_attendance.userid,att_member.name,count(att_attendance.userid) as total from att_attendance,att_member WHERE att_attendance.userid = att_member.userid GROUP BY userid) as sum");
  25.             //在這里繼續,顯示出分組結果和總數結果,只是還沒有把時間增加進去
  26.         }else{
  27.             //對提交上來的start和end作出新的查詢
  28.         }
  29.         
  30.         $this->set_layout('usual');
  31.         $this->assign('load_js_name','canteen');
  32.         exit();
  33.         //display page
  34.         $this->display();
  35.     }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
    當然這里還用了一個access的PHP類,大家可以到我的這篇文章去看:
 
    五岳之巔原創,轉載請注明出處。謝謝。
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM