一飞开源,介绍创意、新奇、有趣、实用的开源应用、系统、软件、硬件及技术,一个探索、发现、分享、使用与互动交流的开源技术社区平台。致力于打造活力开源社区,共建开源新生态!
一、开源项目简介
moredoc - 魔豆文库,由 深圳市摩枫网络科技(Morefun Network Technology Co., Ltd ) 使用 Golang 开发的类似百度文库、新浪爱问文库的开源文库系统,支持 TXT、PDF、EPUB、MOBI、Office 等格式文档的在线预览与管理,为 dochub文库的重构版本。
使用Apache-2.0开源协议
四、功能概述
注:当前只是 1.0 版本,只有PC站点,移动端适配以及小程序等更多功能将在后续版本推出。
关于魔豆文库安装部署以及使用和二次开发等更详细的教程,详见书栈网《魔豆文库使用手册》
除了文件上传相关的接口,其他接口统一使用 proto 进行定义。
请自行配置相应环境。如在此过程中遇到错误,请根据错误提示自行通过 Google 或者百度解决。
部分目录,在程序运行时自动生成,不需要手动创建
. ├── LICENSE # 开源协议 ├── Makefile # 编译脚本 ├── README.md # 项目说明 ├── api # proto api, API协议定义 ├── app.example.toml # 配置文件示例,需要复制为 app.toml ├── biz # 业务逻辑层,主要处理业务逻辑,实现api接口 ├── cmd # 命令行工具 ├── cache # 缓存相关 ├── conf # 配置定义 ├── dict # 结巴分词字典,用于给文档自动进行分词 ├── dist # 前端打包后的文件 ├── docs # API文档等 ├── documents # 用户上传的文档存储目录 ├── go.mod # go依赖管理 ├── go.sum # go依赖管理 ├── main.go # 项目入口 ├── middleware # 中间件 ├── model # 数据库模型,使用gorm对数据库进行操作 ├── release # 版本发布生成的版本会放到这里 ├── service # 服务层,衔接cmd与biz ├── sitemap # 站点地图 ├── third_party # 第三方依赖,主要是proto文件 ├── uploads # 文档文件之外的其他文件存储目录 ├── util # 工具函数 └── web # 前端Web
# 程序运行级别:debug、info、warn、error level="debug" # 日志编码方式,支持:json、console logEncoding="console" # 后端监听端口 port="8880" # 数据库配置 [database] driver="mysql" dsn="root:root@tcp(localhost:3306)/moredoc?charset=utf8mb4&loc=Local&parseTime=true" showSQL=true maxOpen=10 maxIdle=10 # jwt 配置 [jwt] secret="moredoc" expireDays=365
后端初始化
# 安装go依赖 go mod tidy # 初始化工程依赖 make init # 编译proto api make api # 修改 app.toml 文件配置 cp app.example.toml app.toml # 编译后端 go build -o moredoc main.go # 初始化数据库结构 ./moredoc syncdb # 运行后端(可用其他热编译工具),监听8880端口 go run main.go serve
前端初始化
# 切换到web目录 cd web # 安装依赖 npm install # 运行前端,监听3000端口,浏览器访问 http://localhost:3000 npm run dev
admin mnt.ltd
以下为示例
# 打标签 git tag -a v1.0.0 -m "release v1.0.0" # 推送标签 git push origin v1.0.0 # 编译前端 cd web && npm run generate # 编译后端,编译好了的版本会放到release目录下 # 编译linux版本(Windows版本用 make buildwin) make buildlinux
感谢各开源项目为魔豆文库的开发奠定了基础。相关开源项目,后端依赖,详见 go.mod;前端依赖,详见 web/package.json。
评论