天天看點

基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作) 2011-11-2v

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

    這台不是彩屏的,但更加靈敏,反應速度比原來買的那台快,而且快不少。看看參數把:

基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作) 2011-11-2v
基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作) 2011-11-2v

    但有一樣,使用U盤下載下傳考勤資料時,是加密的.txt文檔,用他們公司的軟體才能把資料導入為Access表中。當然也可以自己弄.txt到.mdb的過程,但極為痛苦,極度難受,還很耗時。對于本周就上線運作的食堂管理系統而言,這是顯然不合适的。

    但是是可以實作的,這裡是ocx,說下實作思路:

    首先隻能使用IE浏覽器,通過調用ocx實作相關功能,就和一卡通裡的IC卡子產品一樣。接着執行個體化一個類,使用GetGeneralLogData()方法擷取記錄,麻煩的就在這了,得到的結果不是想當然的數組或是比較容易處理的類型。這塊很耗時。

    可以看一下函數的原型:

  1. long GetGeneralLogData(long *apnEnrollNumber, long *apnVerifyMode,long *apnInOutMode, DATA *apnDateTime)

    執行成功傳回1,失敗傳回對應的錯誤代碼。要先用LoadGeneralLogData或USBLoadDataFromFile指令,不然該指令會執行失敗。

 FKAttend.zip   

    不多說了,附件裡是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.         $fileupload = $this->instance(\'file_upload\');
  8.         $new_file = $dirurl.MDBFILE;
  9.         $result = $fileupload->upload($_FILES[\'upload\'], $new_file);
  10.         if(!$result){
  11.             $this->assign(\'msg\',\'檔案上傳失敗!\');
  12.             $this->saveAction();
  13.         }
  14.         if(!$this->inputDBAction()){
  15.             $this->assign(\'msg\',\'檔案導入資料庫失敗!\');
  16.         }else{
  17.             $this->assign(\'msg\',"檔案已成功導入至資料庫,請您在)."\' >這裡查詢記錄!");
  18.         }
  19.         $this->set_layout(\'usual\');
  20.         $this->assign(\'load_js_name\',\'canteen\');
  21.         //display page
  22.         $this->display(\'save\');
  23.     }

    上傳成功,就要自動填入Mysql中,這是PHP操作Access資料庫的子產品:

  1. //access資料庫資訊導入
  2.     public function inputDBAction(){
  3.         if(file_exists(MDBDIR.MDBFILE)){
  4.             $access = $this->module(\'access\');
  5.     //注意mdb是有密碼,但沒有使用者名
  6.             $access->connect(MDBDIR.MDBFILE, \'\',\'2002\', \'\', 0);
  7.             $execarr = array();
  8.             $result = $access->query("select * from ".mb_convert_encoding("考勤流水表", "GBK", "UTF-8")." where Used = No");
  9.             while($arr = $access->fetch_array($result))
  10.             {
  11.              $execarr[] = $arr;
  12.             }
  13.             //現在寫入資料庫
  14.              $att = $this->model(\'att_attendance\');
  15.              $flag = TRUE;
  16.              foreach($execarr as $value){
  17.                  $data = $att->createRow();
  18.                  $data->userid = trim($value[\'UserID\']);
  19.                  $data->flowtime = strtr(trim($value[\'FlowTime\']),\'/\',\'-\');
  20.                  $result = $att->save($data);
  21.                  if($result < 0){$flag = FALSE;break;}
  22.              }
  23.             return $flag;
  24.         }
  25.     }

    現在做查詢分組統計:

  1. public function queryAction(){
  2.         //權限驗證
  3.         $checkauth = $this->module(\'Checkauth\');
  4.         $checkauth->checkAuth(CANTEEN);
  5.         //設定日期
  6.         if(!isset($_POST[\'start\']) && !isset($_POST[\'end\'])){
  7.             //預設傳回最近1周的記錄
  8.             $now = getdate();
  9.             //********根據今天來确定本周的日期,開始************
  10.             if($now[\'wday\']==0)$foo = -7;
  11.             else $foo = 1-$now[\'wday\'];
  12.             $start = $now[\'year\'].\'-\'.$now[\'mon\'].\'-\'.($now[\'mday\']+$foo);
  13.             if($now[\'wday\']==0)$foo = 0;
  14.             else $foo = 7-$now[\'wday\'];
  15.             $end = $now[\'year\'].\'-\'.$now[\'mon\'].\'-\'.($now[\'mday\']+$foo);
  16.              //********根據今天來确定本周的日期,結束************
  17.             $result = $this->model(\'att_attendance\');
  18.             //求出分組統計
  19.             $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");

  20.             //求得總數,使用Mysql嵌套查詢
  21.             $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");

  22.             //在這裡繼續,顯示出分組結果和總數結果,隻是還沒有把時間增加進去
  23.         }else{
  24.             //對送出上來的start和end作出新的查詢
  25.         }
  26.         $this->set_layout(\'usual\');
  27.         $this->assign(\'load_js_name\',\'canteen\');
  28.         exit();
  29.         //display page
  30.         $this->display();
  31.     }

    有幾個技術點需要記錄下來,以備忘:

    1、不能直接使用PhpMyAdmin構造的SQL,在這個例子中會失敗,問題出要出在FlowTime身上;

    2、格式問題,為了安全起見,要使用strtr把2011/11/11,替換為2011-11-11,為的是保持資料庫通用日期時間格式;

    3、在DoitPHP這個架構裡使用insert()或save()儲存資料時,面對object,而非array類型,盡量不要使用$data[\'UserID\']的數組形式,會出現錯誤,而要采用$data->UserID;

    4、特别好玩的是,Access裡Boolean型的值有三種True/False,On/Off和Yes/No,我這裡mdb設定的就是Yes/No;

    5、注意mdb檔案是加密了的,當然也必須加密,否則食堂的人弄到mdb怎麼辦?當然mdb很容易就被破解了,不過上司看到的是我這個系統裡讀出的記錄,我不給他權限,他哪裡能把自己修改了的mdb檔案上傳給上司看呢。哈哈。上司,你要給我漲工資哦~~~

    最後上傳并且自動導入成功:

基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作) 2011-11-2v
基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作) 2011-11-2v
基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作) 2011-11-2v
基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作) 2011-11-2v

    當然這裡還用了一個access的PHP類,大家可以到我的這篇文章去看:

    《PHP操作指紋機access資料庫小記(初步設想)》

    五嶽之巅原創,轉載請注明出處。謝謝。

基于指紋考勤機的真實的PHP操作Access資料庫成功案例(最終實作) 2011-11-2v