bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

如何在Node中使用OCR實現圖像文字識別功能-創新互聯

如何在Node中使用OCR實現圖像文字識別功能?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業的熱愛。我們立志把好的技術通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:申請域名、虛擬空間、營銷軟件、網站建設、永和網站維護、網站推廣。

環境需求

1.Express 是一個非常流行的node.js的web框架。基于connect(node中間件框架)。提供了很多便于處理http請求等web開發相關的擴展。

2.OCR:

通用文字識別 Node SDK目錄結構:

├── src
    │  ├── auth                                //授權相關類
    │  ├── http                                //Http通信相關類
    │  ├── client                              //公用類
    │  ├── util                                //工具類
    │  └── const                               //常量類
    ├── AipOcr.js                      //通用文字識別交互類
    ├── index.js                               //入口文件
    └── package.json                           //npm包描述文件 

支持 node 版本 4.0+
直接使用node開發包步驟如下:

1.在官方網站下載node SDK壓縮包。
2.將下載的aip-node-sdk-version.zip解壓后,復制到工程文件夾中。
3.進入目錄,運行npm install安裝sdk依賴庫
4.把目錄當做模塊依賴

其中,version為版本號,添加完成后,用戶就可以在工程中使用通用文字識別 Node SDK。

直接使用npm安裝依賴:

npm install baidu-aip-sdk(嘗試沒有成功)

AipOcrClient是Optical Character Recognition的node客戶端,為使用Optical Character Recognition的開發人員提供了一系列的交互方法。

用戶可以參考如下代碼新建一個AipOcrClient:

var AipOcrClient = require("baidu-aip-sdk").ocr; 
// 設置APPID/AK/SK 
var APP_ID = "你的 App ID"; 
var API_KEY = "你的 Api Key"; 
var SECRET_KEY = "你的 Secret Key"; 
var client = new AipOcrClient(APP_ID, API_KEY, SECRET_KEY);

express搭建就不再做詳細介紹了,上一篇博客已有哦~~

功能實現

前端上傳圖片后端處理:

router.route("/uploadPhoto").get(function(req,res){ // 到達此路徑則渲染register文件,并傳出title值供 register.html使用
 res.render("uploadPhoto",{title:'圖片文字識別',message:""});
}).post(function(req,res){
 // 跨域
 res.header("Access-Control-Allow-Origin", "*");
 res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");
 res.header("Access-Control-Allow-Headers", "Content-Type,Content-Length, Authorization, Accept,X-Requested-With");

 let form = new formidable.IncomingForm();
 form.encoding = 'utf-8'; // 編碼
 form.keepExtensions = true; // 保留擴展名
 form.maxFieldsSize = 2 * 1024 * 1024; // 文件大小
 form.uploadDir = 'F:/nodejs/ocrCheck/assets/OCR' // 存儲路徑
 form.parse(req,function(err,fileds,files){ // 解析 formData數據
  if(err){ return console.log(err) }

  let imgPath = files.img.path // 獲取文件路徑
  let imgName = "F:/nodejs/ocrCheck/assets/OCR/test." + files.img.type.split("/")[1] // 修改之后的名字
  let data = fs.readFileSync(imgPath) // 同步讀取文件

  fs.writeFile(imgName,data,function(err){ // 存儲文件
   if(err){ return console.log(err) }

   fs.unlink(imgPath,function(){}) // 刪除文件
   //上傳圖片成功返回code:1
   //res.json({code:1})
   global.nodeServer.getResult(res,imgName);
  })
 });
});

圖片處理核心模塊:

module.exports = { 
 getResult : function(res,imgName){
  var image = fs.readFileSync(imgName);
  var base64Img = new Buffer(image).toString('base64');
  client.generalBasic(base64Img).then(function(result) {
   console.log(JSON.stringify(result));
   res.json(result);
  });
 }
}

獲取到的base64圖片數據和res對象作為闡述傳遞給ocr提供好的方法, 回調產生的數據將作為結果返回給前端。

####小彩蛋:

nodeJs中commonJs規范如何實現的?

1.Node程序由許多個模塊組成,每個模塊就是一個文件。Node模塊采用了CommonJS規范。
2.module對象,Node內部提供一個Module構建函數。所有模塊都是Module的實例。每個模塊內部,都有一個module對象,代表當前模塊。它有以下屬性。

module.id 模塊的識別符,通常是帶有絕對路徑的模塊文件名。
module.filename 模塊的文件名,帶有絕對路徑。
module.loaded 返回一個布爾值,表示模塊是否已經完成加載。
module.parent 返回一個對象,表示調用該模塊的模塊。
module.children 返回一個數組,表示該模塊要用到的其他模塊。
module.exports 表示模塊對外輸出的值。

3.調用:根據模塊名稱作為對象調用其內自定義的方法即可。

global.nodeServer.getResult(res,imgName);

看完上述內容,你們掌握如何在Node中使用OCR實現圖像文字識別功能的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注創新互聯行業資訊頻道,感謝各位的閱讀!

當前題目:如何在Node中使用OCR實現圖像文字識別功能-創新互聯
標題來源:http://vcdvsql.cn/article16/csgodg.html

成都網站建設公司_創新互聯,為您提供品牌網站設計網站導航企業網站制作動態網站Google網站營銷

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

網站托管運營