java实现百度云文字识别接口代码
本文实例为大家分享了java实现百度云文字识别的接口具体代码,供大家参考,具体内容如下
publicclassImages{
publicstaticStringgetResult(){
StringotherHost="https://aip.baidubce.com/rest/2.0/ocr/v1/general";
//本地图片路径
Stringstr="你的本地图片路径"
StringfilePath="str";
try{
byte[]imgData=FileUtil.readFileByBytes(filePath);
StringimgStr=Base64Util.encode(imgData);
Stringparams=URLEncoder.encode("image","UTF-8")+"="+URLEncoder.encode(imgStr,"UTF-8");
/**
*access_token有过期时间,客户端可自行缓存,过期后重新获取。
*/
StringaccessToken=getAuth("申请的apikey","申请的secretkey");
//System.out.println("wwwwwwwwwwwwww");
Stringresult=HttpUtil.post(otherHost,accessToken,params);
//System.out.println("sssssssssssssssssss");
returnresult;
//System.out.println(result);
}catch(Exceptione){
e.printStackTrace();
returnnull;
}
}
publicstaticStringgetAuth(Stringak,Stringsk){
//获取token地址
StringauthHost="https://aip.baidubce.com/oauth/2.0/token?";
StringgetAccessTokenUrl=authHost
//1.grant_type为固定参数
+"grant_type=client_credentials"
//2.官网获取的APIKey
+"&client_id="+ak
//3.官网获取的SecretKey
+"&client_secret="+sk;
try{
URLrealUrl=newURL(getAccessTokenUrl);
//打开和URL之间的连接
HttpURLConnectionconnection=(HttpURLConnection)realUrl.openConnection();
connection.setRequestMethod("GET");
connection.connect();
//获取所有响应头字段
Map>map=connection.getHeaderFields();
//遍历所有的响应头字段
for(Stringkey:map.keySet()){
System.err.println(key+"--->"+map.get(key));
}
//定义BufferedReader输入流来读取URL的响应
BufferedReaderin=newBufferedReader(newInputStreamReader(connection.getInputStream()));
Stringresult="";
Stringline;
while((line=in.readLine())!=null){
result+=line;
}
/**
*返回结果示例
*/
System.out.println("result:"+result);
JSONObjectjsonObject=newJSONObject(result);
Stringaccess_token=jsonObject.getString("access_token");
returnaccess_token;
}catch(Exceptione){
System.err.printf("获取token失败!");
e.printStackTrace(System.err);
}
returnnull;
}
}
测试:
publicstaticvoidmain(String[]args){
StringotherHost="https://aip.baidubce.com/rest/2.0/ocr/v1/general";
//本地图片路径
StringfilePath="本地图片路径";
try{
byte[]imgData=FileUtil.readFileByBytes(filePath);
StringimgStr=Base64Util.encode(imgData);
Stringparams=URLEncoder.encode("image","UTF-8")+"="+URLEncoder.encode(imgStr,"UTF-8");
*//**
*线上环境access_token有过期时间,客户端可自行缓存,过期后重新获取。
*//*
StringaccessToken=getAuth("apikey","secretkey");
//System.out.println("wwwwwwwwwwwwww");
Stringresult=HttpUtil.post(otherHost,accessToken,params);
//System.out.println("sssssssssssssssssss");
System.out.println(result);
}catch(Exceptione){
e.printStackTrace();
}
}
小编再另分享一份网上找到的代码,百度云OCR文字识别功能,作者是:笑释一切。
importjava.util.HashMap; importjava.util.Iterator; importorg.json.JSONArray; importorg.json.JSONObject; importcom.baidu.aip.ocr.AipOcr; /** *测试百度云OCR的文字识别功能
*打开百度云AI的官网:
*https://console.bce.baidu.com/ai/?_=1517288853048#/ai/ocr/overview/index
*/ publicclassTestOcr{ //设置APPID/AK/SK publicstaticfinalStringAPP_ID="10736110"; publicstaticfinalStringAPI_KEY="4nguIG7OdpHZFhdFnz2AbVhx"; publicstaticfinalStringSECRET_KEY="8GnUzj19H0Nie5nOc7HSGSH2VigjU9VL"; publicstaticvoidmain(String[]args){ //初始化一个AipOcr AipOcrclient=newAipOcr(APP_ID,API_KEY,SECRET_KEY); //传入可选参数调用接口 HashMapoptions=newHashMap (); //是否定位单字符位置,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); //调用接口 Stringpath="D:\\QQ截图20180130134257.png"; JSONObjectres=client.accurateGeneral(path,options); JSONArraymyJson=res.getJSONArray("words_result"); Iterator
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。