logo

如何简单实现suno-api账号保活

作者:ChatMoneyAI2024.06.04 16:15浏览量:151

简介:如何简单实现suno-api账号保活

本文由 ChatMoney团队出品

简介

之前的一个简易的项目suno-api。是使用cookie来获取suno-token发起请求的,之前写的简单,并没有做cookie保活,在运行一段时间后cookie会失效,api便失效了。那现在就来实现一个简单的账号保活。

保活原理

账号保活的实现原理比较简单,其实就是每隔一段时间去获取一次token。当然有其他保活方案的也可以大家交流一下。

保活逻辑

我这里的处理比较简单,就是定时请求,

// KeepLive 账号保活
func (s *service) KeepLive() {
   ticker := time.NewTicker(time.Second * 5) // 创建一个定时器,每隔5秒触发一次
   defer ticker.Stop()                       // 确保在退出函数时停止定时器

   for {
      select {
      case <-ticker.C: // 当定时器触发时
         cookieStr := Conf.Cookie
         if cookieStr == "" {
            fmt.Println(CookieNotFound)
            continue
         }

         token, err := s.GetToken(cookieStr)
         if err != nil {
            fmt.Println(err.Error())
            continue
         }

         Token = token
         fmt.Println("协程账号保活token-" + token)
      }
   }
}'

代码测试
main方法中建一个协程处理保活逻辑

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

项目启动
go run main.go

启动后,每隔一段时间则刷新token请求。

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

相关文章推荐

发表评论