go语言后端开发学习(二)——基于七牛云实现的资源上传模块

简介: go语言后端开发学习(二)——基于七牛云实现的资源上传模块

前言

在之前的文章中我介绍过我们基于gin框架怎么实现本地上传图片和文本这类的文件资源(具体文章可以参考gin框架学习笔记(二) ——相关数据与文件的响应),但是在我们实际上的项目开发中一般却是不会使用本地上传资源的方式来上传的,因为文件的上传与读取会频繁进行磁盘读写,会造成资源的不必要浪费,所以我们一般会寻找第三方平台来托管我们的一些文件资源,而这也就是我们今天的主题——基于七牛云平台来实现我们的资源上传模块

注册七牛云平台

然后我们点击对象存储尝试创建存储空间,填写信息:

博主提前创建了一个空间来存储今天我们要测试的文件:

然后接下来我们来看一下如何实现资源的上传。

资源上传模块的上传

一.相关环境的配置与配置文件的编写与读取

由于使用七牛云进行对象存储需要使用七牛云的第三方SDK,这需要我们使用第三方库,下载命令如下:

go get github.com/qiniu/go-sdk/v7

和之前JWT登录验证一样我们首先来配置一下我们的配置文件:

[qiniuyun]
Zone=
Bucket=
AccessKey=
SecretKey=
Domain=

上面的就是我们主要要配置的信息了,由于这个信息私密性比较强,我就不展示我的具体内容了,大家见谅,接下来我给大家讲一下每个参数的作用:

  • Zone:这个参数主要是指定仓库内的存储区域,比如你是华东区域,那这里就是storage.ZoneHuadong(注意: 博主这里用的是国内的,也推荐大家用国内的,国外的访问速度比较慢,可能会影响使用体验)
  • Bucket:你的空间名称
  • AccessKey与SecretKey:个人密钥,Go SDK 的所有的功能,都需要合法的授权。授权凭证的签算需要七牛账号下的一对有效的Access Key和Secret Key,这个到个人中心的密钥管理中就可以找到了。
  • Domain:域名,主要是我们进行文件访问的时候会使用,可以使用七牛云所提供的临时域名,也可以使用自己的个人域名。

配置好了配置文件后我们就可以来读取配置文件了,老规矩,还是go-ini包,如果不知道的话可以参考博主的文章:

go语言并发实战——日志收集系统(五) 基于go-ini包读取日志收集服务的配置文件

读取配置的代码如下:

package utils
import (
  "fmt"
  "github.com/sirupsen/logrus"
  "gopkg.in/ini.v1"
)
type Config struct {
  Server         *server    `ini:"server"`
  Database       *database  `ini:"database"`
  QiniuyunServer *qNYServer `ini:"qiniuyun"`
}
type server struct {
  AppMode  string `ini:"AppMode"`
  HttpPort string `ini:"HttpPort"`
  JWTKey   string `ini:"JWTKey"`
}
type database struct {
  Db         string `ini:"Db"`
  DbName     string `ini:"DbName"`
  DbUser     string `ini:"DbUser"`
  DbPassWord string `ini:"DbPassWord"`
  DbHost     string `ini:"DbHost"`
  DbPort     string `ini:"DbPort"`
}
type qNYServer struct {
  AccessKey string `ini:"AccessKey"`
  SecretKey string `ini:"SecretKey"`
  Bucket    string `ini:"Bucket"`
  Domain    string `ini:"Domain"`
  Zone      int    `ini:"Zone"`
}
var ServerSetting = &server{
  AppMode:  "debug",
  HttpPort: ":3000",
  JWTKey:   "LuoYu123",
}
var DatabaseSetting = &database{
  Db:         "mysql",
  DbName:     "goblog",
  DbUser:     "root",
  DbPassWord: "ba161754",
  DbHost:     "localhost",
  DbPort:     "3306",
}
var QiniuyunServer = &qNYServer{
  AccessKey: "your_access_key",
  SecretKey: "your_secret_key",
  Bucket:    "your_bucket",
  Domain:    "your_domain",
  Zone:      1,
}
// Config_Message
var Config_Message = &Config{
  Server:         ServerSetting,
  Database:       DatabaseSetting,
  QiniuyunServer: QiniuyunServer,
}
func init() {
  filename := "config/config.ini"
  cfg, err := ini.Load(filename)
  if err != nil {
    logrus.Errorf("配置文件加载失败: %v", err)
  }
  err = cfg.MapTo(Config_Message)
  if err != nil {
    logrus.Errorf("配置文件映射失败: %v", err)
  }
  logrus.Infof("配置文件加载成功")
  fmt.Println(Config_Message.QiniuyunServer.Domain)
}

数据模型中上传模块的书写

package model
import (
  "context"
  "gin_vue_blog/utils"
  "gin_vue_blog/utils/errmsg"
  "github.com/qiniu/go-sdk/v7/auth/qbox"
  "github.com/qiniu/go-sdk/v7/storage"
  "mime/multipart"
)
var server = utils.Config_Message.QiniuyunServer
func UploadFile(file multipart.File, fileSize int64) (string, int) {
  putPolicy := storage.PutPolicy{
    Scope: server.Bucket,
  }
  // 获取上传token
  mac := qbox.NewMac(server.AccessKey, server.SecretKey)
  upToken := putPolicy.UploadToken(mac)
  // 设置上传配置
  cfg := setConfig()
  // 构建表单上传的对象
  formUploader := storage.NewFormUploader(cfg)
  ret := storage.PutRet{}
  putExtra := storage.PutExtra{}
  err := formUploader.PutWithoutKey(context.Background(), &ret, upToken, file, fileSize, &putExtra)
  if err != nil {
    return "", errmsg.ERROR
  }
  url := server.Domain + ret.Key
  return url, errmsg.SUCCESS
}
func setConfig() *storage.Config {
  return &storage.Config{
    Region:        selectZone(server.Zone),
    UseHTTPS:      false,
    UseCdnDomains: false,
  }
}
func selectZone(Zone int) *storage.Zone {
  switch server.Zone {
  case 1:
    return &storage.ZoneHuadong
  case 2:
    return &storage.ZoneHuadongZheJiang2
  case 3:
    return &storage.ZoneHuabei
  case 4:
    return &storage.ZoneHuanan
  default:
    return &storage.ZoneHuadong
  }
}

备注:selectZone是因为我那里使用的是数字代指这里转换一下

上传文件路由的书写

package v1
import (
  "gin_vue_blog/model"
  "gin_vue_blog/utils/errmsg"
  "github.com/gin-gonic/gin"
)
func Upload(c *gin.Context) {
  file, fileHeader, _ := c.Request.FormFile("file")
  filesize := fileHeader.Size
  url, code := model.UploadFile(file, filesize)
  c.JSON(200, gin.H{
    "status":  code,
    "message": errmsg.GetErrMsg(code),
    "url":     url,
  })
}

运行并测试

如上所示:我们成功的上传了一张图片,大家有兴趣可以试试这个url是否可以使用:

http://sepff60lp.hd-bkt.clouddn.com/Fse9JUhe5miWPy2rNI0qtfGrSBSJ
相关文章
|
5天前
|
Go 索引
go语言中的循环语句
【11月更文挑战第4天】
15 2
|
5天前
|
Go C++
go语言中的条件语句
【11月更文挑战第4天】
19 2
|
5天前
|
Go
go语言中的 跳转语句
【11月更文挑战第4天】
14 4
|
5天前
|
JSON 安全 Go
Go语言中使用JWT鉴权、Token刷新完整示例,拿去直接用!
本文介绍了如何在 Go 语言中使用 Gin 框架实现 JWT 用户认证和安全保护。JWT(JSON Web Token)是一种轻量、高效的认证与授权解决方案,特别适合微服务架构。文章详细讲解了 JWT 的基本概念、结构以及如何在 Gin 中生成、解析和刷新 JWT。通过示例代码,展示了如何在实际项目中应用 JWT,确保用户身份验证和数据安全。完整代码可在 GitHub 仓库中查看。
20 1
|
15天前
|
API 持续交付 开发者
后端开发中的微服务架构实践与挑战
在数字化时代,后端服务的构建和管理变得日益复杂。本文将深入探讨微服务架构在后端开发中的应用,分析其在提高系统可扩展性、灵活性和可维护性方面的优势,同时讨论实施微服务时面临的挑战,如服务拆分、数据一致性和部署复杂性等。通过实际案例分析,本文旨在为开发者提供微服务架构的实用见解和解决策略。
|
8天前
|
存储 SQL API
探索后端开发:构建高效API与数据库交互
【10月更文挑战第36天】在数字化时代,后端开发是连接用户界面和数据存储的桥梁。本文深入探讨如何设计高效的API以及如何实现API与数据库之间的无缝交互,确保数据的一致性和高性能。我们将从基础概念出发,逐步深入到实战技巧,为读者提供一个清晰的后端开发路线图。
|
7天前
|
JSON 前端开发 API
后端开发中的API设计与文档编写指南####
本文探讨了后端开发中API设计的重要性,并详细阐述了如何编写高效、可维护的API接口。通过实际案例分析,文章强调了清晰的API设计对于前后端分离项目的关键作用,以及良好的文档习惯如何促进团队协作和提升开发效率。 ####
|
9天前
|
存储 SQL 数据库
深入浅出后端开发之数据库优化实战
【10月更文挑战第35天】在软件开发的世界里,数据库性能直接关系到应用的响应速度和用户体验。本文将带你了解如何通过合理的索引设计、查询优化以及恰当的数据存储策略来提升数据库性能。我们将一起探索这些技巧背后的原理,并通过实际案例感受优化带来的显著效果。
28 4
|
8天前
|
Web App开发 JavaScript 前端开发
深入浅出Node.js后端开发
【10月更文挑战第36天】本文将引导您探索Node.js的世界,通过实际案例揭示其背后的原理和实践方法。从基础的安装到高级的异步处理,我们将一起构建一个简单的后端服务,并讨论如何优化性能。无论您是新手还是有经验的开发者,这篇文章都将为您提供新的视角和深入的理解。
|
13天前
|
Web App开发 存储 JavaScript
深入浅出Node.js后端开发
【10月更文挑战第31天】本文将引导你进入Node.js的奇妙世界,探索其如何革新后端开发。通过浅显易懂的语言和实际代码示例,我们将一起学习Node.js的核心概念、搭建开发环境,以及实现一个简单但完整的Web应用。无论你是编程新手还是希望拓展技术的开发者,这篇文章都将为你打开一扇通往高效后端开发的大门。