所有文档

          文字识别

          调用方式

          请求格式

          POST方式调用

          注意:Content-Type为application/x-www-form-urlencoded,然后通过urlencode格式化请求体。

          返回格式

          JSON格式

          请求限制

          请求图片需经过base64编码urlencode后传入:图片的base64编码指将一副图片数据编码成一串字符串,使用该字符串代替图像地址。您可以首先得到图片的二进制,然后去掉编码头后再进行urlencode。

          注意

          1. 图片的base64编码是不包含图片头的,如(data:image/jpg;base64,)
          2. 使用 Postman 工具或 Python、PHP 等请求库会自动进行 urlencode,无需自行处理。

          请求格式支持:PNG、JPG、JPEG、BMP、TIFF、PNM、WebP

          接口名称 图片编码后大小限额
          百度文字识别所有接口的图像大小限制 base64编码urlencode后大小不超过4M,最短边至少15px,最长边最大4096px

          调用方式

          调用AI服务相关的API接口有两种调用方式,两种不同的调用方式采用相同的接口URL。

          区别在于请求方式鉴权方法不一样,请求参数和返回结果一致。

          【如果您对于使用API调用的方式很陌生,您可以参见:【只要10分钟 快速掌握文字识别】 教程

          调用方式一

          请求URL数据格式

          向API服务地址使用POST发送请求,必须在URL中带上参数:

          access_token: 必须参数,参考“Access Token获取”。

          注意:access_token的有效期为30天,需要每30天进行定期更换;

          POST中参数按照API接口说明调用即可。

          例如文字识别API,使用HTTPS POST发送:

          https://aip.baidubce.com/rest/2.0/ocr/v1/general?access_token=24.f9ba9c5241b67688bb4adbed8bc91dec.2592000.1485570332.282335-8574074

          获取access_token示例代码

          #!/bin/bash
          curl -i -k 'https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=【百度云应用的AK】&client_secret=【百度云应用的SK】'
          <?php
          function request_post($url = '', $param = '') {
                  if (empty($url) || empty($param)) {
                      return false;
                  }
                  
                  $postUrl = $url;
                  $curlPost = $param;
                  $curl = curl_init();//初始化curl
                  curl_setopt($curl, CURLOPT_URL,$postUrl);//抓取指定网页
                  curl_setopt($curl, CURLOPT_HEADER, 0);//设置header
                  curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);//要求结果为字符串且输出到屏幕上
                  curl_setopt($curl, CURLOPT_POST, 1);//post提交方式
                  curl_setopt($curl, CURLOPT_POSTFIELDS, $curlPost);
                  $data = curl_exec($curl);//运行curl
                  curl_close($curl);
                  
                  return $data;
              }
          
          	$url = 'https://aip.baidubce.com/oauth/2.0/token';
              $post_data['grant_type']       = 'client_credentials';
              $post_data['client_id']      = '你的 Api Key';
              $post_data['client_secret'] = '你的 Secret Key';
              $o = "";
              foreach ( $post_data as $k => $v ) 
              {
              	$o.= "$k=" . urlencode( $v ). "&" ;
              }
              $post_data = substr($o,0,-1);
              
              $res = request_post($url, $post_data);
          
              var_dump($res);
          
          ?>
          package com.baidu.ai.aip.auth;
          
          import org.json.JSONObject;
          
          import java.io.BufferedReader;
          import java.io.InputStreamReader;
          import java.net.HttpURLConnection;
          import java.net.URL;
          import java.util.List;
          import java.util.Map;
          
          /**
           * 获取token类
           */
          public class AuthService {
          
              /**
               * 获取权限token
               * @return 返回示例:
               * {
               * "access_token": "24.460da4889caad24cccdb1fea17221975.2592000.1491995545.282335-1234567",
               * "expires_in": 2592000
               * }
               */
              public static String getAuth() {
                  // 官网获取的 API Key 更新为你注册的
                  String clientId = "百度云应用的AK";
                  // 官网获取的 Secret Key 更新为你注册的
                  String clientSecret = "百度云应用的SK";
                  return getAuth(clientId, clientSecret);
              }
          
              /**
               * 获取API访问token
               * 该token有一定的有效期,需要自行管理,当失效时需重新获取.
               * @param ak - 百度云官网获取的 API Key
               * @param sk - 百度云官网获取的 Securet Key
               * @return assess_token 示例:
               * "24.460da4889caad24cccdb1fea17221975.2592000.1491995545.282335-1234567"
               */
              public static String getAuth(String ak, String sk) {
                  // 获取token地址
                  String authHost = "https://aip.baidubce.com/oauth/2.0/token?";
                  String getAccessTokenUrl = authHost
                          // 1. grant_type为固定参数
                          + "grant_type=client_credentials"
                          // 2. 官网获取的 API Key
                          + "&client_id=" + ak
                          // 3. 官网获取的 Secret Key
                          + "&client_secret=" + sk;
                  try {
                      URL realUrl = new URL(getAccessTokenUrl);
                      // 打开和URL之间的连接
                      HttpURLConnection connection = (HttpURLConnection) realUrl.openConnection();
                      connection.setRequestMethod("GET");
                      connection.connect();
                      // 获取所有响应头字段
                      Map<String, List<String>> map = connection.getHeaderFields();
                      // 遍历所有的响应头字段
                      for (String key : map.keySet()) {
                          System.err.println(key + "--->" + map.get(key));
                      }
                      // 定义 BufferedReader输入流来读取URL的响应
                      BufferedReader in = new BufferedReader(new InputStreamReader(connection.getInputStream()));
                      String result = "";
                      String line;
                      while ((line = in.readLine()) != null) {
                          result += line;
                      }
                      /**
                       * 返回结果示例
                       */
                      System.err.println("result:" + result);
                      JSONObject jsonObject = new JSONObject(result);
                      String access_token = jsonObject.getString("access_token");
                      return access_token;
                  } catch (Exception e) {
                      System.err.printf("获取token失败!");
                      e.printStackTrace(System.err);
                  }
                  return null;
              }
          
          }
          # encoding:utf-8
          import requests 
          
          # client_id 为官网获取的AK, client_secret 为官网获取的SK
          host = 'https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=【官网获取的AK】&client_secret=【官网获取的SK】'
          response = requests.get(host)
          if response:
              print(response.json())
          #include <iostream>
          #include <curl/curl.h>
          #include <json/json.h>
          #include "access_token.h"
          // libcurl库下载链接:https://curl.haxx.se/download.html
          // jsoncpp库下载链接:https://github.com/open-source-parsers/jsoncpp/
          // 获取access_token所需要的url
          const std::string access_token_url = "https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials";
          // 回调函数获取到的access_token存放变量
          // static std::string access_token_result;
          /**
           * curl发送http请求调用的回调函数,回调函数中对返回的json格式的body进行了解析,解析结果储存在result中
           * @param 参数定义见libcurl库文档
           * @return 返回值定义见libcurl库文档
           */
          static size_t callback(void *ptr, size_t size, size_t nmemb, void *stream) {
              // 获取到的body存放在ptr中,先将其转换为string格式
              std::string s((char *) ptr, size * nmemb);
              // 开始获取json中的access token项目
              Json::Reader reader;
              Json::Value root;
              // 使用boost库解析json
              reader.parse(s,root);
              std::string* access_token_result = static_cast<std::string*>(stream);
              *access_token_result = root["access_token"].asString();
              return size * nmemb;
          }
          
          /**
           * 用以获取access_token的函数,使用时需要先在百度云控制台申请相应功能的应用,获得对应的API Key和Secret Key
           * @param access_token 获取得到的access token,调用函数时需传入该参数
           * @param AK 应用的API key
           * @param SK 应用的Secret key
           * @return 返回0代表获取access token成功,其他返回值代表获取失败
           */
          int get_access_token(std::string &access_token, const std::string &AK, const std::string &SK) {
              CURL *curl;
              CURLcode result_code;
              int error_code = 0;
              curl = curl_easy_init();
              if (curl) {
                  std::string url = access_token_url + "&client_id=" + AK + "&client_secret=" + SK;
                  curl_easy_setopt(curl, CURLOPT_URL, url.data());
                  curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0);
                  curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0);
                  std::string access_token_result;
                  curl_easy_setopt(curl, CURLOPT_WRITEDATA, &access_token_result);
                  curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, callback);
                  result_code = curl_easy_perform(curl);
                  if (result_code != CURLE_OK) {
                      fprintf(stderr, "curl_easy_perform() failed: %s\n",
                              curl_easy_strerror(result_code));
                      return 1;
                  }
                  access_token = access_token_result;
                  curl_easy_cleanup(curl);
                  error_code = 0;
              } else {
                  fprintf(stderr, "curl_easy_init() failed.");
                  error_code = 1;
              }
              return error_code;
          }
          using System;
          using System.Collections.Generic;
          using System.Net.Http;
          
          namespace com.baidu.ai
          {
          	public static class AccessToken
          
          	{
          	    // 调用getAccessToken()获取的 access_token建议根据expires_in 时间 设置缓存
          	    // 返回token示例
          		public static String TOKEN = "24.adda70c11b9786206253ddb70affdc46.2592000.1493524354.282335-1234567";
          
                  // 百度云中开通对应服务应用的 API Key 建议开通应用的时候多选服务
          		private static String clientId = "百度云应用的AK";
          		// 百度云中开通对应服务应用的 Secret Key
          		private static String clientSecret = "百度云应用的SK";
          
          		public static String getAccessToken() {
          			String authHost = "https://aip.baidubce.com/oauth/2.0/token";
          			HttpClient client = new HttpClient();
          			List<KeyValuePair<String, String>> paraList = new List<KeyValuePair<string, string>>();
          			paraList.Add(new KeyValuePair<string, string>("grant_type", "client_credentials"));
          			paraList.Add(new KeyValuePair<string, string>("client_id", clientId));
          			paraList.Add(new KeyValuePair<string, string>("client_secret", clientSecret));
          
          			HttpResponseMessage response = client.PostAsync(authHost, new FormUrlEncodedContent(paraList)).Result;
          			String result = response.Content.ReadAsStringAsync().Result;
          			Console.WriteLine(result);
          			return result;
          		}
          	}
          }
          var https = require('https');
          var qs = require('querystring');
          
          const param = qs.stringify({
              'grant_type': 'client_credentials',
              'client_id': '您的 Api Key',
              'client_secret': '您的 Secret Key'
          });
          
          https.get(
              {
                  hostname: 'aip.baidubce.com',
                  path: '/oauth/2.0/token?' + param,
                  agent: false
              },
              function (res) {
                  // 在标准输出中查看运行结果
                  res.pipe(process.stdout);
              }
          );

          说明:方式一鉴权使用的Access_token必须通过API Key和Secret Key获取。

          调用方式二

          请求头域内容

          在请求的HTTP头域中包含以下信息:

          • host(必填)
          • x-bce-date (必填)
          • x-bce-request-id(选填)
          • authorization(必填)
          • content-type(必填)
          • content-length(选填)

          作为示例,以下是一个标准的人脸识别的请求头域内容:

          POST /rest/2.0/face/v1/detect HTTP/1.1
          accept-encoding: gzip, deflate
          x-bce-date: 2015-03-24T13:02:00Z
          connection: keep-alive
          accept: */*
          host: aip.baidubce.com
          x-bce-request-id: 73c4e74c-3101-4a00-bf44-fe246959c05e
          content-type: application/x-www-form-urlencoded
          authorization: bce-auth-v1/46bd9968a6194b4bbdf0341f2286ccce/2015-03-24T13:02:00Z/1800/host;x-bce-date/994014d96b0eb26578e039fa053a4f9003425da4bfedf33f4790882fb4c54903

          说明:方式二鉴权使用的API认证机制authorization必须通过百度云的AK/SK生成。

          上一篇
          简介
          下一篇
          通用场景文字识别