当前位置: 首页 > news >正文

Node.js环境调用百度智能云(百度云)api鉴权认证三步走

方式一 :Postman脚本的方式生成v1版本的认证字符串

在这里插入图片描述

Postman脚本下载
下载Postman pre-request Script 设置 Authorization 示例脚本

方式二:在线签名工具生成 (试用于验证编程字符串签名是否有错误)

签名计算工具 https://cloud.baidu.com/signature/index.html

百度智能云提供了在线生成签名工具,用户仅需填写必要请求信息、访问密钥(包含访问密钥ID(AK)和秘密访问密钥(SK)),可快速生成认证字符串。

在这里插入图片描述

方式三 编程生成认证字符串(适合最终集成自己系统)

文档地址 https://cloud.baidu.com/doc/Reference/s/njwvz1yfu go
在这里插入图片描述

你可以运行下面的命令来安装所有依赖:

npm install crypto axios

客悦·智能外呼平台 AIOB 获取机器人列表接口node.js示例代码

// robotList.js
// npm install crypto axios
const crypto = require('crypto');
const axios = require('axios');
const url = require('url');
const util = require('util');

function getUTC() {
  const date = new Date();

  const year = date.getUTCFullYear();
  const month = String(date.getUTCMonth() + 1).padStart(2, '0');
  const day = String(date.getUTCDate()).padStart(2, '0');
  const hours = String(date.getUTCHours()).padStart(2, '0');
  const minutes = String(date.getUTCMinutes()).padStart(2, '0');
  const seconds = String(date.getUTCSeconds()).padStart(2, '0');

  return `${year}-${month}-${day}T${hours}:${minutes}:${seconds}Z`;
}
function generateCanonicalUri(urlString) {
  let parsedUrl = url.parse(urlString, true);
  return parsedUrl.path;
}

/**
 * 获取机器人列表接口
 * GET https://aicc.bce.baidu.com/api/v1/robot/list
 * 文档地址 https://cloud.baidu.com/doc/CCC/s/skt9hds4y
 */
function main() {
  //  1).AK/SK、host、method、URL绝对路径、querystring
  let AK = '<管理后台AccessKey>'; //用户的AK(AccessKey)
  let SK = '<管理后台SecretKey>'; //用户的SK(SecretKey)
  let ccApiAuthV1 = 'cc-api-auth-v1' // Authorization 前缀(bce-auth-v1/cc-api-auth-v1 具体看文档)

  let host = 'aicc.bce.baidu.com';
  let URL = 'api/v1/robot/list';
  let query = '';
  let method = 'GET';

  // 拼接完整的 URL
  let fullURL = `https://${host}/${URL}${query}`;

  const signedHeaders = 'host';
  //  2).x-bce-date
  let x_bce_date = getUTC();
  console.log('UTC 时间:' + x_bce_date);
  //  3).header和signed Headers
  let headers = {
    Host: host,
    'content-type': 'application/json;charset=utf-8',
    'x-bce-date': x_bce_date,
  };
  //  4).认证字符串前缀
  let authStringPrefix = ccApiAuthV1 + '/' + AK + '/' + x_bce_date + '/' + '1800';
  //  5).生成Canonical Request

  //  5).1生成Canonical URL
  let canonicalUri = generateCanonicalUri(fullURL);
  console.log('Canonical Uri: ' + canonicalUri);
  //  5).2生成Canonical QueryString
  let canonicalQueryString = query;
  //  5).3生成Canonical Headers
  // 遍历对象的键值对,并获取键和对应的值
  const canonicalHeaders = `host:${host}`;

  console.log(`Canonical Headers:[${JSON.stringify(canonicalHeaders)}]`);
  //  5).4拼接得到Canonical Request
  const canonicalRequest = method + '\n' + canonicalUri + '\n' + canonicalQueryString + '\n' + canonicalHeaders;
  console.log(`Canonical Request:[${JSON.stringify(canonicalRequest)}]`
  );
  //	6).生成signing Key
  // 生成signingKey
  const signingKey = crypto
    .createHmac('sha256', SK)
    .update(authStringPrefix)
    .digest('hex');
  console.log(`signingKey: ${signingKey}`);
  // 生成Signature
  const signature = crypto
    .createHmac('sha256', signingKey)
    .update(canonicalRequest)
    .digest('hex');
  console.log(`Signature: ${signature}`);
  //	8).生成Authorization并放到header里
  headers['Authorization'] = `${authStringPrefix}/${signedHeaders}/${signature}`;
  console.log(headers['Authorization']);
  //	9).发送API请求并接受响应
  // 发送 Axios 请求

  axios
    .request({
      method: method,
      url: fullURL,
      headers: headers,
    })
    .then(response => {
      console.log('Response:', util.inspect(response.data, false, null, true));
    })
    .catch(error => {
      console.error('Error:', error.response.data);
    });
}

main();

相关文章:

  • 北航计算机软件技术基础课程作业笔记【3】
  • Java项目:基于Springboot+vue实现的中国陕西民俗前后台管理系统设计与实现(源码+数据库+毕业论文)
  • ICP配准算法
  • 计算机专业,不擅长打代码,考研该怎么选择?
  • 数据结构—红黑树
  • ThreadLocal加切面实现线程级别的方法缓存
  • QT 线程的使用
  • PDF锐化
  • 【运输层】传输控制协议 TCP
  • easyExcel - 动态复杂表头的编写
  • leetcode热题HOT146. LRU 缓存
  • 【简单讲解下Kotlin】
  • 蓝桥杯 - 受伤的皇后
  • redis的三大模式的演化及集群模式思考和总结
  • Git汇总
  • 【开源书籍】深入讲解内核网络、Kubernetes、ServiceMesh、容器等云原生相关技术。
  • JavaIO输入输出
  • 企业如何设计和实施有效的网络安全演练?
  • 大话设计模式——六大基本设计原则(SOLID原则)
  • 【C语言】扫雷小游戏
  • https://app.hackthebox.com/machines/Inject
  • Spring —— Spring简单的读取和存储对象 Ⅱ
  • 渗透测试之冰蝎实战
  • Mybatis、TKMybatis对比
  • Microsoft Office 2019(2022年10月批量许可版)图文教程
  • 《谷粒商城基础篇》分布式基础环境搭建
  • 哈希表题目:砖墙
  • Vue 3.0 选项 生命周期钩子
  • 【车载嵌入式开发】AutoSar架构入门介绍篇
  • 【计算机视觉 | 目标检测】DETR风格的目标检测框架解读