initialize

概览

  • API URL:/api/v1/zoloz/realid/initialize
  • API 描述:该接口用于初始化ZOLOZ中的身份验证进程,并为其生成一个唯一的事务ID。后续在与ZOLOZ交互的所有过程中均使用该事务ID。

说明:该接口不支持重复调用,即不符合幂等性。

请求参数

字段名称

数据类型

最大长度

是否必填

默认值

描述

示例值

bizId

String

32


-

业务ID,业务的唯一标识,用于追踪业务。例如,商户业务相关数据库中的序列号。

说明:ZOLOZ服务器不检查该字段的值是否唯一。为了更便捷地追踪业务,建议开启商户服务器,并确保业务ID的唯一性。

"2017839040588699"

metaInfo

String

512

-

SDK和用户设备的元信息。该字段的值由ZOLOZ SDK以JSON字符串格式返回。

说明:不要修改返回值,直接传递即可。如果是H5接入模式,则设置为MOB_H5

"{

\"deviceType\": \"android\", \"appVersion\": \"1.0.9\", \"osVersion\": \"9\", \"appName\": \"com.zoloz.atomic.client\", \"bioMetaInfo\": \"3.46.0:2916352,0\", \"apdidToken\": \"69b74bfe-bf7f-4d3b-ac59-907ee09e7955\", \"deviceModel\": \"MI 6\", \"zimVer\": \"1.0.0\" }"

flowType

String

32

-

指定身份验证流的类型。取值如下:

  • REALIDLITE_KYC:使用App SDK接入模式。
  • H5_REALIDLITE_KYC:使用H5接入模式。

"H5_REALIDLITE_KYC"

docType

String

16

null

指定证件类型。例如要上传的证件是护照,该字段的值需要设置为00000001003

说明docTypeautoDocTypes不能同时传入,需选择其中一个传入。

RealID支持的证件类型,请参见RealID和ID Recognition支持的证件类型和返回的OCR结果

"08520000001"

autoDocTypes

List<String>

200

null

证件类型列表。docTypeautoDocTypes不能同时传入,需选择其中一个传入。

  • 如果传入autoDocTypes,ZOLOZ将自动对上传的证件进行分类。
    说明
    • 目前护照不支持自动分类。
    • 新加坡证件0065000000100650000002将统一归类为00650000002
  • 如果ZOLOZ无法对上传的证件进行分类或分类的证件类型不在autoDocTypes中,checkresult API将返回NO_REQUIRED_ID

支持的证件类型,请参见RealID和ID Recognition支持的证件类型和返回的OCR结果

["08520000001","08520000002"]

userId

String

64

-

商户的用户ID或其他可用于识别某一用户的标识,例如手机号码、电子邮件地址等。

建议对userId字段的值进行预脱敏,例如进行哈希处理。

"123456abcd"

sceneCode

String

64

null

场景码,用来为数据分析指定不同的业务场景。

当需要区分不同业务场景中的数据表现时,建议根据业务用途为sceneCode字段设置不同的值,例如login、riskVerify、payment、changePassword。

"changePassword"

serviceLevel

String

32

REALID0001

防伪检测和人脸活体检测的服务等级。取值如下:

  • REALID0001:在身份验证进程中需要用户手动拍摄证件照片。ZOLOZ执行基本的防伪检测,以及使用眨眼检测方法进行基本的活体检测。
  • REALID0002:在身份验证进程中ZOLOZ SDK会自动扫描证件。ZOLOZ执行高等级的防伪检测,以及使用眨眼检测方法进行基本的活体检测。
    说明:当使用场景为Web SDK,且所扫描的证件为中国香港身份证第一版或第二版时,将采用多角度采集方式。
  • REALID0003在身份验证进程中ZOLOZ SDK会自动扫描证件。ZOLOZ执行高等级的防伪检测,并使用多动作检测方法进行活体检测。这些动作从以下列表中随机选择两个:眨眼、张嘴、抬头、低头、左摇头、右摇头。
    说明:该服务等级仅支持在原生SDK模式下使用。
  • REALID0004在身份验证进程中,即使身份证件处于倾斜角度,ZOLOZ SDK也会自动扫描证件。ZOLOZ执行基本的防伪检测,以及使用眨眼检测方法进行基本的活体检测。
  • REALID0009在身份验证进程中ZOLOZ SDK会自动扫描证件。ZOLOZ执行高等级的防伪检测,以及使用眨眼检测方法进行活体检测。
    说明:该服务等级会额外采集一张闭眼的人脸图片,且该服务等级仅支持在原生SDK模式下使用。
  • REALID0011在身份验证进程中ZOLOZ SDK会自动扫描证件。ZOLOZ执行高等级的防伪检测,以及使用眨眼检测方法进行活体检测。
    说明
    • 该服务等级会额外采集一张闭眼的人脸图片,且该服务等级仅支持在Web SDK模式下使用。
    • 当使用场景为Web SDK,且所扫描的证件为中国香港身份证第一版或第二版时,将采用多角度采集方式。
  • REALID0012在身份验证进程中ZOLOZ SDK会自动扫描证件。ZOLOZ执行基本的防伪检测,以及使用眨眼检测方法进行活体检测。
    说明:该服务等级仅支持在Web SDK模式下使用。

"REALID0001"

operationMode

String

32

STANDARD

为身份验证配置操作模式。取值如下:

  • CLOSED:所有的算法和风控规则都未开启。该操作模式可用于测试场景,测试进程不受算法和风控规则的影响。
  • STANDARD:推荐的标准模式。
  • LOOSE:相对宽松的模式,可用于低风险场景。
  • STRICT:相对严格的模式,可用于高风险场景。
  • STANDARD_VC_CLOSED:使用此模式关闭Velocity功能。
  • STANDARD_IDN_CLOSED:使用此模式关闭IDN功能。
  • STANDARD_VC_IDN_CLOSED:使用此模式关闭Velocity功能和IDN功能。

说明:当operationMode设置为STANDARD_VC_CLOSEDSTANDARD_IDN_CLOSEDSTANDARD_VC_IDN_CLOSED时,其他算法能力与STANDARD相同。

以下是IDN和Velocity的含义:

  • IDN:表示通过IDN检测到虚假验证风险。例如,检测到识别出的人脸与多个身份证件相关或检测到一个身份证件与多张人脸相关。更多详情,请参见checkresult
  • Velocity:表示通过Velocity检测到虚假验证风险。例如,同一用户(通过userId、证件号或deviceId识别)在一段时间内尝试攻击(例如篡改证件信息或活体攻击)的次数达到一定阈值时,Velocity功能将不允许该用户继续提交,直到冷却期结束为止。

"STANDARD"

pages

String

32

证件类型支持的所有页

待扫描和上传的证件页面,多个页面以英文逗号分隔。例如:

  • 1:表示扫描第一页。
  • 1,2:表示扫描第一页和第二页。

证件所支持的页面数,请参见RealID和ID Recognition支持的证件类型和返回的OCR结果

说明

  • 如果不传该字段,默认值为对应证件类型支持的所有页。
  • 当传入autoDocTypes时,pages应为空;如果pages不为空,会返回INVALID_ARGUMENT

"1,2"

pageConfig

PageConfig

-

null

指定H5页面的配置信息。详细信息,请参见PageConfig

{ "urlFaceGuide":"http://url-to-face-guide-page.html" }

h5ModeConfig

H5ModeConfig

-

null

H5 RealID的配置信息。详细信息,请参见H5ModeConfig

说明当flowType的值为H5_REALIDLITE_KYC时必须传入该字段。

{ "completeCallbackUrl":"http://xxx.html", "interruptCallbackUrl":"http://xxx.html"

}

productConfig

ProductConfig

-

null

RealID产品提供更精细化的控制。详细信息,请参见ProductConfig

{

"cropDocImage": "Y", "landmarkCheck": [ {"name":"kadPengenalan"}, {"name":"mykadLogo"}, {"name":"flagLogo"}, {"name":"mscLogo"}, {"name":"ghostFace"}, {"name":"hibiscusLogo"}, {"name":"coatOfArm"}, {"name":"twinTower"} ], "hologramCheck": [ {"name":"hologram"} ], "pageInfoCheck": [ {"name":"id"}, {"name":"symbol"}, {"name":"name"} ], "preciseTamperCheck": "Y" }

PageConfig字段说明

字段名称

数据类型

最大长度

是否必填

默认值

描述

示例值

urlFaceGuide

String

256

null

人脸引导页的URL。该页面为H5提示页面,可自定义引导用户进行人脸扫描。
说明:如果您想在定制页面中隐藏ZOLOZ提供的标题栏,请参见如何隐藏Native SDK的人脸引导页标题栏?

"http://url-to-face-guide-page.html"

H5ModeConfig字段说明

字段名称

数据类型

最大长度

是否必填

默认值

描述

示例值

state

String

128

transactionId字段的值

用于恢复客户上下文的标识符。

您可以为该字段设置任何值,当ZOLOZ SDK回调商户的移动App时将该值作为参数进行传递。

"G000000005FID20200304000000000001570702"

completeCallbackUrl

String

128

-

当整个身份验证完成时,为浏览器指定即将重定向的回调URL。

"http://xxx.html"

interruptCallbackUrl

String

128

-

当进程中断时,为浏览器指定重定向到的回调URL。

"http://xxx.html"

locale

String

16

en

网页语言,目前支持以下语言:

  • en(英语)
  • zh-CN(简体中文)
  • zh-HK(繁体中文)
  • jp(日语)
  • th(泰语)
  • es(西班牙语)
  • pt(葡萄牙语)
  • fr(法语)
  • id(印度尼西亚语)
  • de(德语)
  • kr(韩语)
  • vi(越南语)

"zh-CN"

isIframe

String

1

N

是否需要在iframe中打开网页,如果需要设置为Y,否则设置为N。

"Y"

uiCfg

String

256

null

自定义UI配置,采用JSON字符串格式。目前仅支持titlebarbgcolortitlebartextcolorbuttoncolor

"{\"titlebarbgcolor\":\"#ffffff\",\"titlebartextcolor\":\"#000000\",\"buttoncolor\":\"#3696fd\"}"

allowDegradation

String

1

N

是否允许进入降级模式。取值如下:

  • Y:允许进入降级模式。
  • N:不允许进入降级模式。

说明

  • 如果将allowDegradation设置为Y,当ZOLOZ检测到用户的浏览器不支持Web SDK时,用户可以选择是否进入降级模式,确认进入降级模式后,ZOLOZ将调用系统原生相机进行拍摄。
  • 降级模式可能存在较高风险,对于来自降级模式下的交易,ZOLOZ判定出的最高eKYC结果为Pending,需要您进行二次检查。

"Y"

docFrontPageGuideUrl

String

128

null

指定降级模式下证件引导页首页的URL。这是一个可定制的H5提示页面,用于引导用户采集证件的第一页图片。

说明:如果不传该参数,则使用默认页面。

"http://xxx.html"

docBackPageGuideUrl

String

128

null

指定降级模式下证件引导页第二页的URL。这是一个可定制的H5提示页面,用于引导用户采集证件的第二页图片。
说明:如果不传该参数,则使用默认页面。

"http://xxx.html"

facePageGuideUrl

String

128

null

指定降级模式下人脸引导页面的URL。这是一个可定制的H5提示页面,用于引导用户采集自拍人脸图片。

说明:如果不传该参数,则使用默认页面。

"http://xxx.html"

ProductConfig字段说明

字段名称

数据类型

最大长度

是否必填

默认值

描述

特别说明

示例值

cropDocImage

String

1

N

是否额外返回一张裁剪掉证件背景的证件图片。取值如下:

  • Y:是,如果同时采集了证件的正面和背面图片,则会额外返回两张裁剪后的图片。
  • N:否

-

"Y"

cropFaceImage

String

1

N

是否额外返回一张裁剪出脸部区域的人脸图片。取值如下:

  • Y:是
  • N:否

-

"Y"

landmarkCheck

Array

-

null

在证件防伪检测中进行landmark检查,详细检查项,请参见证件防伪检测组件

说明landmark检查仅适用于大马卡(MyKad)。

-

[{"name":"kadPengenalan"}, {"name":"mykadLogo"}, {"name":"flagLogo"}, {"name":"mscLogo"}, {"name":"ghostFace"}, {"name":"hibiscusLogo"}, {"name":"coatOfArm"}, {"name":"twinTower"}]

hologramCheck

Array

-

null

在证件防伪检测中进行全息图检查,详细检查项,请参见证件防伪检测组件

说明全息图检查仅适用于大马卡(MyKad)。

-

[{"name":"hologram"}]

pageInfoCheck

Array

-

null

在证件防伪检测中进行页面信息检查,详细检查项,请参见证件防伪检测组件

说明:页面信息检查仅适用于中国香港身份证。

-

[

{"name":"id"}, {"name":"symbol"}, {"name":"name"} ]

preciseTamperCheck

String

1

N

该参数已废弃,后续不再维护,为了保证API兼容性,该参数会继续保留。

是否进行精细篡改检测。精细篡改检测仅适用于中国香港身份证。

  • Y:进行精细篡改检测
  • N:不进行精细篡改检测

-

"Y"

docUiType

String

20

  • Native SDK:2
  • Web SDK:1

证件照片的采集方式。取值如下:

  • 1:手拍版(Self-capture),用户需要手动拍摄证件照片,仅具备基础防伪能力。
  • 2:Native防伪版(Deep-scan),仅适用于Native SDK。ZOLOZ SDK将自动对齐并拍摄证件照片,具备拦截彩打等高级防伪能力。
  • 3:H5扫描版(Auto-scan),仅适用于Web SDK。ZOLOZ SDK将自动对齐并拍摄证件照片,仅具备基础防伪能力。
    建议Web SDK使用自动扫描的采集方式,因为与手拍版相比,自动扫描的用户体验更好且证件图片质量更高。
  • 4:甩证版(Trace-scan),仅适用于Native SDK。当ZOLOZ SDK在摄像头范围内检测到证件时将自动拍摄。该版式可用于提升用户体验,但防伪能力较弱,仅具备基础防伪能力。
  • 5:多角度版(Multi-angle),仅适用于Web SDK中的中国香港证件。用户需要分别拍摄正对证件的照片和证件倾斜30°的照片,具备拦截彩打等高级防伪能力。

以下10个参数的优先级高于serviceLevel和operationMode,如果传入了10个参数中的任何一个,其他几个参数的默认值都会生效。此时即使传入了servicelevel和operationmode的值,servicelevel和operationmode也不生效。

  • docUiType
  • spoofMode
  • livenessMode
  • antiInjectionMode
  • deeperMode
  • actionCheckItems
  • actionRandom
  • actionFrame
  • riskMode
  • idnThreshold

"2"

spoofMode

String

10

STANDARD

证件防伪等级。取值如下:

  • CLOSED:所有的防伪算法都未开启。该等级可用于测试场景,测试进程不受算法和风控规则的影响。
  • STANDARD:推荐的标准等级。
  • LOOSE预留等级,暂不支持使用
  • STRICT预留等级,暂不支持使用

"STANDARD"

livenessMode

String

10

STANDARD

人脸活体检测等级。取值如下:

  • CLOSED:所有的算法和风控规则都未开启。该等级可用于测试场景,测试进程不受算法和风控规则的影响。
  • STANDARD:推荐的标准等级。
  • LOOSE:相对宽松的等级,可用于低风险场景。
  • STRICT:相对严格的等级,可用于高风险场景。

"STANDARD"

antiInjectionMode

String

10

CLOSED

该参数已废弃,后续不再维护,为了保证API兼容性,该参数会继续保留。

防注入检测等级。防注入检测能够有效抵御使用换脸图片或视频进行的注入攻击。取值如下:

  • CLOSED:所有的防注入算法都不开启。如果业务场景不需要注入攻击检测,则不需要开启。
  • STANDARD:推荐的标准等级。
  • LOOSE预留等级,暂不支持使用。
  • STRICT预留等级,暂不支持使用。

注意:开启防注入检测会略微增加误报率和运行时间,开启前请先联系ZOLOZ技术支持。

"CLOSED"

deeperMode

String

10

CLOSED

AIGC攻击检测的Deeper等级,Deeper检测功能的详细介绍,请参见什么是Deeper。该参数支持以下取值:

  • CLOSED:Deeper的所有能力均不开启,例如AIGC检测算法、终端风险检测等。如果业务场景不需要AIGC攻击检测,则无需开启。
  • STANDARD:推荐的标准等级。
  • LOOSE:相对宽松的等级,可用于低风险场景。
  • STRICT:相对严格的等级,可用于高风险场景。

注意:需要先购买Deeper产品,才能使用该功能。

"CLOSED"

actionCheckItems

List<String>

-

FACEBLINK

客户端和Web端的动作检测列表。取值如下:

  • FACEBLINK:眨眼
  • MOUTHOPEN:张嘴
  • HEADSHAKE:摇头
  • HEADLOWER:低头
  • HEADRAISE:抬头

说明:为了更好的用户体验,不建议使用两种及以上的动作。

["FACEBLINK","HEADLOWER"]

actionRandom

String

1

N

客户端和Web端的动作检测顺序是否随机。取值如下:

  • Y:随机。
  • N:不随机,则按照actionCheckItems中的顺序进行检测。

"Y"

actionFrame

List<String>

-

null

采集其他帧图片。取值如下:

  • EYECLOSE:闭眼帧。

["EYECLOSE"]

riskMode

String

10

STANDARD

RealID中的多维度风控规则校验,用于拦截可疑交易。取值如下:

  • CLOSED:所有有关风险检测的算法都未开启。该等级可用于测试场景,测试进程不受算法和风控规则的影响。
  • STANDARD:推荐的标准等级。
  • LOOSE:相对宽松的等级,可用于低风险场景。
  • STRICT:相对严格的等级,可用于高风险场景。

"STANDARD"

idnThreshold

Integer

-

3

该参数已废弃,后续不再维护,为了保证API兼容性,该参数会继续保留。

指定阈值,用于拦截同一商户同脸不同证或同证不同脸的交易,当不同userId之间的关联交易笔数超过指定的阈值时将被拦截。
支持传入大于等于1的任何整数,默认阈值为3。

"3"

allowExpiredDocument

String

-

不同的证件类型有不同的默认值:

  • Y:除护照(docType=00000001003)外的所有证件
  • N:护照(docType=00000001003)

已过期的证件是否可以通过验证。取值如下:

  • Y:已过期的证件可以通过验证。
  • N:已过期的证件不能通过验证。当检测到证件过期时,RealID流程会失败。

说明:如果传入的值为空或无效,此时将使用默认取值。

-

"N"

faceAttributeCheck

FaceAttributeCheck

-

null

人脸属性检测,详情请参见FaceAttributeCheck

说明:faceAttributeCheck的优先级高于livenessMode。例如,当occlusionCheck.detectOpen为N时,即使livenessMode为STRICT,也不会进行人脸遮挡检测。

-

{

     "occlusionCheck": {

       "details": [

         "eyesOcclusion",

         "noseOcclusion",

         "mouthOcclusion",

         "foreheadOcclusion",

         "chinOcclusion",

         "cheekOcclusion"

       ],

       "detectOpen": "Y",

       "needRetry": "Y"

     },

     "maskCheck": {

       "detectOpen": "Y",

       "needRetry": "N"

     },

     "glassesCheck": {

       "detectOpen": "Y",

       "needRetry": "N"

     },

     "hatCheck": {

       "detectOpen": "Y",

       "needRetry": "N"

     }

   }

consistencyCheck

List<ConsistencyCheckItem>

-

null

是否进行一致性检查。一致性检查仅适用于部分证件的特定字段,详见ConsistencyCheckItem

-

参考请求示例

checkAdvancedIdn

String

-

N

是否开启Advanced IDN风险检查。取值:

  • Y:开启。
  • N:不开启。

说明:需要先购买Advanced IDN,才能开启该功能。

-

"Y"

advancedIdnRiskDetection

RiskDetection

-

RiskDetection

风险检测,详情请参见RiskDetection

说明:仅当checkAdvancedIdnY时,该参数才生效。

-

{

   "riskTypes":[

     "IDFAKE",

     "DUPLICATE",

     "BATCH_REGISTER",

      "DEEPFAKE",

   ],

   "timeWindow":{

      "startTime":1651882535687,

      "endTime":1658902665000

   }

 }

advancedIdnThreshold

String

-

3

指定Advanced IDN风险检查的阈值,取值范围为1-100,当历史有关联的风险交易笔数超过指定阈值时将被拦截。相同的itemId只会计数一次。

说明:仅当checkAdvancedIdnY时,该参数才生效。

-

"3"

checkBlacklist

String

1

N

是否开启黑名单风险检查。取值:

  • Y:开启。
  • N:不开启。

说明:需要先购买黑名单能力,才能开启该功能。

-

"Y"

FaceAttributeCheck字段说明

字段名称

数据类型

最大长度

是否必填

默认值

描述

示例值

occlusionCheck

FaceAttributeDetails

-

null

是否进行人脸遮挡检测,详情请参见FaceAttributeDetails

{

"details": [

"eyesOcclusion",

"noseOcclusion",

"mouthOcclusion",

"foreheadOcclusion",

"chinOcclusion",

"cheekOcclusion"

],

"detectOpen": "Y",

"needRetry": "Y"

}

maskCheck

FaceAttributeDetails

-

null

是否进行口罩检测,详情请参见FaceAttributeDetails

{

"detectOpen": "Y",

"needRetry": "N"

}

glassesCheck

FaceAttributeDetails

-

null

是否进行眼镜检测,详情请参见FaceAttributeDetails

{

"detectOpen": "Y",

"needRetry": "N"

}

hatCheck

FaceAttributeDetails

-

null

是否进行帽子检测,详情请参见FaceAttributeDetails

{

"detectOpen": "Y",

"needRetry": "N"

}

FaceAttributeDetails字段说明

字段名称

数据类型

最大长度

是否必填

默认值

描述

示例值

detectOpen

String

1

null

是否检测人脸属性并在checkresult API中返回检测结果。取值如下:

  • Y:是
  • N:否

"Y"

needRetry

String

1

null

检测到指定属性时是否重试。取值如下:

  • Y:是。当needRetry为Y时,detectOpen必须为Y。
  • N:否。当needRetry为N时,eKYC仍可能会因为人脸质量较低而提示重试。

"Y"

details

List<String>

-

null

是否返回人脸属性的结果详情。目前仅支持返回occlusionCheck的结果详情,支持的选项如下:

  • eyesOcclusion:返回眼睛遮挡结果。
  • noseOcclusion:返回鼻子遮挡结果。
  • mouthOcclusion:返回嘴巴遮挡结果。
  • foreheadOcclusion:返回额头遮挡结果。
  • chinOcclusion:返回下巴遮挡结果。
  • cheekOcclusion:返回脸颊遮挡结果。

说明

  • 当传入details参数时,detectOpen必须为Y。
  • details对应的总结果和特定属性结果将在checkresult API中返回。

[

"eyesOcclusion",

"noseOcclusion",

"mouthOcclusion",

"foreheadOcclusion",

"chinOcclusion",

"cheekOcclusion"

]

ConsistencyCheckItem类型说明

commonConsistencyCheck

字段名称

数据类型

取值范围

描述

支持的证件 / 国家或地区 / 证件类型

OCR一致性检查支持字段

type

String

commonConsistencyCheck

对证件防伪检测中的OCR字段进行一致性检查。

大马卡 / 马来西亚 / 00600000001

  • 证件正面:ID_NUMBER
  • 证件背面:ID_NUMBER_BACK前12位数字

mrzVisualConsistencyCheck

字段名称

数据类型

取值范围

描述

支持的证件 / 国家或地区 / 证件类型

OCR一致性检查支持字段

type

String

mrzVisualConsistencyCheck

证件防伪检测中机读区和视读区的OCR字段进行一致性检查。

-

-

details

List<String>

请参见RealID和ID Recognition支持的证件类型和返回的OCR结果

details中指定OCR字段进行一致性检查。

  • type设置为mrzVisualConsistencyCheck时,必须传入details字段
  • 仅允许传入证件类型所支持的OCR字段。

MyVisa / 马来西亚 / 00600000011

  • NAME
  • SEX

护照(含机读区和视读区)/ 中国大陆、中国香港、中国台湾、中国澳门、菲律宾、新加坡、马来西亚 / 00000001006

  • ID_NUMBER
  • COUNTRY_CODE
  • EXPIRY_DATE
  • DATE_OF_BIRTH

passportCountryCheck

字段名称

数据类型

取值范围

描述

支持的证件 / 国家或地区 / 证件类型 / OCR一致性检查支持字段 / 默认国家代码

type

String

passportCountryCheck

检查OCR结果中的COUNTRY_CODE与系统检测到的国家是否一致。

-

valueRange

List<String>

应与默认国家代码一致

OCR结果中的COUNTRY_CODE应在valueRange范围内。

type设置为passportCountryCheck时,必须传入valueRange字段,各证件支持的valueRange详见RealID和ID Recognition支持的证件类型和返回的OCR结果

以下证件的valueRange为证件所属国家或地区对应的默认国家或地区代码所组成的列表。

  • 中国大陆护照 / 00860000888 / COUNTRY_CODE / CHN
  • 中国台湾护照 / 08860000002 / COUNTRY_CODE / TWN
  • 中国澳门护照 / 08530000002 / COUNTRY_CODE / CHN
  • 菲律宾旧版护照 / 00630000031 / COUNTRY_CODE / PHL
  • 菲律宾新版护照 / 00630000032 / COUNTRY_CODE / PHL

每一项都应符合ISO_3166-1_alpha-3标准

以下证件的valueRange为列表,且每一项都应符合ISO_3166-1_alpha-3标准。

  • 国际护照(仅含机读区) / 00000001003 / COUNTRY_CODE
  • 国际护照(含机读区和视读区)/ 00000001006 / COUNTRY_CODE

RiskDetection字段说明

字段名称

数据类型

最大长度

是否必填

默认值

描述

示例值

riskTypes

List<String>

-

["IDFAKE","DUPLICATE"]

待查询的风险类型。支持以下四大类风险,系统会自动查询其包含的子风险,详情参考IdNetwork风险介绍

  • IDFAKE:身份冒用。
  • DUPLICATE:重复认证。
  • BATCH_REGISTER:批量注册。
  • DEEPFAKE:人脸伪造。

[

     "IDFAKE",

     "DUPLICATE",

     "BATCH_REGISTER",

     "DEEPFAKE"

   ]

timeWindow

TimeWindow

-

TimeWindow

风险查询时间窗口,最长可查询180天的数据,默认查询最近30天的数据,详情请参见TimeWindow

注意:系统单次扫描的数据量限制为50万条记录。如果在查询时间窗口范围内数据量超过50万条记录,系统会动态调整您所设置的时间窗口。

{ "startTime":1651882535687, "endTime":1658902665000 }

TimeWindow字段说明

字段名称

数据类型

最大长度

是否必填

默认值

描述

示例值

startTime

Long

-

当前时间

风险查询起始时间,采用13位时间戳。

1651882535687

endTime

Long

-

30天前的时间

风险查询结束时间,采用13位时间戳。

1658902665000

返回参数

字段名称

数据类型

必须返回

描述

示例值

result

Result

API请求结果,包含结果状态、结果码和结果消息。

{

"resultStatus": "S", "resultCode": "SUCCESS", "resultMessage": "Success"

}

transactionId

String

ZOLOZ服务器为身份验证生成的唯一事务ID。此ID将作为RealID checkresult API请求的输入参数。

说明:当在客户端身份验证中出现错误时,例如参数无效,则不返回事务ID。

"G000000005FID20200304000000000001570702"

clientCfg

String

客户端配置信息,包括SDK连接和行为参数。

说明:当result.resultStatus的值为S时,才返回该字段。

"……"

处理结果

根据请求结果执行下一步的响应动作,具体如下:

  • 当result.resultStatus的值为S时,表示调用ZOLOZ RealID initialize API成功,并返回唯一的事务ID。
  • 当result.resultStatus的值为F时,表示调用ZOLOZ RealID initialize API失败。请检查错误码获取有关该错误的更多信息,并分析导致该错误的原因。

API通用结果码

有关通用结果码的完整列表,请参见API通用结果码

API特有结果码

RealID initialize API的结果码见下表。

结果码

结果状态

描述

SUCCESS

S

API调用成功。

HIGH_RISK

F

检测到高风险。用户账号被风险引擎冻结。

ACCOUNT_SERVICE_SUSPEND

F

用户账号被风险引擎列入黑名单。

DEVICE_NOT_SUPPORT

F

不支持当前的设备类型。

OS_NOT_SUPPORT

F

不支持当前设备的操作系统。

SDKVERSION_NOT_SUPPORT

F

不支持ZOLOZ SDK当前的版本。

INVALID_ARGUMENT

F

输入参数无效。关于无效参数的详细信息,请查看返回的resultMessage。

SYSTEM_ERROR

F

其他内部错误。有关错误详情,请查看返回的resultMessage。

代码示例

请求示例

不同的接入模式请求结构略有不同。在H5模式下初始化身份验证时,必须指定H5ModeConfig对象。

  • 原生RealID请求示例
    在App SDK模式下初始化身份验证的请求代码示例。
copy
{
  "bizId": "2017839040588699",
  "flowType": "REALIDLITE_KYC",
  "userId": "123456abcd",
  "autoDocTypes":["08520000001","08520000002"],
  "pageConfig":{
    "urlFaceGuide":"http://url-to-face-guide-page.htm"
  },
  "serviceLevel": "REALID0001",
  "operationMode": "STANDARD",
  "productConfig": {
    "deeperMode":"STANDARD",
    "cropDocImage": "Y",
    "landmarkCheck": [
      {"name":"kadPengenalan"},
      {"name":"mykadLogo"},
      {"name":"flagLogo"},
      {"name":"mscLogo"},
      {"name":"ghostFace"},
      {"name":"hibiscusLogo"},
      {"name":"coatOfArm"},
      {"name":"twinTower"}
    ],
    "hologramCheck": [
      {"name":"hologram"}
    ],
    "pageInfoCheck": [
      {"name":"id"},
      {"name":"symbol"},
      {"name":"name"}
    ],
    "preciseTamperCheck": "Y",
    "allowExpiredDocument": "Y",
    "faceAttributeCheck": {
      "occlusionCheck": {
        "details": [
          "eyesOcclusion",
          "noseOcclusion",
          "mouthOcclusion",
          "foreheadOcclusion",
          "chinOcclusion",
          "cheekOcclusion"
        ],
        "detectOpen": "Y",
        "needRetry": "Y"
      },
      "maskCheck": {
        "detectOpen": "Y",
        "needRetry": "N"
      },
      "glassesCheck": {
        "detectOpen": "Y",
        "needRetry": "N"
      },
      "hatCheck": {
        "detectOpen": "Y",
        "needRetry": "N"
      }
    },
    "consistencyCheck": [
      {
        "type": "commonConsistencyCheck"
      },
      {
        "details": [
          "NAME",
          "SEX"
        ],
        "type": "mrzVisualConsistencyCheck"
      },
      {
        "valueRange": [
          "CHN",
          "PHL"
        ],
        "type": "passportCountryCheck"
      }
    ],
    "advancedIdnRiskDetection": {
            "riskTypes": [
                "IDFAKE",
                "DUPLICATE",
                "BATCH_REGISTER",
                "DEEPFAKE"
            ],
            "timeWindow": {
                "endTime": 1724377636300,
                "startTime": 1724222116300
            }
        },
    "advancedIdnThreshold": "3",
    "checkAdvancedIdn": "Y",
    "checkBlacklist": "Y"
  },
  "metaInfo": "{
         \"deviceType\": \"deviceType\",
         \"appVersion\": \"1.0\",
         \"osVersion\": \"7.1.1\",
         \"appName\": \"com.company.wallet\",
         \"bioMetaInfo\": \"3.37.0:262144,0\",
         \"apdidToken\": \"mock-apdidToken\",
         \"deviceModel\": \"MI 6\",
         \"zimVer\": \"2.0.0\"
   }"
}
  • H5 RealID请求示例
    在H5模式下初始化身份验证的请求代码示例。
copy
{
  "bizId": "2017839040588699",
  "flowType": "H5_REALIDLITE_KYC",
  "userId": "123456abcd",
  "autoDocTypes":["08520000001","08520000002"],
  "pageConfig":{
    "urlFaceGuide":"http://url-to-face-guide-page.htm"
  },
  "serviceLevel": "REALID0001",
  "operationMode": "STANDARD",
  "productConfig": {
    "deeperMode":"STANDARD",
    "cropDocImage": "Y",
    "landmarkCheck": [
      {"name":"kadPengenalan"},
      {"name":"mykadLogo"},
      {"name":"flagLogo"},
      {"name":"mscLogo"},
      {"name":"ghostFace"},
      {"name":"hibiscusLogo"},
      {"name":"coatOfArm"},
      {"name":"twinTower"}
    ],
    "hologramCheck": [
      {"name":"hologram"}
    ],
    "pageInfoCheck": [
      {"name":"id"},
      {"name":"symbol"},
      {"name":"name"}
    ],
    "preciseTamperCheck": "Y",
    "allowExpiredDocument": "Y",
    "faceAttributeCheck": {
      "occlusionCheck": {
        "details": [
          "eyesOcclusion",
          "noseOcclusion",
          "mouthOcclusion",
          "foreheadOcclusion",
          "chinOcclusion",
          "cheekOcclusion"
        ],
        "detectOpen": "Y",
        "needRetry": "Y"
      },
      "maskCheck": {
        "detectOpen": "Y",
        "needRetry": "N"
      },
      "glassesCheck": {
        "detectOpen": "Y",
        "needRetry": "N"
      },
      "hatCheck": {
        "detectOpen": "Y",
        "needRetry": "N"
      }
    },
    "consistencyCheck": [
      {
        "type": "commonConsistencyCheck"
      },
      {
        "details": [
          "NAME",
          "SEX"
        ],
        "type": "mrzVisualConsistencyCheck"
      },
      {
        "valueRange": [
          "CHN",
          "PHL"
        ],
        "type": "passportCountryCheck"
      }
    ],
    "advancedIdnRiskDetection": {
            "riskTypes": [
                "IDFAKE",
                "DUPLICATE",
                "BATCH_REGISTER",
                "DEEPFAKE"
            ],
            "timeWindow": {
                "endTime": 1724377636300,
                "startTime": 1724222116300
            }
        },
    "advancedIdnThreshold": "3",
    "checkAdvancedIdn": "Y",
    "checkBlacklist": "Y"
  },
  "metaInfo": "MOB_H5",
  "h5ModeConfig":{
    "completeCallbackUrl":"http://xxx.html",
    "interruptCallbackUrl":"http://xxx.html",
    "allowDegradation":"Y",
    "docFrontPageGuideUrl":"http://xxx.html",
    "docBackPageGuideUrl":"http://xxx.html",
    "facePageGuideUrl":"http://xxx.html"
  }
}

返回示例

ZOLOZ服务器返回的响应代码示例。

copy
{
   "result": {
        "resultStatus": "S",
        "resultCode": "SUCCESS",
        "resultMessage": "Success"
    },
  "transactionId":"G000000005FID20200304000000000001570702", 
  "clientCfg": "……"   
}