聚美智数


活体检测SDK-V1(停用)

<h2>接入准备</h2> <ol> <li>下载活体检测SDK IOS:<a href="https://file.jumdata.com/lifecheck-sdk/MotionSDK_iOS_1.0.1.zip">https://file.jumdata.com/lifecheck-sdk/MotionSDK_iOS_1.0.1.zip</a> Android:<a href="https://file.jumdata.com/lifecheck-sdk/Motion_android_V1.0.1.zip">https://file.jumdata.com/lifecheck-sdk/Motion_android_V1.0.1.zip</a></li> <li>向服务商报备App的 <strong>Bundle ID</strong></li> </ol> <h2>使用步骤</h2> <ol> <li>APP唤起SDK,做指定动作进行检测</li> <li>检测之后SDK向APP返回检测结果(加密文件)</li> <li>APP接收到SDK的检测结果后,调用服务商 <strong>验证检测结果接口</strong> 进行验证</li> <li>验证完成之后返回最终验证结果(通过或未通过,提取照片)</li> </ol> <h2>验证检测结果接口</h2> <h3>接口描述</h3> <ul> <li>该API需要配合活体检测SDK使用,在APP调用SDK进行活体检测成功之后,由APP调用该API</li> <li>该API将SDK的返回结果(加密文件)作为入参,返回最终活体检测结果(通过或未通过、提取照片)</li> </ul> <h3>请求地址</h3> <p><code>https://api.jumdata.com/lifecheck-sdk/v1/check</code></p> <h3>请求方式</h3> <ul> <li>POST</li> </ul> <h3>请求格式</h3> <ul> <li>x-www-form-urlencoded</li> </ul> <h3>请求参数</h3> <table> <thead> <tr> <th>名称</th> <th>类型</th> <th>必须</th> <th>说明</th> </tr> </thead> <tbody> <tr> <td>appId</td> <td>varchar</td> <td>是</td> <td>服务商分配的唯一标识</td> </tr> <tr> <td>timestamp</td> <td>number</td> <td>是</td> <td>当前时间的毫秒数</td> </tr> <tr> <td>sign</td> <td>varchar</td> <td>是</td> <td>签名,见签名算法说明</td> </tr> <tr> <td>file</td> <td>file</td> <td>是</td> <td>文件类型,活体检测SDK返回的加密文件</td> </tr> </tbody> </table> <h3>签名算法</h3> <pre><code>sign = sha256(appId + appSecret + timestamp)</code></pre> <p>用服务商分配的 <strong>appId</strong>、服务商分配的 <strong>appSecret</strong>,当前时间毫秒数 <strong>timestamp</strong>,按上述顺序拼接成字符串,再进行 <strong>sha256</strong> 哈希得到。如下:</p> <pre><code class="language-java">String appId = &amp;quot;xyzxy2121zxyz&amp;quot;; String timestamp = &amp;quot;1555378976238&amp;quot;; String appSecret = &amp;quot;efcefcef1121cefcefc1212121&amp;quot;; String str = appId + appSecret + timestamp; String sign = sha256(str);</code></pre> <h3>活体通过返回样例</h3> <pre><code class="language-json">{ &amp;quot;code&amp;quot;: 200, &amp;quot;taskNo&amp;quot;: &amp;quot;69564903663951243279&amp;quot;, &amp;quot;data&amp;quot;: { &amp;quot;result&amp;quot;: 1 , &amp;quot;selfie_url&amp;quot;: &amp;quot;https://&amp;quot; } }</code></pre> <h3>活体未通过返回样例</h3> <pre><code class="language-json">{ &amp;quot;code&amp;quot;: 200, &amp;quot;data&amp;quot;: { &amp;quot;order_no&amp;quot;: &amp;quot;673106944390729728&amp;quot;, &amp;quot;result&amp;quot;: 2 } }</code></pre> <h3>错误返回样例</h3> <pre><code class="language-json">{ &amp;quot;msg&amp;quot;: &amp;quot;SDK结果文件必须上传&amp;quot;, &amp;quot;code&amp;quot;: 400, &amp;quot;data&amp;quot;: { } }</code></pre> <h3>返回字段说明</h3> <table> <thead> <tr> <th>字段名</th> <th>说明</th> </tr> </thead> <tbody> <tr> <td>code</td> <td>成功为200,其它为失败返回码(非http返回状态码)</td> </tr> <tr> <td>msg</td> <td>code对应的描述</td> </tr> <tr> <td>taskNo</td> <td>唯一业务号</td> </tr> <tr> <td>data</td> <td>返回具体结果,object类型,详见data返回字段描述</td> </tr> </tbody> </table> <h4>data返回字段说明</h4> <table> <thead> <tr> <th>字段名</th> <th>说明</th> </tr> </thead> <tbody> <tr> <td>result</td> <td>活体检测结果,1:通过,2:不通过</td> </tr> <tr> <td>selfie_url</td> <td>提取的照片url,保存时间1小时,需尽快下载</td> </tr> </tbody> </table> <h4>code返回码说明</h4> <table> <thead> <tr> <th>code</th> <th>说明</th> </tr> </thead> <tbody> <tr> <td>200</td> <td>成功,计费,其余返回码均不计费</td> </tr> <tr> <td>400</td> <td>参数错误</td> </tr> <tr> <td>404</td> <td>接口地址不正确</td> </tr> <tr> <td>500</td> <td>系统维护,请稍候再试</td> </tr> <tr> <td>601</td> <td>接口未开通</td> </tr> <tr> <td>602</td> <td>账号停用</td> </tr> <tr> <td>603</td> <td>余额不足请充值</td> </tr> <tr> <td>604</td> <td>接口停用</td> </tr> <tr> <td>701</td> <td>包名无权限</td> </tr> <tr> <td>999</td> <td>其他,以实际返回为准</td> </tr> </tbody> </table>

页面列表

ITEM_HTML