springboot整合kkFileView部署,前端使用

前言:

官方文檔:https://kkfileview.keking.cn/zh-cn/docs/production.html
在這里插入圖片描述

docker方式或加入星球獲取發行包直接獲取啟動,無需以下步驟:

拉取鏡像# 網絡環境方便訪問docker中央倉庫
docker pull keking/kkfileview:4.1.0# 網絡環境不方便訪問docker中央倉庫
wget https://kkfileview.keking.cn/kkFileView-4.1.0-docker.tar
docker load -i kkFileView-4.1.0-docker.tar運行
docker run -it -p 8012:8012 keking/kkfileview:4.1.0

kkFileView是一個很好的文件預覽系統,初期開源維護時gitee和github上會直接提供發行包,現只有加入星球(99元一年)才能獲取發行包。以下為源碼方式部署使用細節。

1.下載源碼(獲取最新源碼即可)
https://gitee.com/kekingcn/file-online-preview/tree/v4.4.0-beta/
在這里插入圖片描述

2.IDE工具編譯成jar包(無需更改任何文件)
在這里插入圖片描述
3.jar包上傳到服務器,這里分windows服務器和linux服務器版,都需安裝openOffice或LibreOffice,否則無法啟動。

windows安裝openOffice:https://www.openoffice.org/zh-cn/download/
在這里插入圖片描述

linux安裝LibreOffice:https://blog.csdn.net/an129/article/details/126766228?spm=1001.2014.3001.5506

安裝完后執行java -jar kkFileView.jar即可,默認端口為8012,能訪問到此頁面并能在頁面上正常預覽則說明部署成功。
在這里插入圖片描述

4.前端使用
在這里插入圖片描述
安裝 base64 編碼解碼:

npm install --save js-base64

在下載按鈕下方新寫一個預覽按鈕

<el-buttontype="text"size="small"icon="el-icon-download"@click="download(scope.row, scope.index)"
>下載
</el-button>
// 以下新增一個預覽按鈕
<el-buttontype="text"size="small"icon="el-icon-upload"@click="view(scope.row, scope.index)"
>預覽
</el-button>

實現調用 view 方法

const handlePreview = (row: any, fileName: string, files: any) => {findObjectURL(fileName).then((response) => {window.open(`${store.getters['previewUrl']}/onlinePreview?url=` +encodeURIComponent(Base64.encode(response.data)) +`&fullfilename=test.${fileName.split('.')[1]}`,'_blank');});
};

注:此處需要傳入url才能正常使用預覽,但是kkFileView需要以正常文件后綴名結尾的url才能使用,如:http://127.0.0.1:8081?fileName = 1.xlsx格式。但一般系統都是以文件名或id請求后端接口獲取的文件流數據,還有如minio等文件系統的臨時文件url后面會跟一些權限信息,導致并不是以文件后綴結尾故預覽失敗。解決方法為:請求接口上提供了fullfilename參數,只需給一個默認的文件名并指定相應后綴即可,如上代碼所示。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/15449.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/15449.shtml
英文地址,請注明出處:http://en.pswp.cn/web/15449.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

pytest框架的代碼如何用vscode進行debug

{"version": "0.2.0","configurations": [{"name": "Python: Run My Module", // 配置名稱&#xff0c;將在調試配置下拉列表中顯示"type": "debugpy", // 調試類型&#xff0c;這里是Python"requ…

二元關系表示

一、二元關系的定義和表示 什么是二元關系&#xff1f;對集合A和B&#xff0c;A\timesB的任意子集R為A到B的一個二元關系。當AB時&#xff0c;A\timesA的任一子集R稱為A上的一個二元關系。在不引起誤解的情況下&#xff0c;二元關系可簡稱關系。 若|A|m,|B|n&#xff0c;則A到…

常用字體映射字典

表格形式 英文字體名稱中文字體名稱SimSun宋體SimHei黑體KaiTi楷體FangSong仿宋YouYuan幼圓LiSu隸書NSimSun新宋體SimSun-ExtB宋體-ExtBFangSong_GB2312仿宋_GB2312KaiTi_GB2312楷體_GB2312Microsoft YaHei微軟雅黑Microsoft JhengHei微軟正黑體STXihei華文細黑STKaiti華文楷體…

手機版AI寫作軟件哪個好用?5款AI寫作軟件分享

在這個快節湊的時代&#xff0c;人們對于高效、便捷的創作方式很是追求。尤其是在人工智能技術發展迅速的今天&#xff0c;AI寫作軟件的出現&#xff0c;讓很多自媒體創作者都會想到在手機上面進內容創作&#xff0c;這樣不僅能提高工作效率&#xff0c;而且工作的自由度會更高…

自動化運維(AIOps): 現代IT管理的革命

在數字化時代&#xff0c;企業的 IT 系統變得愈加復雜。從云計算到大數據&#xff0c;從物聯網到人工智能&#xff0c;技術的飛速發展使得企業面臨前所未有的挑戰。這種復雜性不僅體現在數據量和數據流的增加上&#xff0c;還包括高成本和高錯誤率的運維需求。在此背景下&#…

基于51單片機的盆栽自動澆花系統

一.硬件方案 工作原理是濕度傳感器將采集到的數據直接傳送到ADC0832的IN端作為輸入的模擬信號。選用濕度傳感器和AD轉換&#xff0c;電路內部包含有濕度采集、AD轉換、單片機譯碼顯示等功能。單片機需要采集數據時&#xff0c;發出指令啟動A/D轉換器工作&#xff0c;ADC0832根…

Hive 變量定義與引用

文章目錄 1.背景2.Hive 變量命名空間查看變量設置變量引用變量 參考文獻 1.背景 在書寫 Hive SQL 時&#xff0c;有時需要將重復出現的值從 SQL 分離出來&#xff0c;以變量的方式表示和引用。 設置變量和引用變量可以帶來以下幾個好處&#xff1a; 簡化查詢語句&#xff1a;…

Android 實現豎排文本(垂直方向顯示)

Android 實現豎排文本-垂直方向顯示 前言效果圖代碼實現方式一 Custom View1. 自定義視圖 VerticalTextView2. 在xml布局文件中使用3. 設置文本內容 方式二 使用 TextView 的 rotation屬性方式三 使用帶有跨距文本的TextView1. 自定義視圖 VerticalTextView2. 在xml布局文件中使…

AI學習指南數學工具篇-凸優化基礎知識凸函數

AI學習指南數學工具篇-凸優化基礎知識凸函數 引言 在凸優化過程中&#xff0c;凸函數是一個非常重要的概念&#xff0c;它在機器學習、深度學習和優化算法中都有廣泛的應用。凸函數具有很多獨特的性質&#xff0c;能夠幫助我們更好地理解優化問題并且設計高效的優化算法。本文…

【Golang】Golang獲取Gin框架PostForm上傳的文件

文章目錄 前言一、函數解釋二、代碼實現三、總結 前言 在Web開發中&#xff0c;文件上傳是一項常見的功能。例如&#xff0c;用戶可能需要上傳頭像、文檔或其他類型的文件。在Go語言的Gin框架中&#xff0c;我們可以很方便地處理文件上傳。在這篇博客中&#xff0c;我將解釋如…

怎樣理解 Vue 的單項數據流

Vue 的單項數據流是一個核心概念&#xff0c;它指的是在 Vue 組件中&#xff0c;數據的流動方向是單向的&#xff0c;從父組件流向子組件。以下是關于 Vue 單項數據流的詳細理解&#xff1a; 數據流的方向&#xff1a; Vue 中的數據流動是單向的&#xff0c;即數據只能從父組件…

中國交通信息科技集團有限公司(中交信科)java開發工程師-機試題目/頌大技術面試總結/理工數傳 軟件開發一面二面面試總結/武漢智能視覺信息技術有限公司/高級

武漢智能視覺信息技術有限公司/高級 如果解決jvm內存溢出如果解決億級別的數據導出&#xff0c;有沒有其他的方案可以解決呢索引的原理工作中用了哪些索引提高了多少的速度線程池的創建方法--解釋new ThreadPool的其他參數以及四大拒絕策略分布式使用用到了哪些模式xxl-job的原…

pillow學習4

ImageChops 模塊 在 Pillow 庫的內置模塊 ImageChops 中包含了多個用于實現圖片合成的函數。這些合成 功能是通過計算通道中像素值的方式來實現的。其主要用于制作特效、合成圖片等操作。 常用的內置函數如下所示&#xff1a; &#xff08;1&#xff09;相加函數 add()&#xf…

【Windows系統】解決Intel 6代CPU安裝win7系統過程中無法操作鍵盤鼠標的問題

問題 微軟表示&#xff0c;從 2016 年 7 月 17 日起&#xff0c;新的 Intel、AMD 和Qualcomm 處理器將僅支持 Windows 10&#xff0c;不再支持 Windows 7 和 8.1。因此&#xff0c;Intel 6代以后的CPU因為沒有USB驅動無法完成win7系統的安裝。 下文核心思想是通過老毛桃PE系統…

云界洞見:移動云服務開啟技術創新與問題解決的新篇章

一、什么是移動云 移動云以“央企保障、安全智慧、算網一體、屬地服務”為品牌支撐&#xff0c;聚焦智能算力建設&#xff0c;打造一朵智能、智慧、安全可信可控的云&#xff0c;提供更優質的算力服務&#xff0c;引領云計算產業發展。 那么下面博主帶領大家了解移動云的優勢所…

關于c++的通過cin.get()維持黑框的思考

1.前言 由于本科沒有學過c語言&#xff0c;研究生階段接觸c上手有點困難&#xff0c;今天遇到關于通過cin.get()來讓黑框維持的原因。 2.思考 cin.get()維持黑框不消失的原因一言蔽之就是等待輸入。等待鍵盤的輸入內容并回車&#xff08;一般是回車&#xff09;后cin.get()才…

Plotly庫利用滑塊創建數據可視化

使用了Plotly庫來創建一個數據可視化圖表&#xff0c;并使用滑塊來控制顯示哪些數據 import plotly.graph_objects as go from plotly.subplots import make_subplots# 示例數據 x [1, 2, 3, 4, 5] y1 [1, 2, 3, 4, 5] y2 [5, 4, 3, 2, 1] y3 [2, 3, 1, 5, 4]# 創建子圖 f…

Python vscode debug: Error while enumerating installed packages.解決

記錄一個vscode python debug時出現的錯誤&#xff1a; 具體錯誤如下&#xff1a; E00000.030: Error while enumerating installed packages. Traceback (most recent call last): File “/root/.vscode-server/extensions/ms-python.debugpy-2024.0.0-linux-x64/bundled/lib…

java —— 類與方法

一、訪問修飾符 在類和方法中&#xff0c;均可使用訪問修飾符以鎖定該類或方法的被訪問權限。訪問修飾符有四種&#xff1a; &#xff08;一&#xff09;public 同一個項目中&#xff0c;對所有的類可見。 &#xff08;二&#xff09;protected 同一個項目中&#xff0c;對…

Study--Oracle-03-Oracle19C--RAC集群部署

一、硬件信息及配套軟件 1、硬件設置 RAC集群虛擬機&#xff1a;CPU:2C、內存&#xff1a;9G、操作系統&#xff1a;30G、數據庫安裝目錄&#xff1a;100G 數據存儲&#xff1a;50G &#xff08;10G*5&#xff09; 共享存儲&#xff1a;2G &#xff08;1G*2&#xff09; 2…