服务器:WindowsServer 2016

Cloudreve

需求方想整一个在小团队内部使用的网盘系统,最终在千挑万选之下选中了Cloudreve

Github地址:https://github.com/cloudreve/Cloudreve

官网地址:https://docs.cloudreve.org

Cloudreve是采用go + React开发的开源网盘系统,优点是部署简单、界面功能精简好用、更新比较活跃、文档详细,目前在GithubStar 1.6w+

第一步:下载

下载后的文件结构如下图所示(只有cloudreve.execonf.ini

nssm下载链接

提取码: dtbb

第二步:修改配置文件

配置文件主要还是配置端口和数据库,其他详细配置可以去官网查看

[System]
Debug = false
Mode = master
Listen = :7018
SessionSecret = iA9nowZRHi6s5XSAFEVrNl0njyqZfjmx6mZQGWVBbMQG32SE5dx6pVWPTNTeByTh
HashIDSalt = 5hrN8NvlA7LxdVJCkjlHb5A1Ut2Rph85GqfhwZWvpn2tnGi79uEomziXkHStFMZT [Database]
Type = mysql
Port = 3306
User = cloudreve
Password = xxxxx
Host = 0.0.0.0
Name = Cloudreve
TablePrefix = cd
Charset = utf8

第三步:启动

双击cloudreve.exe文件便可以直接启动,启动成功的界面如下:

初始化的数据库表:

真正使用还是建议部署成windows服务,这时候可以使用上面提到的nssm工具。

cdnssm工具对应的目录,输入:nssm install便会出现如下界面:

安装成功后,进到服务管理启动对应的服务即可。

系统成功启动后的界面如下:

kkFileView

网盘部署好了,需求方又提了个需求,想要支持在线预览。

Cloudreve自带预览PDFTXT格式的文件,如果需要预览Office相关文件就需要自己对接第三方服务。

目前提供在线预览的第三方服务有很多,比如微软大大就提供有免费的文档在线预览服务,但前面有说到,网盘系统是在内部使用,这一条只能pass,第三方不行那就自己做第三方。

于是,万能的Github又登场了。

kkFileView是采用java开发的文件文档在线预览方案,目前在GithubStar 7.8K+

Github地址:https://github.com/kekingcn/kkFileView

Gitee地址:https://gitee.com/kekingcn/file-online-preview

官网地址:https://kkfileview.keking.cn

两个系统都有个优点,就是部署简单,文档详细。

下载下来的文件结构如下,点击 startup.bat 文件等待片刻后在浏览器中打开:http://localhost:8012 便会看到kkFileView的测试页面。

如果能看到上图就表示启动成功了,大家可以自行在测试页面上测试相关文件的预览效果,具体的参数配置可以参考官方文档,非常详细。

集成

上面两步我们已经将网盘服务和在线预览服务都部署成功了,接下来就是合二为一。

我们先进到Cloudreve的管理面板 —— 参数设置,有两个信息我们需要配置。

1、站点URL记得添加端口号

2、图像与预览修改Office 文档预览服务地址:http://127.0.0.1:8012/onlinePreview?url={$srcB64}

最后点击保存几即可。

配置成功后,我们去试试预览效果,双击对应的文件:

诶,怎么回事,预览失败了,而且这个文件类型 lpmatwo4pg1n8bc6 是什么鬼。

其实这与kkFileView的预览机制有关系,kkFileView预览是通过下载地址的文件后缀名去判断文件类型,但Cloudreve生成的下载链接文件名是一串随即字符且不包括文件后缀,所以kkFileView在处理时不知道对应的文件类型,导致预览失败。

知道问题了就有解决办法:

  1. 修改Cloudreve的下载链接生成逻辑,使其带上文件后缀

  2. 修改kkFileView的文件类型识别逻辑

因为Cloudreve是将前后端统一打包成exe可执行程序,如果修改后还要打包太麻烦,所以放弃解决办法一(其实这个解决办法才是相对科学的。)

修改

先去Gitee或者Github下载kkFleView源码

下载下来后可以根据如下路径找到对应文件:

file-online-preview-master\server\src\main\java\cn\keking\web\controller\OnlinePreviewController.java

修改思路:根据文件的前n个起始字节,也被称为魔数去判断对应文件属于什么文件类型,但是这个方法也存在缺陷,wpsoffice相关文件的魔数一样,无法做详细区分,比如:docx、xlsx、pptx

上代码

因为本人是微软阵营的,对Java这块不熟悉,代码仅做参考。

1、建立魔数与文件类型的键值对映射关系(只列举了常用的一些,准不准确大家可以自行验证)
public final static Map<String, String> FILE_TYPE_MAP = new HashMap<String, String>();

static {
FILE_TYPE_MAP.put("ffd8ff", "jpg");
FILE_TYPE_MAP.put("89504e47", "png");
FILE_TYPE_MAP.put("47494638", "gif");
FILE_TYPE_MAP.put("49492a00227105008037", "tif");
FILE_TYPE_MAP.put("424d228c010000000000", "bmp"); // 16色位图(bmp)
FILE_TYPE_MAP.put("424d8240090000000000", "bmp"); // 24位位图(bmp)
FILE_TYPE_MAP.put("424d8e1b030000000000", "bmp"); // 256色位图(bmp)
FILE_TYPE_MAP.put("41433130313500000000", "dwg"); FILE_TYPE_MAP.put("68746d6c3e", "html"); // HTML
FILE_TYPE_MAP.put("48544d4c207b0d0a0942", "css");
FILE_TYPE_MAP.put("696b2e71623d696b2e71", "js");
FILE_TYPE_MAP.put("38425053000100000000", "psd");
FILE_TYPE_MAP.put("255044462d312e", "pdf");
FILE_TYPE_MAP.put("75736167", "txt"); FILE_TYPE_MAP.put("00000020667479706d70", "mp4");
FILE_TYPE_MAP.put("49443303000000002176", "mp3");
FILE_TYPE_MAP.put("41564920", "avi"); FILE_TYPE_MAP.put("3c3f786d6c", "xml");// xml文件
FILE_TYPE_MAP.put("504b03040a000", "office");// office文件
FILE_TYPE_MAP.put("504b030414000", "office");// office文件
FILE_TYPE_MAP.put("d0cf11e0a1b11ae10000", "wps");// WPS文字wps、表格et、演示dps都是一样的
}

注意:officewps下的相关文件(docx、xlsx、pptx)的魔数都一样,所以大家可以默认设置成其中一种即可(我默认的是xlsx),kkFileView预览office相关文件依赖的是OpenOfficeLibreOffice

2、根据文件流判断文件类型
/**
* 获取文件类型
*/
private String getFileType(String fileUrl) throws IOException {
URL newUrl = new URL(fileUrl);
HttpURLConnection conn = (HttpURLConnection) newUrl.openConnection();
InputStream inputStream = conn.getInputStream();
byte[] bytes = IOUtils.toByteArray(inputStream); StringBuilder stringBuilder = new StringBuilder();
for (int i = 0; i < 20; i++) {
int v = bytes[i] & 0xFF;
String hv = Integer.toHexString(v);
if (hv.length() < 2) {
stringBuilder.append(0);
}
stringBuilder.append(hv);
} String fileCode = stringBuilder.toString().toLowerCase();
String fileType = null;
Iterator<String> keyIter = FILE_TYPE_MAP.keySet().iterator();
while (keyIter.hasNext()) {
String key = keyIter.next();
if (fileCode.startsWith(key)) {
fileType = FILE_TYPE_MAP.get(key);
break;
}
}
return fileType;
}
3、找到OnlinePreviewController.java文件的对应方法

主要是在getFileAttribute方法内加一层后缀名的处理,为了不影响原方法,所以我们新增一个

/**
* 获取文件属性(扩展无后缀名)
*
* @param url url
* @return 文件属性
*/
public FileAttribute getFileAttributeEx(String url, String suffix, HttpServletRequest req) {
FileAttribute attribute = new FileAttribute();
FileType type;
String fileName;
String fullFileName = WebUtils.getUrlParameterReg(url, "fullfilename");
if (StringUtils.hasText(fullFileName)) {
fileName = fullFileName;
type = FileType.typeFromFileName(fullFileName);
suffix = KkFileUtils.suffixFromFileName(fullFileName);
} else {
fileName = WebUtils.getFileNameFromURL(url);
String newUrl = url;
int index = newUrl.indexOf("?");
if (index < 0) {
newUrl = newUrl + "." + suffix;
} else {
newUrl = newUrl.substring(0, index) + "." + suffix + newUrl.substring(index, newUrl.length() - 1);
}
type = FileType.typeFromUrl(newUrl);
suffix = WebUtils.suffixFromUrl(newUrl);
}
if (url.contains("?fileKey=")) {
attribute.setSkipDownLoad(true);
}
attribute.setType(type);
attribute.setName(fileName + "." + suffix);
attribute.setSuffix(suffix);
attribute.setUrl(url); ...... return attribute;
}

完事后我们再来看看预览效果:

原文件:

预览效果:

注意:kkFileViewxlsxxls文件的处理默认是以html形式转换,其他文件都是以pdf形式,由于xlsxxlspdf后的效果太过凌乱,权衡利弊下officewps相关的文件全部指定为xlsx,以html形式展示。


最后,这个问题其实很早就有人提出过,Cloudreve的作者也在Issues中回复下个版本会增加单独扩展名变量,所以文章的解决方案仅仅做一个分享,大家等Cloudreve版本更新会更好。

在Cloudreve网盘系统中集成kkFileView在线预览(暂时)的更多相关文章

  1. 私人网盘系统2.0—全部升级为layUI+PHP(持续更新中)shang

    网盘系统2.0   上周,我做了第一版的“私人网盘系统”,http://www.cnblogs.com/sunlizheng/p/7822036.html 没看过的朋友可以去看一下,这周在家升级做了第 ...

  2. Layui框架+PHP打造个人简易版网盘系统

    网盘系统   大家应该都会注册过致命的一些网盘~如百度云.百科介绍:网盘,又称网络U盘.网络硬盘,是由互联网公司推出的在线存储服务,服务器机房为用户划分一定的磁盘空间,为用户免费或收费提供文件的存储. ...

  3. kkfileview v2.0 发布,文件在线预览项目方案

    kkfileview文件在线预览 此项目为文件文档在线预览项目解决方案,项目使用流行的spring boot搭建,易上手和部署,部署好后可以独立提供预览服务,使用http接口访问,不需要和应用集成,具 ...

  4. Print2flash在.NET(C#)中的使用,即文档在线预览

    office文档(word,excel,ppt)在线预览查看,有很多种方式,比如可以 1.调用weboffice组件,进行word预览,要求客户端安装word,仅适用IE, word2013, IE1 ...

  5. Print2flash在.NET(C#)64位中的使用,即文档在线预览

    转:http://www.cnblogs.com/flowwind/p/3411106.html Print2flash在.NET(C#)中的使用,即文档在线预览   office文档(word,ex ...

  6. office web apps 整合到自己项目中(wopi实现在线预览编辑)

    借助office web apps实现在线预览和在线编辑 我所有的代码都是用go语言编写,你可以直接编译后使用,不用再有其他的操作. 最近项目实在太忙,这几天才有时间,这次是重头戏,要好好琢磨一下怎么 ...

  7. minio + kkFileView 实现在线预览

    minio上传的pdf之类文件不支持预览,地址在浏览器访问时会直接下载,现在搭配kkFileView文件预览 1.minio查看之前的安装方式 2.kkFileView安装 docker方式 1.拉取 ...

  8. kkFileView对接svn服务完成文件在线预览功能

    1.需求: 之前在公司内部搭建了svn服务器,给部门存放文档.视频,做成了一个文档服务器来用,随着视频文件太大,每次下载太慢 需要把文件在线打开查看 2.解决: kkFileView https:// ...

  9. 网页中动态嵌入PDF文件/在线预览PDF内容https://www.cnblogs.com/xgyy/p/6119459.html

    #网页中动态嵌入PDF文件/在线预览PDF内容# 摘要:在web开发时我们有时会需要在线预览PDF内容,在线嵌入pdf文件: 问题1:如何网页中嵌入PDF: 在网页中: 常用的几种PDF预览代码片段如 ...

  10. #网页中动态嵌入PDF文件/在线预览PDF内容#

    摘要:在web开发时我们有时会需要在线预览PDF内容,在线嵌入pdf文件: 问题1:如何网页中嵌入PDF: 在网页中: 常用的几种PDF预览代码片段如下: 代码片段1: 1 <object ty ...

随机推荐

  1. 【Java面试】面试遇到宽泛的问题,这么回答就稳了,谈谈你对Redis的理解

    "谈谈你对Redis的理解"! 面试的时候遇到这类比较宽泛的问题,是不是很抓狂? 是不是不知道从何开始说起? 没关系,今天我用3分钟教你怎么回答. 大家好,我是Mic,一个工作了1 ...

  2. MyBatis标签之Select resultType和resultMap

    摘要:介绍MyBatis 中Select标签的两个属性resultType和resultMap及其区别. 1 MyBatis动态SQL之if 语句 2 MyBatis动态sql之where标签|转 3 ...

  3. 最强cron解析器

    背景 大家有没有这么一种困境 我现在需要去配置一个定时任务:"每天早上九点执行任务" 若你有一个好的定时任务平台,相信很容易就能配置完成.那若是没有定时任务平台呢?是不是就要自己写 ...

  4. 采用docker方式安装ElastAlert,图形化配置告警规则----具体内容有删改,仅供查看

    1.创建几个文件夹保存ElastAlert相关配置信息,用来挂载到容器中使用 2.编写核心配置,创建 ${ELASTALERT}/config/config.yaml用来存储核心配置: 3.Elast ...

  5. Vue+vant移动端处理弹窗不能滑动问题

    自己在做项目开发时,使用vantUI组件,在项目中遇到了弹窗组件里面当内容过多时,会出现滚动卡顿或者不能滚动问题,开始一直以为是自己的样式写的有问题,检查下来才发现并不是,而是弹窗组件的问题,于是找到 ...

  6. docker搭建yapi接口文档系统、Idea中上传接口、在线调用

    一.前言 在我们后端开发中,必不可少的是接口的交接,有很多种方式,常见的就是swagger,不过这个侵入性太强了.还有就是接口文档的框架,比如今天小编带大家一起搭建的yapi,在公司还是挺常见的! 今 ...

  7. C++ 使用栈求解中缀、后缀表达式的值

    1. 前言 表达式求值对于有知识积累的你而言,可以通过认知,按运算符的优先级进行先后运算. 但对计算机而言,表达式仅是一串普通的信息而已,需要通过编码的方式告诉计算机运算法则,这个过程中栈起到了至关重 ...

  8. Containerd-1.6.5 镜像容器操作

    一.Containerd 镜像操作 1 基本参数 [root@ecs-65685 ~]# ctr c NAME: ctr containers - manage containers USAGE: c ...

  9. C++ 队列!还是要从 STL 中的说起……

    1. 前言 队列和栈一样,都是受限的数据结构. 队列遵循先进先出的存储原则,类似于一根水管,水从一端进入,再从另一端出去.进入的一端称为队尾,出去的一端称为队头. 队列有 2 个常规操作: 入队:进入 ...

  10. PHP获取两个时间差

    <?php //PHP计算两个时间差的方法 $startdate="2017-12-3 12:00:00"; $enddate="2017-12-4 12:00:0 ...