zoukankan      html  css  js  c++  java
  • PHP实现微信小程序人脸识别刷脸登录功能

    首先我们先确认我们的百度云人脸库里已经上传了我们的个人信息照片

    然后我们在后台写刷脸登陆的接口login我们要把拍照获取的照片存储到服务器

    public function login(){ 
       // 上传文件路径 
       $dir = "./Uploads/temp/"; 
       if(!file_exists($dir)){ 
        mkdir($dir,0777,true); 
       } 
       $upload = new \Think\Upload(); 
       $upload->maxSize = 2048000 ;// 设置附件上传大小 
       $upload->exts = array('jpg', 'gif', 'png', 'jpeg');// 设置附件上传类型 
       $upload->savepath = ''; 
       $upload->autoSub = false; 
       $upload->rootPath = $dir; // 设置附件上传根目录 
       // 上传单个文件 
       $info = $upload->uploadOne($_FILES['file']); 
       if(!$info) {// 上传错误提示错误信息 
         echo json_encode(array('error'=>true,'msg'=>$upload->getError()),JSON_UNESCAPED_UNICODE); 
       }else{// 上传成功 获取上传文件信息 
        $file = $dir . $info['savepath'].$info['savename']; 
        $image = base64_encode(file_get_contents($file)); 
        $client = $this->init_face(); 
        $options['liveness_control'] = 'NORMAL'; 
        $options['max_user_num'] = '1'; 
        $ret = $client->search($image,'BASE64','student',$options); 
        // echo json_encode($ret,JSON_UNESCAPED_UNICODE); 
        // exit; 
        if($ret['error_code']==0){ 
         $user = $ret['result']['user_list'][0]; 
         $no = $user['user_id']; 
         $score = $user['score']; 
         if($score>=95){ 
          $data = M('student')->where("no = '{$no}'")->find(); 
          $data['score'] = $score; 
          // $data['name'] = json_decode($data['name'],true); 
          // $data['sex'] = json_decode($data['sex'],true); 
          echo '识别成功' . json_encode($data,JSON_UNESCAPED_UNICODE); 
         }else{ 
          echo '识别失败' . $data['score']; 
         } 
        } 
       } 
      }

     

    然后进行前台设计

    <camera device-position="{{device?'back':'front'}}" flash="off" binderror="error" style=" 100%; height: 300px;"></camera> 
        <view class="weui-cells__title" >开关</view> 
        <view class="weui-cells weui-cells_after-title"> 
          <view class="weui-cell weui-cell_switch"> 
            <view class="weui-cell__bd">切换摄像头</view> 
            <view class="weui-cell__ft" > 
              <switch bindtap="devicePosition" /> 
            </view> 
          </view> 
        </view> 
    <button type="primary" bindtap="takePhoto">刷脸登录</button>

    我们还可以控制相机的前后镜头

    devicePosition() { 
    this.setData({ 
     device: !this.data.device, 
    }) 
    console.log("当前相机摄像头为:", this.data.device ? "后置" : "前置"); 
    camera() { 
     let { ctx, type, startRecord } = this.data; }, 
    data: { 
     src: null, 
    },

     

    在js里面调用接口

    takePhoto() { 
       const ctx = wx.createCameraContext() 
       ctx.takePhoto({ 
        quality: 'high', 
        success: (res) => { 
         this.setData({ 
          src: res.tempImagePath 
         }) 
         console.log(res) 
         wx.uploadFile({ 
          url: '', //仅为示例,非真实的接口地址 
          filePath: this.data.src, 
          name: 'file', 
          formData: { 
          }, 
          success: function (res) { 
           // var data = res.data 
           // var json = JSON.parse(data) 
           console.log(res) 
           wx.showModal({ 
            title: "提示", 
            content: res.data, 
            showCancel: false, 
            confirmText: "确定"
           }) 
          } 
         }) 
        } 
       }) 
      },

    刷脸登录就成功了

  • 相关阅读:
    程序员如何在百忙中更有效地利用时间,如何不走岔路,不白忙(忙得要有效率,要有收获)
    最坏的不是面试被拒,而是没面试机会,以面试官视角分析哪些简历至少能有面试机会
    最近面了不少java开发,据此来说下我的感受:哪怕事先只准备1小时,成功概率也能大大提升
    Ribbon整合Eureka组件,以实现负载均衡
    时间对于程序员的价值,以及如何高效地利用时间,同时划分下勤奋度的等级
    面试过程中,可以通过提问环节的发挥,提升面试的成功率
    以技术面试官的经验分享毕业生和初级程序员通过面试的技巧(Java后端方向)
    和小鲜肉相比,老程序员该由哪些优势?同时说下我看到的老程序员的三窟
    通过软引用和弱引用提升JVM内存使用性能的方法(面试时找机会说出,一定能提升成功率)
    Spring Clould负载均衡重要组件:Ribbon中重要类的用法
  • 原文地址:https://www.cnblogs.com/lxwphp/p/15454244.html
Copyright © 2011-2022 走看看