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
相关文章
|
1天前
|
Kubernetes 监控 开发者
探索后端开发中的微服务架构实践
在现代软件开发领域,微服务架构作为一种灵活、可扩展的后端解决方案,正逐渐取代传统的单体式架构。本文将深入探讨微服务的设计理念、实施策略及其在企业级应用中的具体应用案例,旨在为读者提供一套系统的微服务实践指南。通过对比分析微服务与单体架构的性能差异,结合具体数据和案例研究,本文揭示了微服务在提高系统可维护性、可扩展性和敏捷性方面的优势。最后,文章讨论了微服务实施过程中可能遇到的挑战及解决策略,为后端开发者提供了宝贵的参考和启示。
|
2天前
|
Kubernetes 搜索推荐 开发者
探索后端开发的未来之路:微服务架构与容器化技术
随着云计算技术的不断成熟和普及,后端开发领域正经历着前所未有的变革。本文将深入探讨微服务架构和容器化技术如何重塑后端开发的面貌,提升系统的可扩展性、灵活性和可靠性。通过分析现代后端系统面临的挑战,我们将展示微服务和容器化如何提供解决方案,并预测这些技术如何塑造后端开发的未来发展。
16 3
|
10天前
|
缓存 算法 API
深入理解后端开发中的缓存策略
【7月更文挑战第15天】缓存是提高后端系统性能和扩展性的关键机制之一。本文将深入探讨后端开发中缓存的应用,包括缓存的基本原理、类型、以及在实际应用中的策略。我们将从缓存的定义开始,逐步介绍缓存在数据库查询、API响应和分布式系统中的优化作用。通过实例分析常见的缓存模式,如LRU、LFU和FIFO,并讨论它们在不同场景下的适用性。最后,文章还将涵盖缓存一致性问题和解决方案,帮助读者构建高效且可靠的后端系统。
|
2天前
|
消息中间件 监控 Kubernetes
后端开发中的微服务架构实践与挑战
在数字化时代的浪潮下,后端开发不断演化,微服务架构应运而生,成为解决复杂系统设计问题的一种新范式。本文将深入探讨微服务架构的核心概念、实施策略以及面临的主要技术挑战,同时结合具体案例分析其在实际开发中的应用效果和价值体现,旨在为后端开发人员提供一套系统的微服务实践指南和思考框架。
|
8天前
|
Kubernetes API 开发者
探索现代后端开发中的微服务架构
【7月更文挑战第17天】本文深入探讨了微服务架构在现代后端开发中的应用,分析了其设计原则、优势以及面临的挑战。通过具体实例,展示了如何有效实施微服务架构,并讨论了相关技术栈的选择。文章旨在为后端开发者提供微服务实施的指导和最佳实践。
|
4天前
|
敏捷开发 消息中间件 监控
探索后端开发中的微服务架构
本文深入探讨了微服务架构在后端系统设计中的关键作用,分析了其优势、挑战与实施策略。通过比较传统单体应用与微服务的异同,文章阐述了微服务如何促进敏捷开发和持续交付,同时指出了在采用微服务时可能遇到的技术债务和管理复杂性问题。结合具体案例,本文为读者提供了关于如何有效实施微服务的实用建议。 【7月更文挑战第21天】
|
8天前
|
消息中间件 运维 API
探索后端开发中的微服务架构实践
本文将深入探讨微服务架构在后端开发中的应用,包括其设计原则、优势与挑战。通过对具体案例的分析,我们将了解如何在实际项目中有效实施微服务,以及如何克服实施过程中的常见问题。文章旨在为后端开发人员提供一套微服务架构的实践指南,帮助他们构建更加灵活、可扩展的系统。
20 1
|
1天前
|
缓存 安全 API
后端开发中的API设计原则与实践
在数字化时代的浪潮中,后端开发作为技术架构的核心,承载着数据交互与业务逻辑的重要职责。本文深入探讨了API设计的艺术与科学,从RESTful原则到安全性考量,再到性能优化的实践策略,旨在为后端开发者提供一套全面的API设计指南。通过具体案例分析,文章揭示了良好API设计对于提升系统可维护性、扩展性和用户体验的重要性,同时指出了常见设计陷阱与应对策略,为后端开发领域的专业人士提供了宝贵的参考和启示。
12 0
|
1天前
|
敏捷开发 运维 负载均衡
探索后端开发中的微服务架构:优势与挑战
本文深入探讨了微服务架构在后端开发中的应用,分析了其设计原则、技术优势及面临的主要挑战。通过对比传统单体架构,我们揭示了微服务如何促进敏捷开发和持续交付,同时指出了在采用微服务过程中可能遇到的复杂性和治理问题。文章旨在为后端开发者提供一份微服务实践的指南,帮助他们在架构选择上做出更明智的决定。 【7月更文挑战第24天】
|
10天前
|
消息中间件 API 开发者
探索后端开发中的微服务架构实践
本文将深入探讨微服务架构在后端开发中的应用,分析其优势与面临的挑战,并提供实践中的解决方案。通过具体的案例研究,我们旨在为开发者提供一套可行的微服务实施策略,以促进高效、可扩展的后端系统建设。
15 0