使用 Go 开发命令行工具-OSS 文件上传

Go 专栏收录该内容
2 篇文章 0 订阅

使用 Go 开发命令行工具-OSS 文件上

使用 Go 语言开发一个命令行工具,用于向 OSS 文件上传文件
命令行工具有很多框架,选择使用 Cobra

准备

  • 安装 Cobra
go get -u github.com/spf13/cobra/cobra

初始化项目

  • 创建项目
cd $GOPATH/src
mkdir oss
cd oss
cobra init --pkg-name oss

此时,已经创建了一个 oss 的目录,里面已经包含一个 root 命令

.
├── LICENSE
├── cmd
│   └── root.go
└── main.go

1 directory, 3 files

运行 go run main.go查看root 命令

go run main.go
A longer description that spans multiple lines and likely contains
examples and usage of using your application. For example:

Cobra is a CLI library for Go that empowers applications.
This application is a tool to generate the needed files
to quickly create a Cobra application.
  • 添加 mod

添加mod 是为了更方便的管理依赖,module 设置 GitHub 是为了安装方便

export GO111MODULE=on
go mod init github.com/helloworlde/oss

同时需要改下 mian.go中的包名,由oss/cmd改为 github.com/helloworlde/oss/cmd,如果是在GoLand 这样的 IDE 中,还需要启用Enable Go Modules (vgo) integration

添加命令

  • 添加一个 Upload 命令
cobra add upload

此时,会在 cmd/下新建一个upload.go的文件,包含基本的运行 upload 命令的代码

go run main.go upload

upload called

upload.go中添加相应的逻辑,具体可以参考 getting-started

var uploadCmd = &cobra.Command{
	Use:   "upload [file]",
	Short: "Upload file to OSS",
	Long:  ``,
	Args: func(cmd *cobra.Command, args []string) error {
		if len(args) < 1 {
			return errors.New("requires at least one file path")
		}
		return nil
	},
	Run: func(cmd *cobra.Command, args []string) {
		dir := cmd.Flag("directory").Value.String()
		picture := cmd.Flag("picture").Value.String()
		markdown := cmd.Flag("markdown").Value.String()

		if !util.ValidateConfig(ossConfig) {
			os.Exit(1)
		}

		bucket := util.InitBucket(ossConfig)
		util.UploadFile(ossDir, path, ossConfig, *bucket)
	},
}

func init() {
	rootCmd.AddCommand(uploadCmd)

	uploadCmd.Flags().StringP("directory", "d", "", "Dictionary of upload file")
	uploadCmd.Flags().BoolP("picture", "p", true, "Upload to Picture folder")
	uploadCmd.Flags().BoolP("markdown", "m", false, "Print link as Markdown")
}

发布

先将代码上传到 GitHub,然后可以通过 goreleaser 这个工具来发布;需要注意的是,Repo 的名字要和 Module 一致,否则会在安装时提示 Module 不匹配

安装配置 goreleaser

  • 安装
brew install goreleaser
  • 配置

goreleaser 发布时需要使用 GitHub 的 Token,然后需要将 GitHub Token 添加到环境变量中

export GITHUB_TOKEN=`YOUR_GITHUB_TOKEN`

发布

  • 项目中添加 goreleaser 配置
goreleaser init
  • 添加Tag
git tag -a v0.0.1 -m "First release"
git push origin v0.1.0
  • 发布
goreleaser --rm-dist

待上传完成后就可以在 GitHub Release 页面看到刚才发布的版本

oss-tool.png

使用

安装

go get -u github.com/helloworlde/oss

使用

  • 上传文件
oss upload oss-tool.png
  • 上传到指定文件夹
oss upload oss-tool.png -d images/png
  • 上传文件夹
oss upload ./cmd -d cmd
  • 上传图片到指定文件夹
oss upload oss-tool.png -p
  • 上传图片后输出 Markdown 格式
oss upload oss-tool.png -p -m

GitHub

https://github.com/helloworlde/oss

  • 0
    点赞
  • 0
    评论
  • 1
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

打赏
文章很值,打赏犒劳作者一下
相关推荐
©️2020 CSDN 皮肤主题: 编程工作室 设计师:CSDN官方博客 返回首页

打赏

呜呜呜啦啦啦

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值