博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
draw.io环境搭建
阅读量:6608 次
发布时间:2019-06-24

本文共 2033 字,大约阅读时间需要 6 分钟。

  hot3.png

前言

draw.io是一款在github上的开源产品,由于需要构建在线文档,需要插入画图类型,

对比多款开源产品,最终选择了draw.io。

draw.io图标资源非常的丰富,方便导入图标资源,基本上现有的图标就能满足大部分的需求。

搭建drawio

draw.io的github地址在,可以在release下载正式版本,我们此次下载的是源码版本。

git clone https://github.com/jgraph/drawio.git

编译的话,需要安装ant等环境。

yum install -y ant java-1.8.0-openjdk-devel

接下来,就是需要编译了。

cd etc/build && ant

如果需要生成war包的话,则如下编译

cd etc/build && ant war

编译成功后,war包会生成在drawio/build/draw.war,如果你有tomcat或java的服务环境,可以使用war包部署。整体来说,还是不用war的方便一些,只要有Apache就可以搞定了。

将drawio/war拷贝到www/drawio目录(根据你自己服务器的环境而定)。访问http://xxx.xxx.xxx.xxx/drawio

默认draw.io是强制https的,如果站点没有的话,则可以加上:http://xxx.xxx.xxx.xxx/drawio/index.html?https=0则关闭https,当然,如果你并不打算支持https的话,可以将index.html中的

1

2

3

4

5

6

7

8

9

10

11

12

13

14

if (urlParams['demo'] != '1')

{

    var ssl = (urlParams['https'] != null) ? urlParams['https'] == '1' :

        navigator.userAgent.indexOf('MSIE') < 0 || document.documentMode >= 9;    

    if (ssl && proto != 'https:')

    {

        proto = 'https:';

    }

    else if (!ssl && proto != 'http:')

    {

        proto = 'http:';

    }

}

改成:

1

2

3

4

if (urlParams['demo'] != '1')

{    proto = 'http:';

}

看看效果:

非常之不错,支持的图标也很全,本地访问也非常的快!其还支持离线模式,就是在访问的参数上加上offline=1也就是http://xxx.xxx.xxx.xxx/drawio/index.html?offline=1

之前阿里云9块钱搞了个云虚拟空间,拿过来搭建了drawio,可以访问我的域名:

(虚拟主机到期了,因此暂时下线了!)

docker支持

2018年8月18日看了下drawio新的github,新的添加了对docker的支持。

还是需要按上面的步骤,将代码clone下来,如果已经clone过的话,git pull下工程。

1

2

cd drawio # 切换到工程源码目录

docker build -t drawio -f etc/docker/Dockerfile . # 执行drawio编译以及生成docker镜像

之后,我们就可以通过docker images -a查看到镜像:

1

2

3

docker images -a

REPOSITORY TAG IMAGE ID CREATED SIZE

drawio latest 1496a474a227 33 minutes ago 723MB

运行drawio容器的话,github上提供的端口号是错误的,默认tomcat已经是监听了8080的端口。因此我们这里做了修订:

1

docker run -d -p 8080:8080 --restart=always --hostname=drawio --name drawio drawio

但是由于docker镜像并未对中文有做支持,因此部分字体会出现乱码,暂时可以通过访问: 来访问drawio的程序。后续有时间,我再修订下docker镜像,保证中文没问题!

桌面版本

draw.io目前也提供了桌面版本,也就是离线的版本,对于国内用户来说,桌面版本更加的方便,也放到了github上了:

由于是使用了electron-app技术,因此实现了跨平台的支持,支持windows/MAC/Linux。强烈推荐不是很折腾的,用桌面版本。桌面版本现在唯一的一个缺点就是不支持直接黏贴拷贝到doc文档里面。每次还是需要导出PNG图片再贴图。

本博文引用一览: 

转载于:https://my.oschina.net/moks/blog/3048687

你可能感兴趣的文章
频率域滤波
查看>>
图片存储类型的种类、特点、区别
查看>>
GETTING UP AND RUNNING WITH NODE.JS, EXPRESS, JADE, AND MONGODB
查看>>
求二叉树第K层节点的个数
查看>>
MySQLs数据库建外键时自动跑到缩影处,真奇怪
查看>>
static关键字
查看>>
js 合并多个对象 Object.assign
查看>>
Java 反射机制
查看>>
Unity 碰撞检测中碰撞器与触发器的区别
查看>>
Elasticsearch配置文件说明
查看>>
初识java
查看>>
temporary Object and destructor
查看>>
xcode - 移动手势
查看>>
细说浏览器特性检测(1)-jQuery1.4添加部分
查看>>
古中国数学家的计算力真是惊人
查看>>
Java基础-算术运算符(Arithmetic Operators)
查看>>
C#编程(四十七)----------集合接口和类型
查看>>
【转】关于大型网站技术演进的思考(十二)--网站静态化处理—缓存(4)
查看>>
积跬步,聚小流------Bootstrap学习记录(1)
查看>>
HDUPhysical Examination(贪心)
查看>>