WebApiClientCore

WebApiClient.JIT/AOT的netcore版本,集高性能高可扩展性于一体的声明式http客户端库,特别适用于微服务的restful资源请求,也适用于各种畸形http接口请求。

百度AI

百度AI目前相当开放(至少在使用上),如果不是高并发请求场景,一般免费使用即可。鉴于其提供的.net sdk比较先进(laji),使用Dictionary类型替代模型参数,以及使用万能的JObject类型做为返回值类型的设计,正常人都无法体会其中精髓。试看以下的api原型,想必大家都想找找没有文档说明吧?我觉得这sdk更像是一个httpUtil,只提供了一个 object Send( object )方法。

public JObject Detect(string image, string imageType, Dictionary<string, object> options = null);

小牛试刀

今天我们抛开官方SDK,使用WebApiClientCore请求我们感兴趣的人脸检测接口,虽然只有一个接口,但我会尽量按高规格的设计质量来调用这个接口,让朋友们了解WebApiClientCore的魅力之处。首先,我们先阅读官方文档:Api文档.人脸检测,根据文档内容,大概有以下知识块:

  • access_token获取与使用
  • access_token的过期与刷新
  • 请求参数模型
  • 正确的响应结果模型
  • 人脸识别错误码

模型设计

请求参数模型

为了使用方便,我们将图片类型、人脸类型设计为枚举类型,注意实际请求时,传输的是枚举的键名,而不是值。

/// <summary>
/// 表示待人脸检测的图片
/// </summary>
public class DetectImage
{
/// <summary>
/// 图片信息
/// </summary>
public string Image { get; set; } /// <summary>
/// 图片信息
/// </summary>
[JsonConverter(typeof(JsonStringEnumConverter))]
public ImageType Image_type { get; set; } /// <summary>
/// 最多处理人脸的数目
/// </summary>
[Range(1, 10)]
public int? Max_face_num { get; set; } = 1; /// <summary>
/// 人脸的类型
/// </summary>
[JsonConverter(typeof(JsonStringEnumConverter))]
public FaceType Face_type { get; set; } /// <summary>
/// 图像类型
/// </summary>
public enum ImageType
{
/// <summary>
/// 图片的base64值
/// </summary>
BASE64,
/// <summary>
/// 图片的 URL地址
/// </summary>
URL,
/// <summary>
/// 人脸图片的唯一标识
/// </summary>
FACE_TOKEN
} /// <summary>
/// 人脸的类型
/// </summary>
public enum FaceType
{
/// <summary>
/// 生活照
/// </summary>
LIVE,
/// <summary>
/// 身份证芯片照
/// </summary>
IDCARD,
/// <summary>
/// 带水印证件照
/// </summary>
WATERMARK,
/// <summary>
/// 证件照片
/// </summary>
CERT
}
}

响应模型

通过PostMan预请求,我们发现官方文档里提到的响应内容,实际上只是完整响应内容的里面的Result值而已(官方文档有点不靠谱) 。

/// <summary>
/// 响应内容
/// </summary>
/// <typeparam name="T"></typeparam>
public class Response<T>
{
/// <summary>
/// 错误码
/// </summary>
public int Error_code { get; set; } /// <summary>
/// 错误信息
/// </summary>
public string Error_msg { get; set; } /// <summary>
/// 结果值
/// </summary>
public T Result { get; set; }
} /// <summary>
/// 表示检测结果
/// </summary>
public class DetectResult
{
/// <summary>
/// 人脸数量
/// </summary>
public int Face_num { get; set; } /// <summary>
/// 人脸列表
/// </summary>
public FaceItem[] Face_list { get; set; } /// <summary>
/// 人脸
/// </summary>
public class FaceItem
{
public string Face_token { get; set; } public FaceLocation Location { get; set; } public int Face_probability { get; set; } public FaceAngle Angle { get; set; } /// <summary>
/// 位置
/// </summary>
public class FaceLocation
{
public double Left { get; set; }
public double Top { get; set; }
public int Width { get; set; }
public int Height { get; set; }
public int Rotation { get; set; }
} /// <summary>
/// 角度
/// </summary>
public class FaceAngle
{
public double Yaw { get; set; }
public double Pitch { get; set; }
public double Roll { get; set; }
}
}
}

接口声明

应用请求与响应模型

/// <summary>
/// 百度人脸相关接口
/// </summary>
public interface IBaiduFaceApi
{
/// <summary>
/// 图像的人脸检测
/// </summary>
/// <param name="detectImage">待检测图像</param>
/// <returns></returns>
[HttpPost("rest/2.0/face/v3/detect")]
ITask<Response<DetectResult>> DetectAsync([JsonContent] DetectImage detectImage);
}

应用请求日志

为了方便调试,我们需要将实际请求内容输出到日志组件,这里为接口应用[LoggingFilter]。

/// <summary>
/// 百度人脸相关接口
/// </summary>
[LoggingFilter]
public interface IBaiduFaceApi
{
/// <summary>
/// 图像的人脸检测
/// </summary>
/// <param name="detectImage">待检测图像</param>
/// <returns></returns>
[HttpPost("rest/2.0/face/v3/detect")]
ITask<Response<DetectResult>> DetectAsync([JsonContent] DetectImage detectImage);
}

应用access_token

access_token我们可以做为一个切面处理,WebApiClientCore.Extensions.OAuths扩展包专门处理这个切面,由于百度的access_token不是标准的放到Authorization请求头,而是放到access_token的query参数,所以我们需要继承ClientCredentialsTokenAttribute来实现自定义token应用特性。

/// <summary>
/// token应用特性
/// </summary>
class AccessTokenAttribute : ClientCredentialsTokenAttribute
{
protected override void UseTokenResult(ApiRequestContext context, TokenResult tokenResult)
{
context.HttpContext.RequestMessage.AddUrlQuery("access_token", tokenResult.Access_token);
}
} /// <summary>
/// 百度人脸相关接口
/// </summary>
[AccessToken]
[LoggingFilter]
public interface IBaiduFaceApi
{
/// <summary>
/// 图像的人脸检测
/// </summary>
/// <param name="detectImage">待检测图像</param>
/// <returns></returns>
[HttpPost("rest/2.0/face/v3/detect")]
ITask<Response<DetectResult>> DetectAsync([JsonContent] DetectImage detectImage);
}

接口注册与配置

接口注册

services.AddHttpApi<IBaiduFaceApi>(c =>
{
c.HttpHost = new Uri("https://aip.baidubce.com/");
});

token提供者配置

百度返回的token有refreshToken值,但文档里没有提到怎么刷新token,尝试使用token请求地址去刷新token会失败,所以这里直接配置禁用使用refreshToken的功能,强迫时间到期之后,重新去申请一次token。

services.AddClientCredentialsTokenProvider<IBaiduFaceApi>(c =>
{
c.Endpoint = new Uri("https://aip.baidubce.com/oauth/2.0/token");
c.UseRefreshToken = false;
c.Credentials.Client_id = "API Key";
c.Credentials.Client_secret = "Secret Key";
});

接口调用

将IBaiduFaceApi注入到我们的服务,即可调用

public class FaceService
{
private readonly IBaiduFaceApi baiduFaceApi; public FaceService(IBaiduFaceApi baiduFaceApi)
{
this.baiduFaceApi = baiduFaceApi;
} public async Task DetectAsync()
{
var img = new DetectImage
{
Face_type = DetectImage.FaceType.IDCARD,
Image = "http://xxx.jpg",
Image_type = DetectImage.ImageType.URL
};
var result = await baiduFaceApi.DetectAsync(img);
}
}

现在,我们已经拿到正常的结果,顺便查看请求日志确认请求是否正确。

POST /rest/2.0/face/v3/detect?access_token=省略值 HTTP/1.1
Host: aip.baidubce.com
User-Agent: WebApiClientCore/1.0.6.0
Accept: application/json; q=0.01, application/xml; q=0.01
Content-Type: application/json; charset=utf-8 {"image":"http://xxx.jpg","image_type":"URL","max_face_num":1,"face_type":"IDCARD"}
HTTP/1.1 200 OK
Connection: keep-alive
Date: Thu, 23 Jul 2020 02:05:58 GMT
Content-Type: application/json
Content-Length: 328 {"error_code":0,"error_msg":"SUCCESS","log_id":2599254579794,"timestamp":1595469958,"cached":0,"result":{"face_num":1,"face_list":[{"face_token":"97071a7f306483fea94d0766cfeb120c","location":{"left":34.54,"top":74.23,"width":101,"height":101,"rotation":0},"face_probability":1,"angle":{"yaw":-0.92,"pitch":6.68,"roll":-3.72}}]}}

结束语

以上为WebApiClientCore在百度Ai请求的一个小例子,当然WebApiClientCore还有好多功能,点击项目链接,带你GET到N种使用技能,不求star,只求提供良好建议。

https://github.com/dotnetcore/WebApiClient

WebApiClientCore简约调用百度AI接口的更多相关文章

  1. 使用百度ai接口加图灵机器人完成简单web版语音对话

    app文件 from flask import Flask, request, render_template, jsonify, send_file from uuid import uuid4 i ...

  2. django--调用百度AI接口实现人脸注册登录

    面部识别----考勤打卡.注册登录.面部支付等等...感觉很高大上,又很方便,下面用python中的框架--django完成一个注册登录的功能,调用百度AI的接口,面部识别在网上也有好多教程,可以自己 ...

  3. js调用百度地图接口

    原文:js调用百度地图接口 这是前几天公司做的新项目,上面需要用到地图的数据.第一次做这类型的东西没啥思路,咱们经理说,这东西简单,截个图存文件夹里调整好尺寸,数据库里存上图片的地址动态调用就行了.心 ...

  4. Winform调用百度地图接口简单示例

    1.首先用一个html文件调用百度地图接口(主要注册一个序列号):   <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitiona ...

  5. [初识]使用百度AI接口,图灵机器人实现简单语音对话

    一.准备 1.百度ai开放平台提供了优质的接口资源https://ai.baidu.com/  (基本免费) 2.在语音识别的接口中, 对中文来说, 讯飞的接口是很好的选择https://www.xf ...

  6. Excel催化剂开源第25波-Excel调用百度AI,返回AI结果

    现成的这些轮子,无需调用网页,直接本地离线即可生成). 当然在AI时代,少不了各种AI接口的使用场景,普通开发者只需聚焦在自己的业务场景上,这些AI底层技术,只需类似水煤电一般去BAT这些大厂那里去消 ...

  7. Winform调用百度地图接口

    using System; using System.IO; using System.Collections.Generic; using System.ComponentModel; using ...

  8. 人工智能-调百度AI接口+图灵机器人

    1.登陆百度AI的官网 1.注册:没有账号注册 2.创建应用 3.创建应用 4.查看应用的ID 5.Python代码 from aip import AipSpeech APP_ID = " ...

  9. 基于flask和百度AI接口实现前后端的语音交互

    话不多说,直接怼代码,有不懂的,可以留言 简单的实现,前后端的语音交互. import os from uuid import uuid4 from aip import AipSpeech from ...

随机推荐

  1. 3、尚硅谷_SSM高级整合_使用ajax操作实现增加员工的功能

    20.尚硅谷_SSM高级整合_新增_创建员工新增的模态框.avi 1.接下来当我们点击增加按钮的时候会弹出一个员工信息的对话框 知识点1:当点击新增的时候会弹出一个bootstrap的一个模态对话框 ...

  2. Jmeter系列(29)- 详解 JDBC Connection Configuration

    如果你想从头学习Jmeter,可以看看这个系列的文章哦 https://www.cnblogs.com/poloyy/category/1746599.html 前言 发起 jdbc 请求前,需要有 ...

  3. web如何测试

    当我们负责web测试的时候,先了解B/S架构,然后分析如何开始执行测试,一般步骤:从功能测试,兼容测试,安全测试. 功能测试: 一.链接测试,链接是web应用系统的一个很重要的特征,主要是用于页面之间 ...

  4. 如何在一个HTML文件中嵌套另一个HTML文件并且可以进行切换HTML文件

    使用iframe 要点:a标签+iframe A标签的target属性 iframe 的id与name属性 示例: <!DOCTYPE html> <html> <hea ...

  5. 怎样用 I/O流读取txt文件?

    java.io包提供了用来永久保存对象状态的机制,可处理各种类型的流,如文件流.字节流.字符流等,还提供实现可串行化Serializable接口.可处理对象流. Java语言提供3种自动生成的标准流. ...

  6. GRpc异常处理Filter

    全局错误处理服务端 微软已经实施了Interceptors,它们类似于Filter或Middlewares在ASP.NET MVC的核心或的WebAPI,它们可以用于全局异常处理,日志记录,验证等. ...

  7. 手写SpringMVC框架(一)-------项目搭建

    SpringMVC处理请求的大致流程: 我们来开始着手手写一个SpringMVC框架. 新建一个springMVC项目,流程参见 SpringMVC框架搭建流程 引入servlet相关的jar包: & ...

  8. 每天一个Linux命令(ls)

    前提 文件路径的描述方式   只有1个盘,叫根目录/   绝对路径:从根目录开始描述的文件路径描述方式,如/a/b/c.以/打头的路径描写法一定是绝对路径   相对路径:以相对于当前路径的文件路径描述 ...

  9. MySQL实验 子查询优化双参数limit

    MySQL实验 子查询优化双参数limit 没想到双参数limit还有优化的余地,为了亲眼见到,今天来亲自实验一下.   实验准备 使用MySQL官方的大数据库employees进行实验,导入该示例库 ...

  10. P3295 萌萌哒 题解

    题目 一个长度为n的大数,用\(S_1,S_2,S_3...S_n\)表示,其中\(S_i\)表示数的第\(i\)位,\(S_1\)是数的最高位,告诉你一些限制条件,每个条 件表示为四个数,\(l_1 ...