template_normal.tpl 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. # MinDoc 简介
  2. [![Build Status](https://travis-ci.org/lifei6671/mindoc.svg?branch=master)](https://travis-ci.org/lifei6671/mindoc)
  3. MinDoc 是一款针对IT团队开发的简单好用的文档管理系统。
  4. MinDoc 的前身是 SmartWiki 文档系统。SmartWiki 是基于 PHP 框架 laravel 开发的一款文档管理系统。因 PHP 的部署对普通用户来说太复杂,所以改用 Golang 开发。可以方便用户部署和实用。
  5. 开发缘起是公司IT部门需要一款简单实用的项目接口文档管理和分享的系统。其功能和界面源于 kancloud 。
  6. 可以用来储存日常接口文档,数据库字典,手册说明等文档。内置项目管理,用户管理,权限管理等功能,能够满足大部分中小团队的文档管理需求。
  7. 演示站点: [http://doc.iminho.me](http://doc.iminho.me)
  8. # 安装与使用
  9. **如果你的服务器上没有安装golang程序请手动设置一个环境变量如下:键名为 ZONEINFO,值为MinDoc跟目录下的/lib/time/zoneinfo.zip 。**
  10. **Windows 教程:** [https://github.com/lifei6671/mindoc/blob/master/README_WIN.md](docs/README_WIN.md)
  11. **Linux 教程:**  [https://github.com/lifei6671/mindoc/blob/master/README_LINUX.md](docs/README_LINUX.md)
  12. **PDF 导出配置教程**  [https://github.com/lifei6671/mindoc/blob/master/docs/README_LINUX.md](docs/WKHTMLTOPDF.md)
  13. 对于没有Golang使用经验的用户,可以从 [https://github.com/lifei6671/mindoc/releases](https://github.com/lifei6671/mindoc/releases) 这里下载编译完的程序。
  14. 如果有Golang开发经验,建议通过编译安装。
  15. ```bash
  16. git clone https://github.com/lifei6671/mindoc.git
  17. go get -d ./...
  18. go build -ldflags "-w"
  19. ```
  20. MinDoc 使用MySQL储存数据,且编码必须是`utf8mb4_general_ci`。请在安装前,把数据库配置填充到项目目录下的 conf/app.conf 中。
  21. 如果conf目录下不存在 app.conf 请重命名 app.conf.example 为 app.conf。
  22. 如果 MinDoc 根目录下存在 install.lock 文件表示已经初始化过数据库,想要重新初始化数据库,只需要删除该文件重新启动程序即可。
  23. **默认程序会自动创建表,同时初始化一个超级管理员用户:admin 密码:123456 。请登录后重新设置密码。**
  24. ## Linux 下后台运行
  25. 在 Linux 如果想让程序后台运行可以执行如下命令:
  26. ```bash
  27. #使程序后台运行
  28. nohup ./godoc &
  29. ```
  30. 该命令会使程序后台执行,但是服务器重启后不会自动启动服务。
  31. 使用 supervisor 做服务,可以使服务器重启后自动重启 MinDoc。
  32. ## Windows 下后台运行
  33. Windows 下后台运行需要借助 CMD 命令行命令:
  34. ```bash
  35. #在MinDoc跟目录下新建一个slave.vbs文件:
  36. Set ws = CreateObject("Wscript.Shell")
  37. ws.run "cmd /c start.bat",vbhide
  38. #再建一个start.bat文件:
  39. @echo off
  40. godoc_windows_amd64.exe
  41. ```
  42. 启动时双击slave.vbs即可,等待程序初始化完数据库会在该目录下创建一个install.lock文件,标识已安装成功。
  43. 如果是自己编译,可以用以下命令即可编译出不依赖cmd命令的后台运行的程序:
  44. ```bash
  45. go build -ldflags "-H=windowsgui"
  46. ```
  47. 通过该命令编译的Golang程序在Windows上默认后台运行。
  48. 请将将 MinDoc 加入开机启动列表,使程序开机启动。
  49. ## 密码找回功能
  50. 密码找回功能依赖邮件服务,因此,需要配置邮件服务才能使用该功能,该配置位于 `conf/app.conf` 中:
  51. ```bash
  52. #邮件配置
  53. #是否启用邮件
  54. enable_mail=true
  55. #smtp服务器的账号
  56. [email protected]
  57. #smtp服务器的地址
  58. smtp_host=smtp.ym.163.com
  59. #密码
  60. smtp_password=1q2w3e__ABC
  61. #端口号
  62. smtp_port=25
  63. #邮件发送人的地址
  64. [email protected]
  65. #邮件有效期30分钟
  66. mail_expired=30
  67. ```
  68. # 使用Docker部署
  69. 如果是Docker用户,可参考项目内置的Dockerfile文件编译镜像。
  70. 在启动镜像时需要提供如下的环境变量:
  71. ```ini
  72. MYSQL_PORT_3306_TCP_ADDR MySQL地址
  73. MYSQL_PORT_3306_TCP_PORT MySQL端口号
  74. MYSQL_INSTANCE_NAME MySQL数据库名称
  75. MYSQL_USERNAME MySQL账号
  76. MYSQL_PASSWORD MySQL密码
  77. HTTP_PORT 程序监听的端口号
  78. ```
  79. 举个栗子
  80. ```bash
  81. docker run -p 8181:8181 -e MYSQL_PORT_3306_TCP_ADDR=127.0.0.1 -e MYSQL_PORT_3306_TCP_PORT=3306 -e MYSQL_INSTANCE_NAME=mindoc_db -e MYSQL_USERNAME=root -e MYSQL_PASSWORD=123456 -e httpport=8181 -d daocloud.io/lifei6671/mindoc:latest
  82. ```
  83. # 项目截图
  84. **创建项目**
  85. ![创建项目](https://raw.githubusercontent.com/lifei6671/mindoc/master/uploads/20170501204438.png)
  86. **项目列表**
  87. ![项目列表](https://raw.githubusercontent.com/lifei6671/mindoc/master/uploads/20170501203542.png)
  88. **项目概述**
  89. ![项目概述](https://raw.githubusercontent.com/lifei6671/mindoc/master/uploads/20170501203619.png)
  90. **项目成员**
  91. ![项目成员](https://raw.githubusercontent.com/lifei6671/mindoc/master/uploads/20170501203637.png)
  92. **项目设置**
  93. ![项目设置](https://raw.githubusercontent.com/lifei6671/mindoc/master/uploads/20170501203656.png)
  94. **基于Editor.md开发的Markdown编辑器**
  95. ![基于Editor.md开发的Markdown编辑器](https://raw.githubusercontent.com/lifei6671/mindoc/master/uploads/20170501203854.png)
  96. **基于wangEditor开发的富文本编辑器**
  97. ![基于wangEditor开发的富文本编辑器](https://raw.githubusercontent.com/lifei6671/mindoc/master/uploads/20170501204651.png)
  98. **项目预览**
  99. ![项目预览](https://raw.githubusercontent.com/lifei6671/mindoc/master/uploads/20170501204609.png)
  100. **超级管理员后台**
  101. ![超级管理员后台](https://raw.githubusercontent.com/lifei6671/mindoc/master/uploads/20170501204710.png)
  102. # 使用的技术
  103. - beego 1.8.1
  104. - mysql 5.6
  105. - editor.md
  106. - bootstrap 3.2
  107. - jquery 库
  108. - layer 弹出层框架
  109. - webuploader 文件上传框架
  110. - Nprogress 库
  111. - jstree 树状结构库
  112. - font awesome 字体库
  113. - cropper 图片剪裁库
  114. - layer 弹出层框架
  115. - highlight 代码高亮库
  116. - to-markdown HTML转Markdown库
  117. - wangEditor 富文本编辑器
  118. # 主要功能
  119. - 项目管理,可以对项目进行编辑更改,成员添加等。
  120. - 文档管理,添加和删除文档等。
  121. - 评论管理,可以管理文档评论和自己发布的评论。
  122. - 用户管理,添加和禁用用户,个人资料更改等。
  123. - 用户权限管理 , 实现用户角色的变更。
  124. - 项目加密,可以设置项目公开状态,私有项目需要通过Token访问。
  125. - 站点配置,可开启匿名访问、验证码等。
  126. # 参与开发
  127. 我们欢迎您在 MinDoc 项目的 GitHub 上报告 issue 或者 pull request。
  128. 如果您还不熟悉GitHub的Fork and Pull开发模式,您可以阅读GitHub的文档(https://help.github.com/articles/using-pull-requests) 获得更多的信息。
  129. # 关于作者
  130. 一个不纯粹的PHPer,一个不自由的 gopher 。