快速入门
安装OCR Java SDK
OCR Java SDK目录结构
1com.baidu.aip
2 ├── auth //签名相关类
3 ├── http //Http通信相关类
4 ├── client //公用类
5 ├── exception //exception类
6 ├── ocr
7 │ └── AipOcr //AipOcr类
8 └── util //工具类
支持 JAVA版本:1.7+
使用maven依赖:
添加以下依赖即可,其中版本号可在maven官网查询
1<dependency>
2 <groupId>com.baidu.aip</groupId>
3 <artifactId>java-sdk</artifactId>
4 <version>${version}</version>
5</dependency>
直接使用JAR包步骤如下:
1.在官方网站下载Java SDK压缩工具包。
2.将下载的aip-java-sdk-version.zip
解压后,复制到工程文件夹中。
3.在Eclipse右键“工程 -> Properties -> Java Build Path -> Add JARs”。
4.添加SDK工具包aip-java-sdk-version.jar
和第三方依赖工具包json-20160810.jar
slf4j-simple-1.7.25.jar
。
其中,version
为版本号,添加完成后,用户就可以在工程中使用OCR Java SDK。
新建AipOcr
AipOcr是Optical Character Recognition的Java客户端,为使用Optical Character Recognition的开发人员提供了一系列的交互方法。
用户可以参考如下代码新建一个AipOcr,初始化完成后建议单例使用,避免重复获取access_token:
1import java.util.*;
2import org.json.JSONObject;
3import com.baidu.aip.ocr.AipOcr;
4public class Sample {
5 //设置APPID/AK/SK
6 public static final String APP_ID = "你的 App ID";
7 public static final String API_KEY = "你的 Api Key";
8 public static final String SECRET_KEY = "你的 Secret Key";
9
10 public static void main(String[] args) {
11 // 初始化一个AipOcr
12 AipOcr client = new AipOcr(APP_ID, API_KEY, SECRET_KEY);
13
14 // 可选:设置网络连接参数
15 client.setConnectionTimeoutInMillis(2000);
16 client.setSocketTimeoutInMillis(60000);
17
18 // 可选:设置代理服务器地址, http和socket二选一,或者均不设置
19 client.setHttpProxy("proxy_host", proxy_port); // 设置http代理
20 client.setSocketProxy("proxy_host", proxy_port); // 设置socket代理
21
22 // 可选:设置log4j日志输出格式,若不设置,则使用默认配置
23 // 也可以直接通过jvm启动参数设置此环境变量
24 System.setProperty("aip.log4j.conf", "path/to/your/log4j.properties");
25
26 // 调用接口
27 String path = "test.jpg";
28 JSONObject res = client.basicGeneral(path, new HashMap<String, String>());
29 System.out.println(res.toString(2));
30
31 }
32}
其中示例的log4j.properties文件内容如下:
1#可以设置级别:debug>info>error
2#debug:显示debug、info、error
3#info:显示info、error
4#error:只error
5log4j.rootLogger=debug,appender1
6#log4j.rootLogger=info,appender1
7#log4j.rootLogger=error,appender1
8
9#输出到控制台
10log4j.appender.appender1=org.apache.log4j.ConsoleAppender
11#样式为TTCCLayout
12log4j.appender.appender1.layout=org.apache.log4j.PatternLayout
13
14#自定义样式
15# %r 时间 0
16# %t 方法名 main
17# %p 优先级 DEBUG/INFO/ERROR
18# %c 所属类的全名(包括包名)
19# %l 发生的位置,在某个类的某行
20# %m 输出代码中指定的讯息,如log(message)中的message
21# %n 输出一个换行
22
23log4j.appender.appender1.layout.ConversionPattern=[%d{yy/MM/dd HH:mm:ss:SSS}][%t][%p] -%l %m%n
在上面代码中,常量APP_ID
在百度智能云控制台中创建,常量API_KEY
与SECRET_KEY
是在创建完毕应用后,系统分配给用户的,均为字符串,用于标识用户,为访问做签名验证,可在AI服务控制台中的应用列表中查看。
注意:如您以前是百度智能云的老用户,其中API_KEY
对应百度智能云的“Access Key ID”,SECRET_KEY
对应百度智能云的“Access Key Secret”。
配置AipOcr
如果用户需要配置AipOcr的一些细节参数,可以在构造AipOcr之后调用接口设置参数,目前只支持以下参数:
接口 | 说明 |
---|---|
setConnectionTimeoutInMillis | 建立连接的超时时间(单位:毫秒) |
setSocketTimeoutInMillis | 通过打开的连接传输数据的超时时间(单位:毫秒) |
setHttpProxy | 设置http代理服务器 |
setSocketProxy | 设置socket代理服务器 (http和socket类型代理服务器只能二选一) |