自助柜机前端开发【身份证、人脸】

背景需求:自助查询柜机开发,访客来大厅验证时,使用身份证查询、人脸验证功能。在此记录一下各个环节所使用的方法。

身份证读卡器

  • 身份证读卡器硬件使用的是神思二代身份证验证机具 SS628(100)+100, 根据型号在官网上查找到对应的驱动程序和使用demo。
    官网下载地址
  • 拿到demo后,确认了身份证读取相关操作是由ActiveX控件完成的,前端只需要调用ActiveX控件提供的方法即可,而这也决定了我们的项目代码只能运行在IE上。(顺便吐槽一下:6年前遇到身份证读卡器时,是由ActiveX控件来实现,而在6年后IE已经不维护的今天,还在使用ActiveX来实现)
  • 接下来就是安装相关驱动程序及代码部分了。以下是身份证读卡器相关代码(基于Vue):
    template部分:
      <OBJECT
          ref="rdcard"
          classid="clsid:F1317711-6BDE-4658-ABAA-39E31D3704D3"
          codebase="SDRdCard.cab#version=2,0,1,0"
          width=0
          height=0
          align=center
          hspace=0
          vspace=0
          id=idcard
          name=rdcard
      >
      </OBJECT>

script部分:
其中this.readIDShensi()方法是身份证读卡器读取身份证信息成功后的回调方法

    init(){
      this.rdcard = document.getElementById("idcard")
      this.rdcard.openport()  // 打开机具
      const read = this.rdcard.ReadCard2()  //开始自动读卡
      if(read === 0){
        console.log('开始读卡成功')
      }else this.$message.error('读卡失败')
      document.getElementById('idcard').addEventListener("Readed", this.readIDShensi);
      document.getElementById('idcard').attachEvent("Readed", this.readIDShensi);
    },

人脸拍照

  • 在做人脸检测时走了一些弯路,在此也记录一下。首先是没搞清楚必须基于IE开发,导致我在使用navigator.mediaDevice调用摄像头+canvas截图实现人脸相关功能后才发现IE不兼容的问题。

  • 发现IE不兼容后,又走了一些弯路,试图在不修改代码的情况下,通过一些其他的办法来实现兼容IE:

    1. 360浏览器可以使用兼容模式
      360官网是这么写的:
      360兼容模式

      但这条路是走不通的,无论在项目中如何修改meta,这个meta在一开始index.html加载时就已被360读取并加载了,后期无论如何在项目中修改meta,也无法再修改360加载时的模式了。
      在【360浏览器选项-高级设置-内核设置-内核切换设置】中发现360的兼容模式设置,的确是精确到域名级别而无法精确到url级别
      360兼容模式配置
    2. 去谷歌应用商店下载IE tab插件
      IE tab插件可以精准配置到url级别对页面判断使用IE,还是使用chrome。在试用后完美解决了我的需求,在身份证页面使用IE内核,在摄像头页面使用chrome内核。只是有个问题,当我去Hide the IE Tab address bar时,发现此项功能需要付费,否则全屏时页面最上端会出现一个小横条。这样的用户体验对于柜机用户来说是无法接受的,所以我只好另寻办法。
      IE tab配置url判断规则
  • 最终只好使用IE了。在IE上调用摄像头并播放视频需要使用到flash player, webcamjs内部swf文件帮你实现这一部分了。
    Webcam实现在IE上的调用摄像头+拍照上传的功能,当然你也可以使用canvas截图来实现拍照功能,只是webcam已经提供拍照功能了,不必多此一举。 很简单,clone下来看看里面的调用demo就知道如何使用了。pixlcore官网也有详细的在线demo演示,和如何使用的介绍。以下是相关调用代码(基于Vue
    index.html引入(注意将webcam.swf也放到webcam.js所在目录下:):

<script src="webcam.js"></script>

template部分

      <div class="video-box">
        <div id="my_camera"></div>
        <canvas id="canvas"></canvas>
      </div>

script部分

    // 初始化Webcam配置
    init(){
      Webcam.set({
        width: 460,
        height: 542,
        image_format: 'jpeg',
        jpeg_quality: 90
      });
      Webcam.attach('#my_camera');
      ......
    },
    // 截图处理
    drawImage() {
      Webcam.snap(function (dataurl) {
        ...截图返回base64字符串处理逻辑
      });
    },
  • 另一插曲:人脸检测是由后端封装阿里云人脸检测接口实现,但由于该接口收费。产品让我找找使用前端的库来实现人脸检测,减少接口调用次数从而减少项目成本。使用trakingjs可以解决这个问题,官网:trackingjs 源码: 当我在chrome调试完成后,发现它不兼容IE。

其他

项目中还用到了指纹、打印热敏小票功能:

  • 管供应商要到指纹仪型号zkteco Live10r后,发现它只有c++ 和 java文档,所以指纹相关调用部分就只有与后端的逻辑交互了。
  • 打印功能能使用Clodop插件,Clodop自定义样式打印,且提供了丰富的调用接口。关于Clodop打印,网上有很多的相关使用资料,在此不再赘述。

虽然在这个项目中走了一些弯路,但是有时候,恰好是那些弯路,让自己获取到了更多的知识,扩宽了自己解决问题的思路。即便是在解决问题的过程中经历了挣扎、怀疑、烦躁的不良情绪,但解决完问题如释重负的那刻,我相信这也是每位开发者最喜欢的时刻。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,907评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,987评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,298评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,586评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,633评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,488评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,275评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,176评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,619评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,819评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,932评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,655评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,265评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,871评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,994评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,095评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,884评论 2 354

推荐阅读更多精彩内容