好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

java实现百度云文字识别接口代码

本文实例为大家分享了java实现百度云文字识别的接口具体代码,供大家参考,具体内容如下

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

public class images {

 

   public static string getresult() {

   string otherhost = "https://aip.baidubce.com/rest/2.0/ocr/v1/general" ;

    // 本地图片路径

 

   string str= "你的本地图片路径"

 

    string filepath = "str" ;

    try {

     byte [] imgdata = fileutil.readfilebybytes(filepath);

     string imgstr = base64util.encode(imgdata);

     string params = urlencoder.encode( "image" , "utf-8" ) + "=" + urlencoder.encode(imgstr, "utf-8" );

     /**

     * access_token有过期时间, 客户端可自行缓存,过期后重新获取。

     */

     string accesstoken = getauth( "申请的api key" , "申请的secret key" );

 

     //system.out.println("wwwwwwwwwwwwww");

     string result = httputil.post(otherhost, accesstoken, params);

     //system.out.println("sssssssssssssssssss");

     return result;

     //system.out.println(result);

    } catch (exception e) {

     e.printstacktrace();

     return null ;

    }

  

   }

   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.out.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 ;

   }

}

测试:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

public static void main(string[] args) {

   

   string otherhost = "https://aip.baidubce.com/rest/2.0/ocr/v1/general" ;

    // 本地图片路径

    string filepath = "本地图片路径" ;

    try {

     byte [] imgdata = fileutil.readfilebybytes(filepath);

     string imgstr = base64util.encode(imgdata);

     string params = urlencoder.encode( "image" , "utf-8" ) + "=" + urlencoder.encode(imgstr, "utf-8" );

     * //**

      * 线上环境access_token有过期时间, 客户端可自行缓存,过期后重新获取。

      * //*

     string accesstoken = getauth( "api key" , "secret key" );

     //system.out.println("wwwwwwwwwwwwww");

     string result = httputil.post(otherhost, accesstoken, params);

     //system.out.println("sssssssssssssssssss");

     system.out.println(result);

    } catch (exception e) {

     e.printstacktrace();

    }

  }

小编再另分享一份网上找到的代码,百度云ocr文字识别功能,作者是:笑释一切。

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

import java.util.hashmap;

import java.util.iterator;

 

import org.json.jsonarray;

import org.json.jsonobject;

import com.baidu.aip.ocr.aipocr;

 

/**

  * 测试百度云ocr的文字识别功能 <br>

  * 打开百度云ai的官网: <br>

  * https://console.bce.baidu.com/ai/?_=1517288853048#/ai/ocr/overview/index <br>

  */

public class testocr {

 

  //设置app id/ak/sk

  public static final string app_id = "10736110" ;

  public static final string api_key = "4nguig7odphzfhdfnz2abvhx" ;

  public static final string secret_key = "8gnuzj19h0nie5noc7hsgsh2vigju9vl" ;

 

  public static void main(string[] args) {

 

   // 初始化一个aipocr

   aipocr client = new aipocr(app_id, api_key, secret_key);

 

   // 传入可选参数调用接口

   hashmap<string, string> options = new hashmap<string, string>();

   // 是否定位单字符位置,big:不定位单字符位置,默认值;small:定位单字符位置

   options.put( "recognize_granularity" , "big" );

   // 识别语言类型,默认为chn_eng。可选值包括:

   // chn_eng:中英文混合;

   // eng:英文;

   // por:葡萄牙语;

   // fre:法语;

   // ger:德语;

   // ita:意大利语;

   // spa:西班牙语;

   // rus:俄语;

   // jap:日语;

   // kor:韩语;

   options.put( "language_type" , "chn_eng" );

   // 是否检测图像朝向,默认不检测,即:false。朝向是指输入图像是正常方向、逆时针旋转90/180/270度。

   options.put( "detect_direction" , "true" );

   // 是否检测语言,默认不检测。当前支持(中文、英语、日语、韩语)

   options.put( "detect_language" , "true" );

   // 是否返回文字外接多边形顶点位置,不支持单字位置。默认为false

   options.put( "vertexes_location" , "false" );

   // 是否返回识别结果中每一行的置信度

   options.put( "probability" , "false" );

 

   // 可选:设置网络连接参数

   client.setconnectiontimeoutinmillis( 2000 );

   client.setsockettimeoutinmillis( 60000 );

 

   // 调用接口

   string path = "d:\\qq截图20180130134257.png" ;

   jsonobject res = client.accurategeneral(path, options);

   jsonarray myjson = res.getjsonarray( "words_result" );

   iterator<object> iterator = myjson.iterator();

   while (iterator.hasnext()){

    object value = iterator.next();

    jsonobject obj = new jsonobject(value.tostring());

    system.out.println(obj.get( "words" ));

   }

 

  }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

原文链接:https://blog.csdn.net/syy363250763/article/details/80843480

查看更多关于java实现百度云文字识别接口代码的详细内容...

  阅读:11次