亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue+Java+Base64實(shí)現(xiàn)條碼解析的示例

 更新時(shí)間:2020年09月23日 08:56:27   作者:Mr_Bingzi  
這篇文章主要介紹了Vue+Java+Base64實(shí)現(xiàn)條碼解析的示例,幫助大家實(shí)現(xiàn)條碼解析,感興趣的朋友可以了解下

前端部分(Vue + Vant)

  • 引入Vant、使用Vant中的Uploader組件上傳文件(支持手機(jī)拍照)
import Vue from 'vue' 
import { Uploader } from 'vant' 
Vue.use(Uploader);
  • 使用Uploader上傳組件
 <van-uploader>
  <van-button icon="plus" type="primary" :after-read="afterRead">    
   上傳文件(識(shí)別條碼)
 </van-button>
 </van-uploader>
  • js部分、文件上傳完畢后會(huì)觸發(fā) after-read 回調(diào)函數(shù),獲取到對(duì)應(yīng)的 file 對(duì)象。
afterRead(file) {
  var self = this;
  //調(diào)用上傳回調(diào)函數(shù) - upload
  this.upLoad(this.$baseUrl + "upload/uploadParsing", file,
  function (response) {
    if( response.msg.length >0){
     console.log(response.msg)
    }else{
      Toast.fail('識(shí)別失敗,請(qǐng)重新上傳條碼!',3500)
    }
   });  

 },
 
 upLoad(url, file, func) {
    var fileBase64 =''
    // 創(chuàng)建Canvas對(duì)象(畫(huà)布)
    debugger
    let canvas = document.createElement("canvas");
    // 獲取對(duì)應(yīng)的CanvasRenderingContext2D對(duì)象(畫(huà)筆)
    let context = canvas.getContext("2d");
    // 創(chuàng)建新的圖片對(duì)象
    let img = new Image();
    // 指定圖片的DataURL(圖片的base64編碼數(shù)據(jù))
    img.src = file.content;
    // 監(jiān)聽(tīng)瀏覽器加載圖片完成,然后進(jìn)行進(jìn)行繪制
    img.onload = () => {
      // 指定canvas畫(huà)布大小,該大小為最后生成圖片的大小
      canvas.width = 400;
      canvas.height = 300;
      /* drawImage畫(huà)布繪制的方法。(0,0)表示以Canvas畫(huà)布左上角為起點(diǎn),400,300是將圖片按給定的像素進(jìn)行縮小。
      如果不指定縮小的像素圖片將以圖片原始大小進(jìn)行繪制,圖片像素如果大于畫(huà)布將會(huì)從左上角開(kāi)始按畫(huà)布大小部分繪制圖片,最后的圖片就是張局部圖。*/
 
      context.drawImage(img, 0, 0, 400, 300);
      // 將繪制完成的圖片重新轉(zhuǎn)化為base64編碼,file.file.type為圖片類(lèi)型,0.92為默認(rèn)壓縮質(zhì)量
      file.content = canvas.toDataURL(file.file.type, 0.92);
      fileBase64 = file.content
      // 最后將base64編碼的圖片保存到數(shù)組中,留待上傳。43      console.log(fileBase64)
      //查詢(xún)字典值
      this.$axios.post(url,{'fileBase64Code' :fileBase64})
      .then(function (response) {
       func(response.data);
      }.bind(this))
      .catch(function (error) {
        Toast.file("識(shí)別失敗,請(qǐng)重新上傳條碼!",3500);
      })
   };
 },

后端部分(Java )

添加 zxing + base64 依賴(lài)

<!-- 解析二維碼 -->
  <dependency>
    <groupId>com.google.zxing</groupId>
    <artifactId>core</artifactId>
    <version>3.3.3</version>
  </dependency>
  <dependency>
    <groupId>com.google.zxing</groupId>
    <artifactId>javase</artifactId>
    <version>3.3.3</version>
  </dependency>


  <!-- Base64 -->
  <!-- https://mvnrepository.com/artifact/net.iharder/base64 -->
  <dependency>
    <groupId>net.iharder</groupId>
    <artifactId>base64</artifactId>
    <version>2.3.8</version>
  </dependency>

Controller

  @ResponseBody
  @RequestMapping(value = "/uploadParsing", method = RequestMethod.POST)
  public ResponseMessage uploadParsing(@RequestBody imgUploadMessage uploadFile){
    ResponseMessage rm=new ResponseMessage();
    //解析Base64編碼之后 讀取條
    try {
      String imgStr = uploadFile.getFileBase64Code().substring(uploadFile.getFileBase64Code().indexOf(",")+1);
      Decoder decoder = Base64.getDecoder();
      byte[] base = decoder.decode(imgStr);
      for (int i = 0; i < base.length; ++i) {
        if (base[i] < 0) {
          base[i] += 256;
        }
      }
       ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(base);
       BufferedImage read = ImageIO.read( byteArrayInputStream);
        if (null==read) {
          rm.setMsg("解析失敗");
          rm.setSuccess(false);
          return rm;
        }
        BufferedImageLuminanceSource source = new BufferedImageLuminanceSource(read);
        BinaryBitmap bitmap = new BinaryBitmap(new HybridBinarizer(source));
        Map<DecodeHintType,Object> hints=new HashMap<>();
        hints.put(DecodeHintType.CHARACTER_SET,"GBK");
        hints.put(DecodeHintType.PURE_BARCODE,Boolean.TRUE);
        hints.put(DecodeHintType.TRY_HARDER,Boolean.TRUE);
  
        Result decode = new MultiFormatReader().decode(bitmap, hints);
        log.debug("條形碼的內(nèi)容是:" + decode.getText());
        rm.setMsg(decode.getText());
       
      } catch (Exception e) {
        e.printStackTrace();
        log.debug("解析失敗:",e);
        rm.setSuccess(false);
        rm.setMsg("解析失敗");
      }
     return rm;
  }

以上就是Vue+Java+Base64實(shí)現(xiàn)條碼解析的示例的詳細(xì)內(nèi)容,更多關(guān)于Vue+Java+Base64實(shí)現(xiàn)條碼解析的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Vue.js中使用${}實(shí)現(xiàn)變量和字符串的拼接方式

    Vue.js中使用${}實(shí)現(xiàn)變量和字符串的拼接方式

    這篇文章主要介紹了Vue.js中使用${}實(shí)現(xiàn)變量和字符串的拼接方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • 詳解基于vue-cli3快速發(fā)布一個(gè)fullpage組件

    詳解基于vue-cli3快速發(fā)布一個(gè)fullpage組件

    這篇文章主要介紹了詳解基于vue-cli3快速發(fā)布一個(gè)fullpage組件,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-03-03
  • 使用vue封裝一個(gè)自定義樣式的滾動(dòng)條

    使用vue封裝一個(gè)自定義樣式的滾動(dòng)條

    眾所周知,當(dāng)容器高度固定而內(nèi)容部分高度超出容器高度時(shí),瀏覽器會(huì)渲染出一個(gè)可以滾動(dòng)并用于顯示剩余界面的條 -- 滾動(dòng)條,它可以簡(jiǎn)單的樣式修改,但是位置是固定的,無(wú)法移動(dòng),而我們需要改變位置的時(shí)候,它就不能滿(mǎn)足我們的需求了,這時(shí)我們可以自己手寫(xiě)一個(gè)
    2023-10-10
  • vue用戶(hù)長(zhǎng)時(shí)間不操作退出到登錄頁(yè)的兩種實(shí)現(xiàn)方式

    vue用戶(hù)長(zhǎng)時(shí)間不操作退出到登錄頁(yè)的兩種實(shí)現(xiàn)方式

    出于安全考慮,用戶(hù)長(zhǎng)時(shí)間不操作,就回到登錄頁(yè)面,讓用戶(hù)重新登錄,本文就記錄一下實(shí)現(xiàn)這種效果的兩種方式,具有一定的參考價(jià)值,感興趣的可以了解一下
    2021-09-09
  • ElementUI時(shí)間選擇器限制選擇范圍disabledData的使用

    ElementUI時(shí)間選擇器限制選擇范圍disabledData的使用

    本文主要介紹了ElementUI時(shí)間選擇器限制選擇范圍disabledData的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • 淺析Vue2和Vue3中雙向綁定機(jī)制的優(yōu)化與差異

    淺析Vue2和Vue3中雙向綁定機(jī)制的優(yōu)化與差異

    Vue.js?核心特性之一就是雙向綁定,本文將深入探討?Vue2?和?Vue3?在雙向綁定上的區(qū)別,并分析這些改進(jìn)對(duì)性能和開(kāi)發(fā)體驗(yàn)的影響,希望對(duì)大家有所幫助
    2024-11-11
  • 如何解決el-checkbox選中狀態(tài)更改問(wèn)題

    如何解決el-checkbox選中狀態(tài)更改問(wèn)題

    這篇文章主要介紹了如何解決el-checkbox選中狀態(tài)更改問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • vue前端如何向后端傳遞參數(shù)

    vue前端如何向后端傳遞參數(shù)

    這篇文章主要介紹了vue前端如何向后端傳遞參數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Vue?socket.io模塊實(shí)現(xiàn)聊天室流程詳解

    Vue?socket.io模塊實(shí)現(xiàn)聊天室流程詳解

    vue-socket.io其實(shí)是在socket.io-client(在瀏覽器和服務(wù)器之間實(shí)現(xiàn)實(shí)時(shí)、雙向和基于事件的通信)基礎(chǔ)上做了一層封裝,將socket掛載到vue實(shí)例上,同時(shí)可使用sockets對(duì)象輕松實(shí)現(xiàn)組件化的事件監(jiān)聽(tīng),在vue項(xiàng)目中使用起來(lái)更方便
    2022-12-12
  • OpenLayer基于vue的封裝使用教程

    OpenLayer基于vue的封裝使用教程

    這篇文章主要介紹了OpenLayer基于vue的封裝使用,openlayer使用的版本是"^6.4.3",引入了mapbox的樣式,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-10-10

最新評(píng)論