如何调用百度API,实现文字识别?【超详细】

因为毕设要做网站,但是无奈导师说,如果做web或者APP,就必须要加入一些新颖的功能,比如文字识别、图像识别、人脸识别,看了别人的博客,但是还是决定做一期这样的内容,老规矩~~~大神绕道。
  另外说这个api还挺好用的,可以身份证识别、发票识别、图像识别、人脸识别、自定义识别,很多很多~
--------------------------------------------分割线--------------------------------------------
  首先,你要先在百度的AI开放平台中有自己的账号啦~附上链接 https://ai.baidu.com/
用自己的百度账号就能登录。。

登录后在首页的右上角有个控制台,点进去
在这里插入图片描述
  点进去后,右侧栏有个文字识别,点击
在这里插入图片描述
 点进去后创建应用,,填好相关信息,然后点击管理应用得到如下界面,注意,一会要用到其中的AppID、API Key、Secret Key(点击显示就能看到)。

好了,这时候到代码部分了,在eclipse或者idea新建工程,new一个java的class,然后导入jar包(也就是sdk,我会给资源)。

我们回到刚刚的百度智能云,①点击右侧的文字识别—》②点击技术文档—》点击右侧栏的API文档,我们点击我们想要实现的功能,这里用票据文字识别为例。

点击火车票识别,我们把页面往下拉,找到代码,点击java的代码,代码如下

package com.baidu.ai.aip;

import com.baidu.ai.aip.utils.Base64Util;
import com.baidu.ai.aip.utils.FileUtil;
import com.baidu.ai.aip.utils.HttpUtil;

import java.net.URLEncoder;

/**
* 火车票识别
*/
public class TrainTicket {

    /**
    * 重要提示代码中所需工具类
    * FileUtil,Base64Util,HttpUtil,GsonUtils请从
    * https://ai.baidu.com/file/658A35ABAB2D404FBF903F64D47C1F72
    * https://ai.baidu.com/file/C8D81F3301E24D2892968F09AE1AD6E2
    * https://ai.baidu.com/file/544D677F5D4E4F17B4122FBD60DB82B3
    * https://ai.baidu.com/file/470B3ACCA3FE43788B5A963BF0B625F3
    * 下载
    */
    public static String trainTicket() {
        // 请求url
        String url = "https://aip.baidubce.com/rest/2.0/ocr/v1/train_ticket";
        try {
            // 本地文件路径
            String filePath = "[本地文件路径]";
            byte[] imgData = FileUtil.readFileByBytes(filePath);
            String imgStr = Base64Util.encode(imgData);
            String imgParam = URLEncoder.encode(imgStr, "UTF-8");

            String param = "image=" + imgParam;

            // 注意这里仅为了简化编码每一次请求都去获取access_token,线上环境access_token有过期时间, 客户端可自行缓存,过期后重新获取。
            String accessToken = "[调用鉴权接口获取的token]";

            String result = HttpUtil.post(url, accessToken, param);
            System.out.println(result);
            return result;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }

    public static void main(String[] args) {
        TrainTicket.trainTicket();
    }
}

我们只需把里面的trainTicket()方法copy到咱们刚刚在eclipse新建好的java文件里

咱们来看这里面的代码:

  • String url = “https://aip.baidubce.com/rest/2.0/ocr/v1/train_ticket”; ----》 这是调用的百度的API的链接.
  • String filePath = “[本地文件路径]”;–>在双引号内填入你要识别的车票的url。
  • String accessToken = “[调用鉴权接口获取的token]”; —》这里要填入accessToken码
    在上面的第三点中,accessToken需要用咱们的前文提到的AppID、API Key、Secret Key生成,咱们新建一个class,用于生成accessToken,代码如下:
package com.zhj;

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;

/**
 * @ClassName TestText
 * @Description: TODO
 * @Author 欧后成
 * @Date 2020/3/6
 * @Version V1.0
 **/
public class TestAccessToken {
    public static void main(String[] args) {
        String auth1 = getAuth("04cmXtloX5i0VagdG2N4qA3P", "l15v62nFyxfrsmqA5Sdyl3LgXCbNgR4e");
        System.out.println(auth1);
    }
    /**
     * 获取权限token
     * @return 返回示例:
     * {
     * "access_token": "24.460da4889caad24cccdb1fea17221975.2592000.1491995545.282335-1234567",
     * "expires_in": 2592000
     * }
     */
    public static String getAuth() {
        // 官网获取的 API Key 更新为你注册的
        String clientId = "zgmFnyklFU5eVWbZS20wyf9E";
        // 官网获取的 Secret Key 更新为你注册的
        String clientSecret = "RA3W9H5dRiEqwOGKbuxGOg79zvGmTKao";
        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;
    }

}

我们截取上面程序的这段代码
String auth1 = getAuth(“04cmXtloX5i0VagdG2N4qA3P”, “l15v62nFyxfrsmqA5Sdyl3LgXCbNgR4e”);
第一个参数换成我们的API Key,第二个参数换成咱们的Secret Key,运行程序,得到我们专属的access_token,这个码会过期,不过过期时间好像可以设置,具体我就不
清楚了。

运行我们第一次建的主程序(main方法自己写啦,调用trainTicket()方法输出结果),就可以得到我们的识别结果。

返回示例

{
	{
	"errno":"0",
	"logid":"55481588484",
	"date":"2017年12月11日",
	"destination_station":"嘉善南站",
	"name":"刘虎",
	"seat_category":"二等座",
	"starting_station":"上海虹桥站",
	"ticket_num":"Z13N025800",
	"ticket_rates":"¥24.0元",
	"train_num":"D3125"
	}
}

返回参数

参数 类型 是否必须 说明
log_id uint64 请求标识码,随机数,唯一。
ticket_num string 车票号
starting_station string 始发站
train_num string 车次号
destination_station string 到达站
date string 出发日期
ticket_rates string 车票金额
seat_category string 席别
name string 乘客姓名

好了,觉得有用的话给个赞和评论吧。。。。。

发布了16 篇原创文章 · 获赞 23 · 访问量 3458

猜你喜欢

转载自blog.csdn.net/weixin_40032967/article/details/104739059