草庐IT

云原生身份证在线识别小项目(阿里云Serverless+Python)

星期五是周几 2023-04-11 原文

前言

什么是Serverless

Serverless由两部分组成,Server和Less。

前者可以理解为其解决方案范围处在服务端;后者可以译为少量的;组合起来就是较少服务端干预的服务端解决方案。

Serverless 俗称为“无服务器架构”,Serverless 不是具体的一个编程框架、类库或者工具。简单来说,Serverless 是一种软件系统架构思想和方法,它的核心思想是用户无须关注支撑应用服务运行的底层主机。这种架构的思想和方法将对未来软件应用的设计、开发和运营产生深远的影响。

所谓“无服务器”,并不是说基于 Serverless 架构的软件应用不需要服务器就可以运行,其指的是用户无须关心软件应用运行涉及的底层服务器的状态、资源(比如 CPU、内存、磁盘及网络)及数量。软件应用正常运行所需要的计算资源由底层的云计算平台动态提供。

serverless详细介绍

什么是FC

FC(函数计算):阿里云函数计算是事件驱动的全托管计算服务。通过函数计算,用户无需管理服务器等基础设施,只需编写代码并上传。函数计算会为您准备好计算资源,以弹性、可靠的方式运行您的代码,并提供日志查询、性能监控、报警等功能。

FC工作流程

  • 开发者使用编程语言编写应用和服务。函数计算支持的开发语言,请参见开发语言列表。

  • 开发者上传应用到函数计算。
    上传途径包括:

    • 通过函数计算控制台上传。
    • 通过Serverless Devs上传。
    • 通过API或SDK上传。
  • 触发函数执行。触发方式包括事件触发以及函数计算API、SDK等。

  • 动态扩缩容以响应请求。函数计算可以根据用户请求量自动扩缩容,该过程对您和您的用户均透明无感知。

  • 根据函数的实际执行时间按量计费。

1. 首先开通阿里云身份证识别服务 和 阿里云函数计算服务(FC)

  • 文字识别服务

  • 函数计算

在菜单栏搜索FC

2.创建服务

3.创建函数

选择使用模板创建 flask-web

弹性实例等设置可在配置之后修改

函数创建成功,进入在线IDE

在这里我们就可以编写自己想要的函数服务了

4.身份证识别服务代码添加

  • 首先添加依赖包

【身份证识别附件】附件.zip

将这三个文件上传至项目根目录

* 在项目根目录新建 recognizeIdentityCard.py 文件 * 在recognizeIdentityCard.py中写入如下代码:
#!/usr/bin/env python
# coding=utf-8
import json
from aliyunsdkcore.client import AcsClient
from aliyunsdkocr.request.v20191230.RecognizeIdentityCardRequest import RecognizeIdentityCardRequest


ak = 'LTA***************ixV'  #  AccessKey ID
secret = '4r*********************cK' # AccessKey Secret
region_id = 'cn-shanghai'


# url转换
def generate_url(or_url):
 
    from viapi.fileutils import FileUtils
    file_utils = FileUtils(ak, secret)
    oss_url = file_utils.get_oss_url(or_url, "jpg", False)
    print(oss_url)
    return oss_url


# 识别身份证正面信息
def face_recognizeIdentityCard(face_url):
    face_url = generate_url(face_url)

    client = AcsClient(ak=ak, secret=secret, region_id=region_id)
    request = RecognizeIdentityCardRequest()
    request.set_accept_format('json')
    # 识别正面
    request.set_Side("face")
    request.set_ImageURL(face_url)
    request = client.do_action_with_exception(request)
    re = str(request, encoding='utf-8')
    # print(re)

    re_dict = eval(re)
    info = re_dict['Data']['FrontResult']
    info_dict = {}
    info_dict['IDNumber'] = info['IDNumber']
    info_dict['Name'] = info['Name']
    info_dict['Gender'] = info['Gender']
    info_dict['Nationality'] = info['Nationality']
    info_dict['BirthDate'] = info['BirthDate']
    info_dict['Address'] = info['Address']
    # print(info_dict)
    return info_dict


def back_recognizeIdentityCard(back_url):
    back_url = generate_url(back_url)

    client = AcsClient(ak=ak, secret=secret, region_id=region_id)
    request = RecognizeIdentityCardRequest()
    # 识别背面
    request = RecognizeIdentityCardRequest()
    request.set_Side("back")
    request.set_ImageURL(back_url)
    request = client.do_action_with_exception(request)
    re = str(request, encoding='utf-8')
    # print(re)

    re_dict = eval(re)
    info = re_dict['Data']['BackResult']
    info_dict = {}
    info_dict['StartDate'] = info['StartDate']
    info_dict['EndDate'] = info['EndDate']
    info_dict['Issue'] = info['Issue']
    # print(info_dict)
    return info_dict


def get_IdentityCardInfo(face_url, back_url):
    re_dict = {
        'FrontResult': face_recognizeIdentityCard(face_url),
        'BackResult': back_recognizeIdentityCard(back_url)
    }
    print(re_dict)
    return json.dumps(re_dict)


  • 更改 ak 和 secret
ak = 'LTA***************ixV' #你自己的 AccessKey ID
secret = '4r*********************cK'# 你自己的 AccessKey Secret
  • AccessKey ID 和 AccessKey Secret 获取方法如下
  • 注意:为方便使用,建议下载并保存Secret

  • 在main.py 中注册身份证识别接口路由:

@app.route('/idcard', methods=['GET'])
def idcard():
    from recognizeIdentityCard import get_IdentityCardInfo
    face_url=request.args.get('FaceUrl')
    back_url=request.args.get('BackUrl')
    
    re=get_IdentityCardInfo(face_url,back_url)
  
    resp = make_response(re, 200)
    return resp

5.点击部署


6.获取身份证识别服务接口url

  • 点击调用
  • 拿到请求地址后拼接上我们自己定义的路由’idcard’得到最终的url:

列如 请求地址为:
https://18xxxxxxxxxx89.cn-hangzhou.fc.aliyuncs.com/2016-08-15/proxy/id_identify.LATEST/id_identify/

则最终的url为:
https://18xxxxxxxxxx89.cn-hangzhou.fc.aliyuncs.com/2016-08-15/proxy/id_identify.LATEST/id_identify/idcard


7.使用接口测试工具进行测试

在APIPost中填入最终url
选用get方法
参数位置 Query

至此你已经成功搭建你的第一个云原生应用

(注意:阿里云身份证识别服务按流量计费,每次调用成本约为0.08元)

参考文章:https://blog.csdn.net/qq_45385867/article/details/115272821

有关云原生身份证在线识别小项目(阿里云Serverless+Python)的更多相关文章

  1. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  2. ruby - 具有身份验证的私有(private) Ruby Gem 服务器 - 2

    我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..

  3. Python 相当于 Perl/Ruby ||= - 2

    这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Pythonconditionalassignmentoperator对于这样一个简单的问题表示歉意,但是谷歌搜索||=并不是很有帮助;)Python中是否有与Ruby和Perl中的||=语句等效的语句?例如:foo="hey"foo||="what"#assignfooifit'sundefined#fooisstill"hey"bar||="yeah"#baris"yeah"另外,类似这样的东西的通用术语是什么?条件分配是我的第一个猜测,但Wikipediapage跟我想的不太一样。

  4. java - 什么相当于 ruby​​ 的 rack 或 python 的 Java wsgi? - 2

    什么是ruby​​的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht

  5. 报告回顾丨模型进化狂飙,DetectGPT能否识别最新模型生成结果? - 2

    导读语言模型给我们的生产生活带来了极大便利,但同时不少人也利用他们从事作弊工作。如何规避这些难辨真伪的文字所产生的负面影响也成为一大难题。在3月9日智源Live第33期活动「DetectGPT:判断文本是否为机器生成的工具」中,主讲人Eric为我们讲解了DetectGPT工作背后的思路——一种基于概率曲率检测的用于检测模型生成文本的工具,它可以帮助我们更好地分辨文章的来源和可信度,对保护信息真实、防止欺诈等方面具有重要意义。本次报告主要围绕其功能,实现和效果等展开。(文末点击“阅读原文”,查看活动回放。)Ericmitchell斯坦福大学计算机系四年级博士生,由ChelseaFinn和Chri

  6. 华为OD机试用Python实现 -【明明的随机数】 2023Q1A - 2

    华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o

  7. [Vuforia]二.3D物体识别 - 2

    之前说过10之后的版本没有3dScan了,所以还是9.8的版本或者之前更早的版本。 3d物体扫描需要先下载扫描的APK进行扫面。首先要在手机上装一个扫描程序,扫描现实中的三维物体,然后上传高通官网,在下载成UnityPackage类型让Unity能够使用这个扫描程序可以从高通官网上进行下载,是一个安卓程序。点到Tools往下滑,找到VuforiaObjectScanner下载后解压数据线连接手机,将apk文件拷入手机安装然后刚才解压文件中的Media文件夹打开,两个PDF图打印第一张A4-ObjectScanningTarget.pdf,主要是用来辅助扫描的。好了,接下来就是扫描三维物体。将瓶

  8. python - 如何读取 MIDI 文件、更改其乐器并将其写回? - 2

    我想解析一个已经存在的.mid文件,改变它的乐器,例如从“acousticgrandpiano”到“violin”,然后将它保存回去或作为另一个.mid文件。根据我在文档中看到的内容,该乐器通过program_change或patch_change指令进行了更改,但我找不到任何在已经存在的MIDI文件中执行此操作的库.他们似乎都只支持从头开始创建的MIDI文件。 最佳答案 MIDIpackage会为您完成此操作,但具体方法取决于midi文件的原始内容。一个MIDI文件由一个或多个音轨组成,每个音轨是十六个channel中任何一个上的

  9. 「Python|Selenium|场景案例」如何定位iframe中的元素? - 2

    本文主要介绍在使用Selenium进行自动化测试或者任务时,对于使用了iframe的页面,如何定位iframe中的元素文章目录场景描述解决方案具体代码场景描述当我们在使用Selenium进行自动化测试的时候,可能会遇到一些界面或者窗体是使用HTML的iframe标签进行承载的。对于iframe中的标签,如果直接查找是无法找到的,会抛出没有找到元素的异常。比如近在咫尺的例子就是,CSDN的登录窗体就是使用的iframe,大家可以尝试通过F12开发者模式查看到的tag_name,class_name,id或者xpath来定位中的页面元素,会抛出NoSuchElementException异常。解决

  10. ruby-on-rails - 在 heroku 的 .fonts 文件夹中包含自定义字体,似乎无法识别它们 - 2

    Heroku支持人员告诉我,为了在我的Web应用程序中使用自定义字体(未安装在系统中,您可以在bash控制台中使用fc-list查看已安装的字体)我必须部署一个包含所有字体的.fonts文件夹里面的字体。问题是我不知道该怎么做。我的意思是,我不知道文件名是否必须遵循heroku的任何特殊模式,或者我必须在我的代码中做一些事情来考虑这种字体,或者如果我将它包含在文件夹中它是自动的......事实是,我尝试以不同的方式更改字体的文件名,但根本没有使用该字体。为了提供更多详细信息,我们使用字体的过程是将PDF转换为图像,更具体地说,使用rghostgem。并且最终图像根本不使用自定义字体。在

随机推荐