本文由 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变现方案!