背景

Confluence是现在广泛使用的团队协作文档系统。虽然自身带了一些表格编辑功能,但表格的整体功能较弱,比如不能通过Excel文件进行导入导出,表格在复制到Excel时格式会比较奇怪等等。对于未完全整合流程到Confluence上的团队,信息从Excel到在线文档系统的流转是个巨大的工作量。

介绍

Elements Spreadsheet作为Confluence的插件可以有效的解决上面的部分问题,通过这个插件可以接近完美导入导出Excel到Confluence系统中(试了Excel太大的话会莫名其妙的编辑中崩溃),Excel文档可以完美嵌入到Confluence的网页中,同时支持在线编辑与占用提示,公式等等功能,参考Confluence的介绍与文档。Elements Spreadsheet for Confluence | Atlassian Marketplace

安装步骤

整个安装步骤参考Confluence安装Drawio插件 - MrHeartTired (ltang.me)

  1. 首先在官方链接下载当前版本支持的插件。(前面的官方链接进入Version页面选择)

  2. 其次,再IDE(Idea)中新建如下文件与对应的包目录:

AbstractSpreadsheetRestService.java文件与对应的包目录。


package com.valiantys.software.spreadsheets.rest; import com.atlassian.upm.api.license.PluginLicenseManager;
import com.valiantys.software.spreadsheets.rest.model.ErrorModel;
import com.valiantys.software.spreadsheets.service.error.ErrorType;
import com.valiantys.software.spreadsheets.service.error.SpreadsheetError; import javax.servlet.http.HttpServletRequest;
import javax.ws.rs.core.Response;
import javax.ws.rs.core.Response.Status; public abstract class AbstractSpreadsheetRestService {
public static final String ATLASSIAN_DEV_MODE = "atlassian.dev.mode";
private final PluginLicenseManager pluginLicenseManager; protected AbstractSpreadsheetRestService(PluginLicenseManager pluginLicenseManager) {
this.pluginLicenseManager = pluginLicenseManager;
} protected boolean isLicenseValid() {
return true;
} private boolean isDevMode() {
String devMode = System.getProperty("atlassian.dev.mode");
return Boolean.parseBoolean(devMode);
} protected ErrorModel toErrorModel(SpreadsheetError error) {
return new ErrorModel(error.getMessage());
} protected Response toResponse(SpreadsheetError error) {
ErrorType type = error.getType();
if (type == ErrorType.DATA_CONVERSION_ERROR) {
return Response.status(Status.BAD_REQUEST).entity(new ErrorModel(error.getMessage())).build();
} else if (type == ErrorType.FORBIDDEN) {
return Response.status(Status.FORBIDDEN).entity(new ErrorModel(error.getMessage())).build();
} else if (type == ErrorType.MISSING_DATA) {
return Response.status(Status.NOT_FOUND).entity(new ErrorModel(error.getMessage())).build();
} else {
return type == ErrorType.INVALID_REQUEST ? Response.status(Status.BAD_REQUEST).entity(new ErrorModel(error.getMessage())).build() : Response.status(Status.INTERNAL_SERVER_ERROR).entity(new ErrorModel(error.getMessage())).build();
}
} protected String getCharset(HttpServletRequest request) {
String characterEncoding = request.getCharacterEncoding();
return characterEncoding == null ? "UTF-8" : characterEncoding;
}
}

ErrorModel文件与对应的包目录

package com.valiantys.software.spreadsheets.rest.model;  

public class ErrorModel {  

    private String message;  

    public ErrorModel() {
} public ErrorModel(String message) {
this.message = message;
} public String getMessage() {
return this.message;
} public void setMessage(String message) {
this.message = message;
}
}

ErrorType文件与对应的包目录

package com.valiantys.software.spreadsheets.service.error;  

public enum ErrorType {
DATA_CONVERSION_ERROR,
FORBIDDEN,
INVALID_REQUEST,
INTERNAL_ERROR,
MISSING_DATA; private ErrorType() {
}
}

SpreadsheetError文件与对应的包目录

package com.valiantys.software.spreadsheets.service.error;  

import javax.ws.rs.core.Response;  

public class SpreadsheetError {
private ErrorType type;
private String message; public SpreadsheetError() {
} public SpreadsheetError(ErrorType type) {
this.type = type;
} public SpreadsheetError(ErrorType type, String message) {
this.type = type;
this.message = message;
} public static SpreadsheetError build(ErrorType type) {
return new SpreadsheetError(type);
} public static SpreadsheetError build(ErrorType type, String message) {
return new SpreadsheetError(type, message);
} public ErrorType getType() {
return this.type;
} public void setType(ErrorType type) {
this.type = type;
} public String getMessage() {
return this.message;
} public void setMessage(String message) {
this.message = message;
} public String toString() {
return "Error " + this.type.name() + ": " + this.message;
} public Response build() {
return null;
}
}

这一步中只有第一个AbstractSpreadsheetRestService编译出来的的class文件是需要的,其他只是为了解决编译报错。

  1. 在刚安装的jdk环境下,以下两个包会提示找不到,这两个包理论上是可以直接导入的
import javax.ws.rs.core.Response;
import javax.ws.rs.core.Response.Status;

但是由于我对java不太熟悉,java环境都是新装的,所以这两个包我也是按步骤1的方式,补的文件用来编译。

Response文件与对应的包目录。


package javax.ws.rs.core; import java.lang.annotation.Annotation;
import java.net.URI;
import java.util.Date;
import java.util.Iterator;
import java.util.List;
import java.util.Locale;
import java.util.Map;
import java.util.Set; public abstract class Response {
protected Response() {
} public static ResponseBuilder status(Status status) {
return null;
} public interface StatusType { } public enum Status implements Response.StatusType { BAD_REQUEST,
FORBIDDEN,
NOT_FOUND,
INTERNAL_SERVER_ERROR, }
}

ResponseBuilder文件与包目录。

package javax.ws.rs.core;  

import com.valiantys.software.spreadsheets.rest.model.ErrorModel;
import com.valiantys.software.spreadsheets.service.error.SpreadsheetError; public class ResponseBuilder { public SpreadsheetError entity(ErrorModel errorModel) {
return null;
}
}

不要在意具体的代码逻辑与包关系,目的只是为了编译AbstractSpreadsheetRestService.class。同样PluginLicenseManagerLicenseService也需要像参考文章一样补出,这里由于没有代码就不列出来了。

替换与安装

文件编辑完成后,使用7z打开elements-spreadsheet.obr文件,替换AbstractSpreadsheetRestService.class文件并保存。然后按参考文章的方式上传到Confluence安装即可(使用管理员账号登录confluence,找到插件管理 -> 上传插件 -> 选择修改后的obr包,点击上传)。安装成功后,虽然显示试用,但是这时候就已经可以在Confluence中导入并保存Excel文件了,真实的试用状态下Excel导入后是无法保存的。到此安装完成,可以尽情在网页中编辑Excel了。

Confluence的Excel插件Elements Spreadsheet安装的更多相关文章

  1. 个人用户永久免费,可自动升级版Excel插件,使用VSTO开发,Excel催化剂安装过程详解及安装失败解决方法

    因Excel催化剂用了VSTO的开发技术,并且为了最好的用户体验,用了Clickonce的布署方式(无需人工干预自动更新,让用户使用如浏览器访问网站一般,永远是最新的内容和功能).对安装过程有一定的难 ...

  2. 如何在Excel里安装excel插件?

    随着科技的发展,人们对数据分析的要求越来越多, Excel也存在一些问题,长期困扰一线业务用户:首先是性能问题.对于大数据量,Excel处理起来很慢.数据获取的过程麻烦,特别是周期性的数据获取,每次都 ...

  3. django入门8之xadmin引入富文本和excel插件

    django入门8之xadmin引入富文本和excel插件 Xadmin引入富文本 插件的文档 https://xadmin.readthedocs.io/en/docs-chinese/make_p ...

  4. 不需要高价购买BI工具,掌握这个Excel插件就能碾压大数据

    ​曾几何时,EXCEL在数据界可谓是独树一帜,引领风骚,在职场中无人不知,无人不晓.但是随着大数据的出现,EXCEL便风光不再,江河日下,一度被其他大数据工具挤到了后面,逐渐被边缘化了.而我是一个EX ...

  5. vim插件ctags的安装和使用

    vim插件ctags的安装和使用 2013-11-19 20:47 17064人阅读 评论(0) 收藏 举报  分类: 开发工具(3)  linux编程(9)  c/c++编程(11)  版权声明:本 ...

  6. NSIS:使用PassDialog插件实现密码安装(卸载)功能

    原文 NSIS:使用PassDialog插件实现密码安装(卸载)功能 有时,出于特殊的需求,我们要给安装或卸载程序加一个密码,只有输入了正确的密码才可以继续.比如: 下面我们使用插件来实现安装密码: ...

  7. IDEA翻译插件推荐Translation 安装和使用以及快捷键绑定

    首先第一步是安装该插件 如图: File -> setting -->plugins 进入该页面,点击如图所示按钮. 然后搜索 Translation 如图: 我们需要的结果一般都不会排在 ...

  8. vim学习、各类插件配置与安装

    vim学习.各类插件配置与安装 vim 插件 配置 1. vim学习 vim基础学习:根据网上流行基础文章<简明Vim练级攻略>,进阶书籍<vim实用技巧>.注:进阶书籍可以在 ...

  9. 免费高端出辕营,横空出世惊鬼神 Excel插件:ExcelPower_Helper 0.41初出茅庐

    免费高端出辕营,横空出世惊鬼神 Excel插件:ExcelPower_Helper 0.41初出茅庐        隐鹤 倾心开发 2019.4.1 1.   引言 经过前后大约零零散散的一年的开发, ...

  10. 【小o地图Excel插件版】计算两点间驾车路径,获取途径道路、驾车距离、耗时等信息

    小o地图Excel插件版:一款基于Excel软件开发的地图软件,提供基于Excel表格进行地理数据挖掘.地理数据分析.地图绘制.地图图表等功能的工具类软件.具有易用.高效.稳定的特点,能够满足地理数据 ...

随机推荐

  1. 领福利 | 腾讯千帆HR数字化专场,教你数字时代的技术招聘秘笈

    HR难,做技术招聘的HR难上加难 技术部门急需用人,收到的简历却寥寥无几? 推了简历,却被用人部门告知完全不合适? 候选人过了面试,却鸽了offer? 桥豆麻袋! 腾讯千帆联合ShowMeBug举办 ...

  2. Galaxy 生信平台(三):xlsx 上传与识别

    我在<Firefox Quantum 向左,Google Chrome 向右>中,曾经吐槽过在 Firefox 中使用 Galaxy 上传本地的 Excel 文件时,会出现 xlsx 无法 ...

  3. Anaconda 使用的一些体验与困惑

    Channels 使用 需要注意的是做生信分析的童鞋使用 conda 环境时一定要特别注意 conda channels 的设置,滥用 channels 很有可能会导致你的软件升降级(甚至环境)错乱. ...

  4. Docusaurus之markdown文档的vscode代码片段

    需求 我是使用Docusaurus建立的个人站点,在写文档是总是要在开头配置作者.日期等等,用过Docusaurus的都应该知道. 因为每次新建一个md文档都需要重新配置,很麻烦,于是我就想能不能新建 ...

  5. 10分钟讲清int 和 Integer 的区别

    其实在Java编程中,int和Integer都是非常常用的数据类型,但它们之间存在一些关键的区别,特别是在面向对象编程中.所以接下来,就让我们一起来探讨下关于int和Integer的区别这个问题吧. ...

  6. JVM中的编译器

    JVM中集成了两种编译器,Client Compiler和Server Compiler,它们的作用也不同.Client Compiler注重启动速度和局部的优化,Server Compiler则更加 ...

  7. 嵌入式低功耗WiFi设备保活功耗分析

    (一)嵌入式低功耗设备介绍 在物联网(IoT)领域,设备可以使用以太网和无线网进行网络连接. 以太网: 网络稳定,带宽高,延迟低,但是以太网需要拉网布线,设备安装邻活便利性能差. 无线网络:安装位置灵 ...

  8. Day05_Java_作业

    A:看程序写结果(写出自己的分析理由),程序填空,改错,看程序写结果. 1.看程序写结果 class Demo { public static void main(String[] args) { i ...

  9. 跟运维学 Linux - 01

    跟运维学 Linux - 01 运维的诞生 运维工程师有很多叫法:系统运维.Linux 工程师.系统管理员... 网管可以说是运维工程师最早的雏形.在个人电脑未普及时,大家去网吧玩游戏. 玩家:&qu ...

  10. Linux 软件包:kernel*

    运行命令: # rpm -qa | grep $(uname -r) | while read pkgname ; do echo "### $pkgname ###" ; rpm ...