腾讯云直播接入笔记--人脸核身篇

本文记录了在公司直播项目中,如何对接腾讯SDK进行人脸核身的步骤。虽然腾讯的文档质量不高,但其SDK功能齐全。流程包括服务端生成参数并下发,客户端启动SDK进行核身,然后SDK返回结果,服务端再进行结果验证。涉及代码包括配置信息、Nacos配置、人脸核身工具类、Controller接口及实现。
摘要由CSDN通过智能技术生成

公司有直播的需求,选择了对接腾讯的sdk(吐槽一下,腾讯的文档写得是真的垃圾,但是功能倒是挺全的)


人脸核身:

用户首次使用时需要申请直播的开播权限,腾讯刚好有人脸核身的服务,需要在腾讯平台申请信息

由于我们使用的是appsdk 所以需要看的是appsdk 增强版的文档

大概流程是需要由服务端生成并下发参数,客户端获取参数后启动sdk,进行人脸核身,sdk返回人脸核身结果,服务端验证人脸结果


代码:

人脸核身sdk的信息,也就是申请sdk时的信息


@Component

@ConfigurationProperties(prefix = "tencent-faceid")

public class TencentFaceIdInfo {

    // 腾讯人脸核身的访问api

    private String bizTokenUrl;

    //腾讯人脸核身sdkwbappid

    private String WBappid;

    //腾讯人脸核身sdk Secret

    private String secret;

    private String keyLicense;

}

Nacos 上的配置

人脸核身工具类

/**
* @author hzl
* 人脸核身
*/
@Component
@Slf4j
public class TencentFaceIdClient {
   
    @Resource
    private TencentFaceIdInfo tencentFaceIdInfo;
    @Resource
    private TencentLiveInfo tencentLiveInfo;

    private static String ACCESS_TOKEN_URL = "https://miniprogram-kyc.tencentcloudapi.com/api/oauth2/access_token";
    private static String TICKET_URL = "https://miniprogram-kyc.tencentcloudapi.com/api/oauth2/api_ticket";
    private static String SUCCESS = "0";
        


/**
* 获取accessToken
* @return
* @throws Exception
*/
    public String getAccessToken() throws Exception {
   
        HashMap<String,Object> paramMap = new HashMap<>();
        paramMap.put("app_id",tencentFaceIdInfo.getWBappid());
        paramMap.put("secret",tencentFaceIdInfo.getSecret());
        paramMap.put("grant_type","client_credential");
        paramMap.put("version","1.0.0");
        String result = HttpUtil.get(ACCESS_TOKEN_URL, paramMap);
        JSONObject object = JSONObject.parseObject(result);
        String code = object.getString("code");
        if (!SUCCESS.equals(code)){
   
            throw new BizException("请求AccessToken失败");
        }
        return object.getString("access_token");
    }

/**
* 获取SignTicket
* @return
* @throws Exception
*/
    public String getSignTicket(String accessToken) throws Exception {
   
        HashMap<String,Object> paramMap = new HashMap<>();
        paramMap.put("app_id",tencentFaceIdInfo.getWBappid());
        paramMap.put("access_token",accessToken);
        paramMap.put("type","SIGN");
        paramMap.put("version","1.0.0");
        String result = HttpUtil.get(TICKET_URL, paramMap);
        JSONObject object = JSONObject.parseObject(result);
        String code = object.getString("code");
        if (!SUCCESS.equals(code)){
   
            throw new BizException("请求SignTicket失败");
        }
        return object.getJSONArray("tickets").getJSONObject(0).
## 使用前准备​ 1. 前往注册: [腾讯云账号注册](https://cloud.tencent.com/register) (详细指引见 [注册腾讯云](https://cloud.tencent.com/document/product/378/9603)) 2. 取得存储桶名称 **BucketName**: 请前往 [创建存储桶](https://cloud.tencent.com/document/product/460/10637) 3. 取得 **APPID**、**SecretId**、**SecretKey**:请前往 [云API密钥](https://console.cloud.tencent.com/cam/capi) ,点击“新建密钥” ## 快速体验 1. 修改文件 src/main/java/com/qcloud/image/demo/Demo.java 的 main() 方法,填入上述申请到的 **APPID**、**SecretId**、**SecretKey**、**BucketName** 2. 导入到 IDE:工程用 Maven 构建,以 Intellij IDEA 为例,导入方式为:Import Project -> 选择工程目录 -> Import project from external model -> Maven 3. 运行:Demo.java 右键,Run Demo.main() ## 使用简介 ### 初始化 ```java ImageClient imageClient = new ImageClient(APPID, SecretId, SecretKey); ``` ### 设置代理 根据实际网络环境,可能要设置代理,例如: ```java Proxy proxy = new Proxy(Type.HTTP, new InetSocketAddress("127.0.0.1", 8080)); imageClient.setProxy(proxy); ``` ### 使用 SDK 提供功能如下: **图像识别**:鉴黄,标签 **文字识别(OCR)**:身份证,名片,通用,驾驶证行驶证,营业执照,银行卡,车牌号 **人脸识别**:人脸检测,五官定位,个体信息管理,人脸验证,人脸对比及人脸检索 **人脸核身**:照片核身(通过照片和身份证信息),获取唇语验证码(用于活体核身),活体核身(通过视频和照片),活体核身(通过视频和身份证信息) ```java // 调用车牌识别API示例 String imageUrl = "http://youtu.qq.com/app/img/experience/char_general/icon_ocr_license_3.jpg"; String result = imageClient.ocrPlate(new OcrPlateRequest("bucketName", imageUrl)); System.out.println(result); ``` 更多例子详情可参见 [Demo.java](https://github.com/tencentyun/image-java-sdk-v2.0/blob/master/src/main/java/com/qcloud/image/demo/Demo.java) 的代码。 ## 集成到你的项目中 ### 获得 SDK jar 文件 1. 直接使用 release/*-with-dependencies.jar 2. 自行编译:在工程根目录下执行命令 `mvn assembly:assembly`,编译结果见 target/*-with-dependencies.jar ### 导入 jar 文件 根据项目具体情况导入 *-with-dependencies.jar
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值