读取连接中文件流和页面展示base64编码的文件
创始人
2024-11-14 17:07:49
0

读取连接中文件流和页面展示base64编码的文件

  • 背景需求
    • 从接口处获取base64编码的字节流
      • 依赖
      • java 代码
    • 前端展示
      • pdf
      • 图片

背景需求

我需要展示一个pdf 文件在页面上,但是我一直没办法将 pdf的下载链接用预览方式展示出来,于是打算讨个巧,直接给前端页面发送 Base64 编码的字符串,用来展示pdf文件。而正好我们的文件也有一个获取流的接口。于是,变出现了这篇文章。

从接口处获取base64编码的字节流

依赖

                     org.apache.hadoop             hadoop-common             3.4.0          

java 代码

  1. 直接从 URL 获取流
    public static String downloadFile3(String UrlFilePath, String localFilePath) {         URL url = null;         HttpURLConnection httpUrl = null;         try {             url = new URL(UrlFilePath);             httpUrl = (HttpURLConnection) url.openConnection();             // 设置请求方式,默认是GET             // httpUrl.setRequestMethod("POST");             httpUrl.connect();             try (BufferedInputStream bis = new BufferedInputStream(httpUrl.getInputStream())) {                 byte[] bytes = IOUtils.toByteArray(bis);                 String base64String = Base64.getEncoder().encodeToString(bytes);                  // Write the BASE64 encoded string to the file                 try (BufferedWriter writer = new BufferedWriter(new FileWriter(localFilePath))) {                     writer.write(base64String);                 }                 return base64String;             }         } catch (Exception e) {             e.printStackTrace();         }         return "";     } 
  1. 发送 GET 请求 获取流
/**      * @param url 远程文件路径      * @return base64 编码字符串      */     public static String byGet(String url) {         // 创建Httpclient对象         CloseableHttpClient httpclient = HttpClientBuilder.create().build();         RequestConfig requestConfig = RequestConfig.custom().setConnectTimeout(30000).setConnectionRequestTimeout(30000).setSocketTimeout(30000).build();          String resultString = "";         CloseableHttpResponse response = null;         try {             URIBuilder builder = new URIBuilder(url);             URI uri = builder.build();             // 创建http GET请求             HttpGet httpGet = new HttpGet(uri);             httpGet.setConfig(requestConfig);             httpGet.addHeader("Content-type", "application/json; charset=utf-8");              // 执行请求             response = httpclient.execute(httpGet);               // 判断返回状态是否为200             if (response.getStatusLine().getStatusCode() == 200) {                 InputStream inputStream = response.getEntity().getContent();                 byte[] bytes = IOUtils.toByteArray(inputStream);                 BASE64Encoder encoder = new BASE64Encoder();                 resultString = encoder.encode(bytes);                 return resultString;             }         } catch (Exception e) {          } finally {             try {                 if (response != null) {                     response.close();                 }                 httpclient.close();             } catch (IOException e) {                 e.printStackTrace();             }         }         return "";     } 

前端展示

pdf

        function viewPdf (content) {              const blob = this.base64ToBlob(content)             if (window.navigator && window.navigator.msSaveOrOpenBlob) {                 window.navigator.msSaveOrOpenBlob(blob)             } else {                 const fileURL = URL.createObjectURL(blob)                 window.open(fileURL)             }         }         function base64ToBlob (code) {             code = code.replace(/[\n\r]/g, '')             const raw = window.atob(code)             const rawLength = raw.length             const uInt8Array = new Uint8Array(rawLength)             for (let i = 0; i < rawLength; ++i) {                 uInt8Array[i] = raw.charCodeAt(i)             }             return new Blob([uInt8Array], { type: 'application/pdf' })         } 

图片

let ImgURL ="\"; 

将拼接好的 ImgURL 拼接即可

相关内容

热门资讯

重大发现!微乐游戏辅助脚本安装... 重大发现!微乐游戏辅助脚本安装(辅助挂)开挂透视辅助软件(原来是真的挂)-哔哩哔哩1、在微乐游戏辅助...
连日来!陕西三代实战技巧,点星... 连日来!陕西三代实战技巧,点星休闲修改,扑克教程(一贯真的有挂)-哔哩哔哩1、每一步都需要思考,不同...
近年来!微信小程序挂件辅助,金... 近年来!微信小程序挂件辅助,金杯竞技辅助,扑克教程(果然真的是有挂)-哔哩哔哩1、微信小程序挂件辅助...
最新研发!捉住捣蛋鸡辅助码(辅... 最新研发!捉住捣蛋鸡辅助码(辅助挂)开挂透视辅助技巧(本来有挂)-哔哩哔哩在进入捉住捣蛋鸡辅助码辅助...
此事引发广泛关注!微信小程序游... 此事引发广泛关注!微信小程序游戏破解微乐游戏,闲逸辅助器,AA德州教程(果然真的是有挂)-哔哩哔哩1...
最新技巧!桂林字牌科技免费版(... 最新技巧!桂林字牌科技免费版(辅助挂)开挂透视辅助神器(果然有挂)-哔哩哔哩1)桂林字牌科技免费版辅...
有了最新消息!广东雀神智能插件... 有了最新消息!广东雀神智能插件使用,闽游辅助软件,攻略方法(总是真的有挂)-哔哩哔哩1、广东雀神智能...
一分钟揭秘!微信小程序多功能修... 一分钟揭秘!微信小程序多功能修改器(辅助挂)开挂透视辅助神器(竟然存在有挂)-哔哩哔哩1、点击下载安...
为了进一步!传送屋有没有挂,随... 为了进一步!传送屋有没有挂,随意玩辅助软件,2025新版(都是真的是有挂)-哔哩哔哩1、点击下载安装...
分享一款!微信小程序边锋辅助(... 分享一款!微信小程序边锋辅助(辅助挂)开挂透视辅助脚本(本来真的有挂)-哔哩哔哩1、全新机制【微信小...