五步实现你的出海AI生成音乐网站,开源啦~

继上一篇《周末卷一卷,一个音乐生成AI网站写好了,开源啦》发布后,又一个清明假期结束了,除了进行优良的传统活动事项外,也抽空完善了我的项目。

终于...

一个功能虽少,五脏还是全的网站正式完成了。主要技术栈:

项目地址:github.com/Alvin-Liu/s...

网站地址:www.sunomusic.fun/

由于部署方式对国内用户直接访问不一定友好,搭乘🪜更佳。下面正式开始我们五步实现AI生成音乐网站的路。

上一篇《周末卷一卷,一个音乐生成AI网站写好了,开源啦》有提到过,项目的主要功能是基于 suno.ai 的强大能力逆向实现的,所以第一步,我们需要注册网站,获取我们逆向请求需要的 cookie。找到路径带 client?_clerk_js_version 的请求复制出如图所示的 cookie 值出来备用:

2. 注册 clerk

clerk 是什么?

简单点说,clerk 是一个用户管理系统,提供了Google、Github 等等第三方网站的登录、注册集成功能。免费版提供了每月 10000 用户,足够我们使用了。

我们只需要注册好账号后,创建项目,添加 Secret keys 即可。记住此时获取到的值:

ini 复制代码
NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=
CLERK_SECRET_KEY=

后面会用到

3. 获取你的支付功能

作为一个出海站,一个友好的支付功能必不可少。国内的支付方式对国外用户并不友好,而 Stripe 等国外友好的支付方式对我们使用却并不方便,要求公司资质,同时国内用户存在封号的风险。

作为一个折中的方案,Lemon Squeezy 是目前发现的相对合适的方案,很多出海玩家也在使用。审核可能会花费你几天时间,通常在一到两个工作日,需要提前预留好时间。

审核通过后,就可以添加我们的订阅服务了,我们的项目提供了两种订阅方式:

  • One-time Payment: 一次性获取指定的使用次数
  • Monthly Subscription: 每月订阅,成为月度会员

添加我们的订阅产品后,保留好如下数据:

ini 复制代码
LEMON_SQUEEZY_API_KEY=
LEMON_SQUEEZY_STORE_ID=
LEMON_SQUEEZY_PRODUCT_ID=
LEMON_SQUEEZY_MEMBERSHIP_MONTHLY_VARIANT_ID=
LEMON_SQUEEZY_MEMBERSHIP_SINGLE_TIME_VARIANT_ID=
LEMONS_SQUEEZY_SIGNATURE_SECRET=

具体为:

  • LEMON_SQUEEZY_API_KEY:API 接口的 key
  • LEMON_SQUEEZY_STORE_ID:我们申请开通的店铺 id
  • LEMON_SQUEEZY_PRODUCT_ID:我们添加的产品 id
  • LEMON_SQUEEZY_MEMBERSHIP_MONTHLY_VARIANT_ID:月度会员的 id,可以理解成我们产品 id 下的其中一个 skuId
  • LEMON_SQUEEZY_MEMBERSHIP_SINGLE_TIME_VARIANT_ID:One-time Payment 的id,可以理解成我们产品 id 下的另一个 skuId
  • LEMONS_SQUEEZY_SIGNATURE_SECRET:在 settings/webhooks 中开通我们的支付成功的回调事件,保留好你创建 webhooks 用的 key,接口 URL 为你的域名 + /api/payment/webhook

4. 准备好数据库

vercel 这个宝藏网站真的是我们的福音,它不仅提供了与 Github 集成自动构建部署的 CI/CD,同时,还有免费的数据库可以用。接下来我们就要在 vercel 开通我们的 Postgres 数据库,保存好数据库的信息。可以在本地链接下测试联通性。获取到配置如下:

makefile 复制代码
POSTGRES_URL=

类似如下我最近新创建的数据库:

5. 部署网站

进入 Github 仓库

最最重要的来了,高能!!!

一定要 Star 下项目!!!

一定要 Star 下项目!!!

一定要 Star 下项目!!!

重要的事情说 3 遍,发现不少同学习惯很不好呀。克隆了项目,跑来问我哪里哪里报错了,结果连个 Star 都没有,听了都让人伤心💔

好了,完成了上面的步骤后,找到 README 中的 Deploy 按钮,填入你的项目名,以及上面几步中获取的信息作为环境变量就可以了,等待 vercel 部署完成就可以访问你的音乐 AI 网站了。全部环境变量为:

ini 复制代码
NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=""
NEXT_PUBLIC_CLERK_SIGN_IN_URL=/sign-in
NEXT_PUBLIC_CLERK_SIGN_UP_URL=/sign-up
NEXT_PUBLIC_CLERK_AFTER_SIGN_IN_URL=/
NEXT_PUBLIC_CLERK_AFTER_SIGN_UP_URL=/

SUNO_COOKIE=""

LEMON_SQUEEZY_HOST=https://api.lemonsqueezy.com/v1
LEMON_SQUEEZY_API_KEY=
LEMON_SQUEEZY_STORE_ID=
LEMON_SQUEEZY_PRODUCT_ID=
LEMON_SQUEEZY_MEMBERSHIP_MONTHLY_VARIANT_ID=
LEMON_SQUEEZY_MEMBERSHIP_SINGLE_TIME_VARIANT_ID=
LEMONS_SQUEEZY_SIGNATURE_SECRET=

POSTGRES_URL=

记得补充完善好你自己的变量数据。

最后

生命在于折腾,当然,更希望你所有步骤都完成的很顺利

有不明白的地方也欢迎沟通交流,一起进步~

再一次:

项目地址:github.com/Alvin-Liu/s...

网站地址:www.sunomusic.fun/

一定要记得 star~

相关推荐
m0_748247801 分钟前
Flutter Intl包使用指南:实现国际化和本地化
前端·javascript·flutter
飞的肖4 分钟前
前端使用 Element Plus架构vue3.0实现图片拖拉拽,后等比压缩,上传到Spring Boot后端
前端·spring boot·架构
Q_19284999066 分钟前
基于Spring Boot的摄影器材租赁回收系统
java·spring boot·后端
良许Linux11 分钟前
0.96寸OLED显示屏详解
linux·服务器·后端·互联网
青灯文案112 分钟前
前端 HTTP 请求由 Nginx 反向代理和 API 网关到后端服务的流程
前端·nginx·http
m0_7482548816 分钟前
DataX3.0+DataX-Web部署分布式可视化ETL系统
前端·分布式·etl
求知若饥23 分钟前
NestJS 项目实战-权限管理系统开发(六)
后端·node.js·nestjs
ZJ_.28 分钟前
WPSJS:让 WPS 办公与 JavaScript 完美联动
开发语言·前端·javascript·vscode·ecmascript·wps
GIS开发特训营32 分钟前
Vue零基础教程|从前端框架到GIS开发系列课程(七)响应式系统介绍
前端·vue.js·前端框架·gis开发·webgis·三维gis
Cachel wood1 小时前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架