听了我的建议,我们单位的食堂准备使用一台指纹考勤机统计吃饭人次,这样院里好给食堂的承包人以相应饭补。以前买过一台彩屏指纹机,数据库是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类,大家可以到我的这篇文章去看:
 
    五岳之巅原创,转载请注明出处。谢谢。
 

版权声明:本文为caicaizi原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/caicaizi/p/6678459.html