基于指纹考勤机的真实的PHP操作Access数据库成功案例(最终实现) 2011-11-2v
2017-04-07 15:47
591 查看
听了我的建议,我们单位的食堂准备使用一台指纹考勤机统计吃饭人次,这样院里好给食堂的承包人以相应饭补。以前买过一台彩屏指纹机,数据库是access的,今儿又买了一台准备放到食堂里,而且考虑到停电,还特地配备了电池盒。
这台不是彩屏的,但更加灵敏,反应速度比原来买的那台快,而且快不少。看看参数把:
但有一样,使用U盘下载考勤数据时,是加密的.txt文档,用他们公司的软件才能把数据导入为Access表中。当然也可以自己弄.txt到.mdb的过程,但极为痛苦,极度难受,还很耗时。对于本周就上线运行的食堂管理系统而言,这是显然不合适的。
但是是可以实现的,这里是ocx,说下实现思路:
首先只能使用IE浏览器,通过调用ocx实现相关功能,就和一卡通里的IC卡模块一样。接着实例化一个类,使用GetGeneralLogData()方法获取记录,麻烦的就在这了,得到的结果不是想当然的数组或是比较容易处理的类型。这块很耗时。
可以看一下函数的原型:
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文件上传模块:
//数据库文件上传
public function uploadAction(){
//保存目录检测
$dirurl = MDBDIR;
$dir = $this->instance('file_list');
$dir->make_dir($dirurl);
$fileupload = $this->instance('file_upload');
$new_file = $dirurl.MDBFILE;
$result = $fileupload->upload($_FILES['upload'], $new_file);
if(!$result){
$this->assign('msg','文件上传失败!');
$this->saveAction();
}
if(!$this->inputDBAction()){
$this->assign('msg','文件导入数据库失败!');
}else{
$this->assign('msg',"文件已成功导入至数据库,请您在)."' >这里查询记录!");
}
$this->set_layout('usual');
$this->assign('load_js_name','canteen');
//display page
$this->display('save');
}
上传成功,就要自动填入Mysql中,这是PHP操作Access数据库的模块:
//access数据库信息导入
public function inputDBAction(){
if(file_exists(MDBDIR.MDBFILE)){
$access = $this->module('access');
//注意mdb是有密码,但没有用户名
$access->connect(MDBDIR.MDBFILE, '','2002', '', 0);
$execarr = array();
$result = $access->query("select * from ".mb_convert_encoding("考勤流水表", "GBK", "UTF-8")." where Used = No");
while($arr = $access->fetch_array($result))
{
$execarr[] = $arr;
}
//现在写入数据库
$att = $this->model('att_attendance');
$flag = TRUE;
foreach($execarr as $value){
$data = $att->createRow();
$data->userid = trim($value['UserID']);
$data->flowtime = strtr(trim($value['FlowTime']),'/','-');
$result = $att->save($data);
if($result < 0){$flag = FALSE;break;}
}
return $flag;
}
}
现在做查询分组统计:
public function queryAction(){
//权限验证
$checkauth = $this->module('Checkauth');
$checkauth->checkAuth(CANTEEN);
//设定日期
if(!isset($_POST['start']) && !isset($_POST['end'])){
//默认返回最近1周的记录
$now = getdate();
//********根据今天来确定本周的日期,开始************
if($now['wday']==0)$foo = -7;
else $foo = 1-$now['wday'];
$start = $now['year'].'-'.$now['mon'].'-'.($now['mday']+$foo);
if($now['wday']==0)$foo = 0;
else $foo = 7-$now['wday'];
$end = $now['year'].'-'.$now['mon'].'-'.($now['mday']+$foo);
//********根据今天来确定本周的日期,结束************
$result = $this->model('att_attendance');
//求出分组统计
$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");
//求得总数,使用Mysql嵌套查询
$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");
//在这里继续,显示出分组结果和总数结果,只是还没有把时间增加进去
}else{
//对提交上来的start和end作出新的查询
}
$this->set_layout('usual');
$this->assign('load_js_name','canteen');
exit();
//display page
$this->display();
}
有几个技术点需要记录下来,以备忘:
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文件上传给领导看呢。哈哈。领导,你要给我涨工资哦~~~
最后上传并且自动导入成功:
当然这里还用了一个access的PHP类,大家可以到我的这篇文章去看:
《PHP操作指纹机access数据库小记(初步设想)》
五岳之巅原创,转载请注明出处。谢谢。
这台不是彩屏的,但更加灵敏,反应速度比原来买的那台快,而且快不少。看看参数把:
但有一样,使用U盘下载考勤数据时,是加密的.txt文档,用他们公司的软件才能把数据导入为Access表中。当然也可以自己弄.txt到.mdb的过程,但极为痛苦,极度难受,还很耗时。对于本周就上线运行的食堂管理系统而言,这是显然不合适的。
但是是可以实现的,这里是ocx,说下实现思路:
首先只能使用IE浏览器,通过调用ocx实现相关功能,就和一卡通里的IC卡模块一样。接着实例化一个类,使用GetGeneralLogData()方法获取记录,麻烦的就在这了,得到的结果不是想当然的数组或是比较容易处理的类型。这块很耗时。
可以看一下函数的原型:
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文件上传模块:
//数据库文件上传
public function uploadAction(){
//保存目录检测
$dirurl = MDBDIR;
$dir = $this->instance('file_list');
$dir->make_dir($dirurl);
$fileupload = $this->instance('file_upload');
$new_file = $dirurl.MDBFILE;
$result = $fileupload->upload($_FILES['upload'], $new_file);
if(!$result){
$this->assign('msg','文件上传失败!');
$this->saveAction();
}
if(!$this->inputDBAction()){
$this->assign('msg','文件导入数据库失败!');
}else{
$this->assign('msg',"文件已成功导入至数据库,请您在)."' >这里查询记录!");
}
$this->set_layout('usual');
$this->assign('load_js_name','canteen');
//display page
$this->display('save');
}
上传成功,就要自动填入Mysql中,这是PHP操作Access数据库的模块:
//access数据库信息导入
public function inputDBAction(){
if(file_exists(MDBDIR.MDBFILE)){
$access = $this->module('access');
//注意mdb是有密码,但没有用户名
$access->connect(MDBDIR.MDBFILE, '','2002', '', 0);
$execarr = array();
$result = $access->query("select * from ".mb_convert_encoding("考勤流水表", "GBK", "UTF-8")." where Used = No");
while($arr = $access->fetch_array($result))
{
$execarr[] = $arr;
}
//现在写入数据库
$att = $this->model('att_attendance');
$flag = TRUE;
foreach($execarr as $value){
$data = $att->createRow();
$data->userid = trim($value['UserID']);
$data->flowtime = strtr(trim($value['FlowTime']),'/','-');
$result = $att->save($data);
if($result < 0){$flag = FALSE;break;}
}
return $flag;
}
}
现在做查询分组统计:
public function queryAction(){
//权限验证
$checkauth = $this->module('Checkauth');
$checkauth->checkAuth(CANTEEN);
//设定日期
if(!isset($_POST['start']) && !isset($_POST['end'])){
//默认返回最近1周的记录
$now = getdate();
//********根据今天来确定本周的日期,开始************
if($now['wday']==0)$foo = -7;
else $foo = 1-$now['wday'];
$start = $now['year'].'-'.$now['mon'].'-'.($now['mday']+$foo);
if($now['wday']==0)$foo = 0;
else $foo = 7-$now['wday'];
$end = $now['year'].'-'.$now['mon'].'-'.($now['mday']+$foo);
//********根据今天来确定本周的日期,结束************
$result = $this->model('att_attendance');
//求出分组统计
$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");
//求得总数,使用Mysql嵌套查询
$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");
//在这里继续,显示出分组结果和总数结果,只是还没有把时间增加进去
}else{
//对提交上来的start和end作出新的查询
}
$this->set_layout('usual');
$this->assign('load_js_name','canteen');
exit();
//display page
$this->display();
}
有几个技术点需要记录下来,以备忘:
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文件上传给领导看呢。哈哈。领导,你要给我涨工资哦~~~
最后上传并且自动导入成功:
当然这里还用了一个access的PHP类,大家可以到我的这篇文章去看:
《PHP操作指纹机access数据库小记(初步设想)》
五岳之巅原创,转载请注明出处。谢谢。
相关文章推荐
- 基于PHP文件操作实现页面统计
- PHP实现的同步推荐操作API接口案例分析
- PHP基于单例模式实现的数据库操作基类
- PHP数据库编程③基于mysql的在线词典案例(只实现中英文互查)
- 57-005-3 bootstrap实现一个简单的项目案例--新闻操作(基于jsp无刷新异步操作)
- PHP基于双向链表与排序操作实现的会员排名功能示例
- PHP基于PDO实现的SQLite操作类【包含增删改查及事务等操作】
- 基于php和mysql的简单的dao类实现crud操作功能
- PHP实现基于面向对象的mysqli扩展库增删改查操作工具类
- PHP基于迭代实现文件夹复制、删除、查看大小等操作的方法
- php基于数组函数实现关联表的编辑操作示例
- PHP实现对xml的增删改查操作案例分析
- PHP基于单例模式实现的数据库操作基类
- 基于php和mysql的简单的dao类实现crud操作功能
- 9-18 ASP第二讲实现数据的真实操作,从txt文件中读取进行校对,判断登陆是否成功
- PHP基于非递归算法实现先序、中序及后序遍历二叉树操作示例
- 基于PHP的AJAX技术实现文件异步上传
- 基于的Swing图形界面开发工具的实现案例(转自WilliamChen)
- PHP,操作多个用户,多个线程的session,实现用户登陆状态session值的自动更新