简单实现Viper配置管理

本文由 ChatMoney团队出品

简介

前面实现的一个简易suno-api。是使用cookie来获取suno-token发起请求的。当时并没有通过配置的方式来获取cookie,而是直接在代码中写死了cookie的值,这种做法并不好,所以现在打算把cookie值改造为一个配置,通过viper来读取。

什么是viper

Viper是一个用于Go语言的应用程序配置库,它支持多种格式的配置文件,如JSON、YAML、TOML等,并且可以轻松地从环境变量、命令行参数、远程配置源等读取配置。Viper由Spf13开发,是Cobra和Hugo等项目的一部分。

安装

要开始使用Viper,首先需要安装它。可以使用Go的包管理工具go get来安装:

go get github.com/spf13/viper

简单实现Viper配置管理

基本使用

配置定义

suno:
  cookie: "12321312312321"

简单实现Viper配置管理

配置结构体

package autoload

type Config struct {
   *Suno `mapstructure:"suno"`
}

type Suno struct {
   Cookie string `mapstructure:"cookie"`
}

简单实现Viper配置管理

全局变量

package internal

import "go-suno/config/autoload"

var (
   // BasePath 项目根目录
   BasePath string
   // Conf 全局配置
   Conf *autoload.Config
)

简单实现Viper配置管理

初始化Viper

定义viper初始化方法,读取配置文件并绑定到配置结构体

package viper

import (
   "fmt"
   "github.com/fsnotify/fsnotify"
   "github.com/spf13/viper"
   "go-suno/internal"
   "log"
   "path"
   "runtime"
)

// Init 初始化viper
func Init() {
   _, filename, _, _ := runtime.Caller(0)
   internal.BasePath = path.Dir(path.Dir(path.Dir(filename)))

   viper.SetConfigFile(internal.BasePath + "/config/config.yaml") // 指定配置文件路径
   err := viper.ReadInConfig()                     // 读取配置信息
   if err != nil {                                 // 读取配置信息失败
      log.Fatal("viper.ReadInConfig() failed,err:" + err.Error())
   }

   // 把读取到的配置信息反序列化到Conf 变量中
   if err := viper.Unmarshal(&internal.Conf); err != nil {
      log.Fatal("viper.Unmarshal failed, err:" + err.Error())
   }

   // 监控配置文件变化
   viper.WatchConfig()
   viper.OnConfigChange(func(in fsnotify.Event) {
      fmt.Println("配置文件修改了")
      if err := viper.Unmarshal(&internal.Conf); err != nil {
         fmt.Printf("viper.Unmarshal failed, err:%v\n", err)
      }
   })
}

简单实现Viper配置管理

测试效果

main入口调用viper初始化方法,创建测试配置接口

package main

import (
   "github.com/gin-gonic/gin"
   "go-suno/internal"
   "go-suno/pkg/viper"
   "net/http"
)

func main() {
   r := gin.Default()
   // 配置加载
   viper.Init()
   // 使用中间件
   internal.RateLimitMiddleware(r, 1, 100)
   // 创建一个路由组,可以为其添加中间件
   handler := new(internal.Handler)
   v1 := r.Group("/api")
   {
      v1.POST("/gen", handler.GenMusic)
      v1.GET("/feed", handler.GetFeed)

      // 测试
      v1.GET("/config", func(c *gin.Context) {
         c.JSON(http.StatusOK, gin.H{
            "data":  internal.Conf.Suno.Cookie,
         })
      })
   }
   _ = r.Run()
}

简单实现Viper配置管理

设置配置文件

f0bfd24f-cf9b-451c-aeb2-aa2e86c652e9

启动项目

go run main.go

简单实现Viper配置管理

访问测试接口

687bbd9c-52d9-4eee-9c0f-0697617c64ef

完整代码

https://gitee.com/mofung1/go-suno

关于我们

本文由ChatMoney团队出品,ChatMoney专注于AI应用落地与变现,我们提供全套、持续更新的AI源码系统与可执行的变现方案,致力于帮助更多人利用AI来变现,欢迎进入ChatMoney获取更多AI变现方案!

ChatMoney的头像ChatMoney
Previous 2024年 6月 5日 下午4:56
Next 2024年 6月 7日 下午3:51

相关推荐

  • Android Studio下载Gradle超时解决方案

    本文由 ChatMoney团队出品 Android Studio 找到项目中 gradle 配置文件的路径,我的路径为 /你的项目路径/gradle/wrapper/gradle-wrapper.properties,里面对应内容应该如下所示: 超时原因是因为as(Android Studio,此后简称 as)中默认是从gradle官网去下载,此时我们有一个…

    2024年 7月 17日
    195
  • 在vue中定义一个防抖ref

    本文由 ChatMoney团队出品 为什么ref要实现防抖 在vue的开发过程中,我们通常会使用到ref,但在我们需要对一个频繁的赋值操作做防抖操作时,我们通常只能通过编写一个独立的防抖函数来实现,这样相对会多一些步骤(麻烦一些)。例如我们给一个即时搜索框的input实现防抖输入(即在输入文本n秒之后才触发搜索,避免频繁请求后端接口浪费资源)时,我们不仅不能…

    2024年 6月 20日
    170
  • php 简单的单例模式

    本文由 ChatMoney团队出品 单例模式是一种常用的设计模式,它的核心思想是确保一个类只有一个实例,并提供一个全局访问点来获取这个实例。在 PHP 中实现单例模式通常有三种形式:饿汉式(Eager)、懒汉式(Lazy)和登记式(Register)。 使用注意事项: 不要使用反射(Reflection)机制来创建单例,因为这会实例化一个新的对象。 在使用懒…

    2024年 7月 2日
    220
  • Vue3中组件使用ref时获取组件类型推导

    本文由 ChatMoney团队出品 我们在使用Vue3+ts开发时,常常会用到一些第三方组件库,比如Element-Plus UI、Navie UI等,这些UI框架中有些组件常常会暴露一些方法给我们便捷的去实现各种复杂的交互,我们经常会像下面这样去给组件定义一个ref去获取组件的实例: 这个方法可以正常使用,但是没有任何的ts类型推导,这也就丧失了一部分我们…

    2024年 7月 12日
    219
  • PHP单例模式详解及应用

    本文由 ChatMoney团队出品 在PHP开发中,我们经常会遇到一些对象需要在整个应用程序中共享的情况。例如,数据库连接、缓存等资源。这时候,我们可以使用单例模式来确保这些资源只被创建一次,并且在程序的任何地方都可以访问到。 什么是单例模式? 单例模式(Singleton Pattern)是一种设计模式,它保证一个类只有一个实例,并提供一个全局访问点。这种…

    2024年 7月 30日
    155

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信