# API文档
# 开发前必读
接口认证和鉴权
除了开放接口,其余接口必须设置请求头
Authorization
用于认证和鉴权Authorization
值格式为Bearer ${Token}
${Token}
可通过登录接口(/api/auth/login
)获得通用返回对象
返回示例:
{ "code": 20000, "type": "success", "message": "", "data": {} }
参数说明:
参数 | 必须 | 说明 |
---|---|---|
code | 是 | 状态码 20000/成功 50000/系统错误 50014/登录过期 50008/认证失败 50401/未认证 50403/暂无权限 |
type | 是 | 类型 success/成功 error/错误 warning/警告 |
data | 否 | 返回值 |
# 开放接口
# 验证码
接口地址: /api/auth/generateCaptcha
请求方式: GET
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"captchaId": "VeC7Raoxo33hQTrnJT8s",
"captchaImg": ""
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
captchaId | 是 | 验证码id |
captchaImg | 是 | 验证码图片 |
# 登录
接口地址: /api/auth/login
请求方式: POST
请求示例:
{
"username": "sysadmin",
"pass": "123456",
"captchaId": "y1mAtmYe4fErHN6vcYvo",
"captchaCode": "25"
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
username | 是 | 登录用户名 |
pass | 是 | 登录密码 |
captchaId | 否 | 验证码id |
captchaCode | 否 | 验证码值 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhY2NvdW50Vm8iOnsiaWQiOjEsInF1b3RhIjowLCJkb3dubG9hZCI6MCwidXBsb2FkIjowLCJ1c2VybmFtZSI6InN5c2FkbWluIiwiZW1haWwiOiIiLCJyb2xlSWQiOjEsImRlbGV0ZWQiOjAsInByZXNldEV4cGlyZSI6MCwicHJlc2V0UXVvdGEiOjAsImxhc3RMb2dpblRpbWUiOjAsImV4cGlyZVRpbWUiOjAsImNyZWF0ZVRpbWUiOiIwMDAxLTAxLTAxVDAwOjAwOjAwWiIsInJvbGVzIjpbInN5c2FkbWluIiwiYWRtaW4iLCJ1c2VyIl19LCJleHAiOjE2OTIzODM4MzQsImlzcyI6InRyb2phbi1wYW5lbCJ9.ymvQ_VPsCvxjNpQUPTZ3fjWTZJk-URujCt3vSI-bnw8"
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
token | 是 | 授权Token |
# 注册
接口地址: /api/auth/register
请求方式: POST
请求示例:
{
"username": "123456",
"pass": "123456",
"captchaId": "BqEEo9jEdZrmfzz8K7R9",
"captchaCode": "9"
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
username | 是 | 登录用户名 |
pass | 是 | 登录密码 |
captchaId | 否 | 验证码id |
captchaCode | 否 | 验证码值 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 系统默认设置
接口地址: /api/auth/setting
请求方式: GET
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"registerEnable": 1,
"registerQuota": 0,
"registerExpireDays": 0,
"trafficRankEnable": 1,
"captchaEnable": 1,
"emailEnable": 0,
"systemName": "Trojan Panel"
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
registerEnable | 是 | 是否开放注册 |
registerQuota | 是 | 注册用户默认配额 单位/MB |
registerExpireDays | 是 | 注册用户过期天数 单位/天 |
captchaEnable | 是 | 是否开启验证码登录 |
emailEnable | 是 | 是否开启邮箱功能 0/否 1/是 |
systemName | 是 | 系统名称 |
# 订阅
接口地址: /api/subscribe/:token
请求方式: GET
请求示例:
/api/auth/subscribe/NUNjOWtCZHhwWGpUYXZKSjRvNF9JTFBMU3VZWmphOTB4MEpmZWVicGt1UFBHZmRT
参数说明:
参数 | 必须 | 说明 |
---|---|---|
token | 是 | Token |
# logo
接口地址: /api/image/logo
请求方式: GET
返回示例:
Content-Type: application/octet-stream
# 首页
# 仪表板
接口地址: /api/dashboard/panelGroup
请求方式: GET
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"quota": -1,
"residualFlow": -1,
"nodeCount": 0,
"expireTime": 4078656000000,
"accountCount": 8,
"cpuUsed": 1,
"memUsed": 32.9,
"diskUsed": 32.3
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
quota | 是 | 配额 |
residualFlow | 是 | 剩余流量 |
nodeCount | 是 | 节点总数 |
expireTime | 是 | 到期时间 |
accountCount | 是 | 用户总数 |
cpuUsed | 是 | CPU使用率 |
memUsed | 是 | 内存使用率 |
diskUsed | 是 | 磁盘使用率 |
# 流量排行榜
接口地址: /api/dashboard/trafficRank
请求方式: GET
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": [
{
"username": "23****34",
"trafficUsed": "0"
},
{
"username": "12****23",
"trafficUsed": "0"
}
]
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
username | 是 | 登录用户名 |
trafficUsed | 是 | 已用流量 |
# 账户
# 注销
接口地址: /api/account/logout
请求方式: POST
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 查询单个账户
接口地址: /api/account/selectAccountById
请求方式: GET
请求示例:
{
"id": 1
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"id": 1,
"username": "sysadmin",
"roleId": 1,
"email": "123@gmail.com",
"presetExpire": 7,
"presetQuota": 1073741824,
"expireTime": 1692519522967,
"deleted": 0,
"quota": -1,
"download": 0,
"upload": 0
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
username | 是 | 登录用户名 |
roleId | 是 | 角色id 1/系统管理员 3/普通用户 |
是 | 邮箱 | |
presetExpire | 是 | 预设过期时长 单位/天 |
presetQuota | 是 | 预设配额 单位/byte |
expireTime | 是 | 过期时间 |
deleted | 是 | 是否禁用 0/正常 1/禁用 |
quota | 是 | 配额 单位/byte |
download | 是 | 下载 单位/byte |
upload | 是 | 上传 单位/byte |
# 创建账户
接口地址: /api/account/createAccount
请求方式: POST
请求示例:
{
"quota": 1024,
"username": "123456",
"pass": "123456",
"email": "123@gmail.com",
"roleId": 3,
"deleted": 0,
"expireTime": 1693061885000
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
quota | 是 | 配额 单位/MB |
username | 是 | 登录用户名 |
pass | 是 | 登录密码 |
否 | 邮箱 | |
roleId | 是 | 角色id 1/系统管理员 3/普通用户 |
deleted | 是 | 是否禁用 0/正常 1/禁用 |
expireTime | 是 | 过期时间 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 获取当前账户信息
接口地址: /api/account/getAccountInfo
请求方式: GET
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"id": 1,
"username": "sysadmin",
"roles": [
"sysadmin",
"admin",
"user"
]
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
username | 是 | 登录用户名 |
roles | 是 | 角色 |
# 分页查询账户
接口地址: /api/account/selectAccountPage
请求方式: GET
请求示例:
/api/account/selectAccountPage?pageNum=1&pageSize=20&username=admin&deleted=0&orderFields=role_id,create_time&orderBy=desc&lastLoginTime=1
参数说明:
参数 | 必须 | 说明 |
---|---|---|
pageNum | 是 | 页号 |
pageSize | 是 | 页大小 |
username | 否 | 登录用户名 |
deleted | 否 | 是否禁用 0/正常 1/禁用 |
orderFields | 否 | 排序字段 quota/总流量 role_id/角色 last_login_time/最后一次登录时间 expire_time/到期时间 deleted/是否禁用 create_time/创建时间 |
orderBy | 否 | 排序方式 asc/正序 desc/倒序 |
lastLoginTime | 否 | 是否使用过 0/未使用过 1/使用过 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"pageNum": 1,
"pageSize": 20,
"total": 1,
"accounts": [
{
"id": 1,
"quota": -1,
"download": 0,
"upload": 0,
"username": "sysadmin",
"email": "",
"roleId": 1,
"deleted": 0,
"presetExpire": 0,
"presetQuota": 0,
"lastLoginTime": 1692430857369,
"expireTime": 4078656000000,
"createTime": "2022-04-01T00:00:00+08:00"
}
]
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
pageNum | 是 | 页号 |
pageSize | 是 | 页大小 |
total | 是 | 总数 |
accounts | 否 | 账户 |
id | 否 | 主键 |
quota | 否 | 配额 单位/byte |
download | 否 | 下载 单位/byte |
upload | 否 | 上传 单位/byte |
username | 否 | 登录用户名 |
否 | 邮箱 | |
roleId | 否 | 角色id 1/系统管理员 3/普通用户 |
deleted | 否 | 是否禁用 0/正常 1/禁用 |
presetExpire | 否 | 预设过期时长 单位/天 |
presetQuota | 否 | 预设配额 单位/byte |
lastLoginTime | 否 | 最后一次登录时间 |
expireTime | 否 | 过期时间 |
createTime | 否 | 创建时间 |
# 通过id删除账户
接口地址: /api/account/deleteAccountById
请求方式: POST
请求示例:
{
"id": 2
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 修改密码
接口地址: /api/account/updateAccountPass
请求方式: POST
请求示例:
{
"oldPass": "123456",
"newPass": "123123"
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
oldPass | 是 | 原密码 |
newPass | 是 | 新密码 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 修改用户名或者邮箱
接口地址: /api/account/updateAccountProperty
请求方式: POST
请求示例:
{
"email": "123456@gmail.com",
"username": "sysadmin",
"pass": "123456"
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
否 | 邮箱 | |
username | 否 | 登录用户名 |
pass | 是 | 登录密码 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 修改账户
接口地址: /api/account/updateAccountById
请求方式: POST
请求示例:
{
"id": 1,
"quota": 1024,
"username": "123456",
"pass": "123123",
"roleId": 3,
"deleted": 0,
"expireTime": 1692378469728,
"email": ""
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
quota | 是 | 配额 单位/MB |
username | 是 | 登录用户名 |
pass | 否 | 登录密码 |
roleId | 是 | 角色id |
deleted | 是 | 是否禁用 0/正常 1/禁用 |
expireTime | 是 | 过期时间 |
否 | 邮箱 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 获取Clash订阅地址
接口地址: /api/account/clashSubscribe
请求方式: GET
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": "/api/auth/subscribe/b0dBQVh1b1FlOEtLdUZPeWRZMGZYdGJuMC1UNWppSktOdm1aTEhlcU5ocVRuOG55"
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
data | 是 | 订阅地址 |
# 获取指定账户的Clash订阅地址
接口地址: /api/account/clashSubscribeForSb
请求方式: GET
请求示例:
/api/account/clashSubscribeForSb?id=1
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": "/api/auth/subscribe/SkxhejNnQkQtbWZDb2owbUNDVjFsQWwzUzNsOWVxeGprME9qWHNfOGc4R0dMdUZP"
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
data | 是 | 订阅地址 |
# 重设下载和上传流量
接口地址: /api/account/resetAccountDownloadAndUpload
请求方式: POST
请求示例:
{
"id": 1
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 导出账户
接口地址: /api/account/exportAccount
请求方式: POST
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 导入账户
接口地址: /api/account/importAccount
请求方式: POST
请求示例:
Form Data
file: (binary)
cover: 1
参数说明:
参数 | 必须 | 说明 |
---|---|---|
file | 是 | 文件二进制 |
cover | 是 | 是否根据用户名覆盖 0/否 1/是 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 批量创建账户
接口地址: /api/account/createAccountBatch
请求方式: POST
请求示例:
{
"num": 5,
"presetQuota": 1024,
"presetExpire": 7
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
num | 是 | 数量 |
presetQuota | 是 | 预设配额 单位/MB |
presetExpire | 是 | 预设过期时长 单位/天 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 导出未使用的账户
接口地址: /api/account/exportAccountUnused
请求方式: POST
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 角色
# 查询角色列表
接口地址: /api/role/selectRoleList
请求方式: GET
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": [
{
"id": 1,
"name": "sysadmin",
"desc": "System Admin"
},
{
"id": 2,
"name": "admin",
"desc": "Admin"
},
{
"id": 3,
"name": "user",
"desc": "User"
}
]
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
name | 是 | 名称 |
desc | 是 | 描述 |
# 服务器
# 根据id查询服务器
接口地址: /api/nodeServer/selectNodeServerById
请求方式: GET
请求示例:
{
"id": 1
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"id": 1,
"name": "测试服务器",
"grpcPort": 8100,
"createTime": "2023-08-19T01:24:22+08:00"
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
name | 是 | 服务器名称 |
grpcPort | 是 | API端口 |
createTime | 是 | 创建时间 |
# 创建服务器
接口地址: /api/nodeServer/createNodeServer
请求方式: POST
请求示例:
{
"ip": "trojanpanel.github.io",
"name": "测试服务器",
"grpcPort": 8100
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
ip | 是 | 服务器IP |
name | 是 | 服务器名称 |
grpcPort | 是 | API端口 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 分页查询服务器
接口地址: /api/nodeServer/selectNodeServerPage
请求方式: GET
请求示例:
/api/nodeServer/selectNodeServerPage?pageNum=1&pageSize=20&ip=trojanpanel.github.io&name=测试服务器
参数说明:
参数 | 必须 | 说明 |
---|---|---|
pageNum | 是 | 页号 |
pageSize | 是 | 页大小 |
ip | 否 | 服务器IP |
name | 否 | 服务器名称 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"nodeServers": [
{
"id": 1,
"name": "测试服务器",
"ip": "trojanpanel.github.io",
"grpcPort": 8100,
"createTime": "2023-08-19T01:24:22+08:00",
"status": 1,
"trojanPanelCoreVersion": "v2.1.2"
}
],
"pageNum": 1,
"pageSize": 20,
"total": 1
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
nodeServers | 否 | 服务器对象 |
id | 否 | 主键 |
name | 否 | 服务器名称 |
ip | 否 | 服务器名称 |
grpcPort | 否 | API端口 |
createTime | 否 | 创建时间 |
status | 否 | 状态 0/异常 1/正常 |
trojanPanelCoreVersion | 否 | Trojan Panel Core 版本 |
pageNum | 是 | 页号 |
pageSize | 是 | 页大小 |
total | 是 | 总数 |
# 删除服务器
接口地址: /api/nodeServer/deleteNodeServerById
请求方式: POST
请求示例:
{
"id": 1
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 更新服务器
接口地址: /api/nodeServer/updateNodeServerById
请求方式: POST
请求示例:
{
"id": 1,
"ip": "143.201.86.91",
"name": "测试服务器",
"grpcPort": 8100
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
ip | 是 | 服务器IP |
name | 是 | 服务器名称 |
grpcPort | 是 | API端口 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
参数说明:
# 查询服务器列表
接口地址: /api/nodeServer/selectNodeServerList
请求方式: GET
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": [
{
"id": 1,
"name": "测试服务器"
}
]
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
name | 是 | 名称 |
# 查询服务器状态
接口地址: /api/nodeServer/nodeServerState
请求方式: GET
请求示例:
/api/nodeServer/nodeServerState?id=1
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"cpuUsed": 1,
"memUsed": 32.8,
"diskUsed": 32.3
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
cpuUsed | 是 | CPU使用率 |
memUsed | 是 | 内存使用率 |
diskUsed | 是 | 磁盘使用率 |
# 导出服务器
接口地址: /api/nodeServer/exportNodeServer
请求方式: POST
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 导入服务器
接口地址: /api/nodeServer/importNodeServer
请求方式: POST
请求参数:
file: (binary)
cover: 1
参数说明:
参数 | 必须 | 说明 |
---|---|---|
file | 是 | 文件二进制 |
cover | 是 | 是否根据用户名覆盖 0/否 1/是 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 节点
# 根据id查询节点
接口地址: /api/node/selectNodeById
请求方式: GET
请求示例:
/api/node/selectNodeById?id=1
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"id": 1,
"nodeServerId": 1,
"nodeSubId": 1,
"nodeTypeId": 1,
"name": "vless-reality",
"domain": "trojanpanel.github.io",
"port": 443,
"priority": 100,
"createTime": "2023-08-19T23:20:27+08:00",
"uuid": "",
"alterId": 0,
"xrayProtocol": "vless",
"xrayFlow": "xtls-rprx-vision",
"xraySSMethod": "aes-256-gcm",
"realityPbk": "JraCqHw8lrQ-YdgrBSpBVTA4fhqHLfTUpZiP45x5gRI",
"xraySettings": "",
"xraySettingsEntity": {
"fallbacks": [
{
"name": "",
"alpn": "",
"path": null,
"dest": "80",
"xver": 0
}
],
"network": "tcp"
},
"xrayStreamSettingsEntity": {
"network": "tcp",
"security": "reality",
"tlsSettings": {
"serverName": "",
"alpn": [
"h2",
"http/1.1"
],
"allowInsecure": false,
"fingerprint": "chrome"
},
"realitySettings": {
"dest": "trojanpanel.github.io:8863",
"xver": 0,
"serverNames": [
"trojanpanel.github.io"
],
"fingerprint": "chrome",
"privateKey": "GCRTXDZm1zuBdsQSM3Up9awTqxuzNwF6yXr5kxVT11w",
"shortIds": [
"c6b6b5bf30c98f05"
],
"spiderX": "/SCalpsSw"
},
"wsSettings": {
"path": "/trojan-panel-websocket-path",
"headers": {
"Host": ""
}
}
},
"xrayTag": "user",
"xraySniffing": "",
"xrayAllocate": "",
"trojanGoSni": "",
"trojanGoMuxEnable": 0,
"trojanGoWebsocketEnable": 0,
"trojanGoWebsocketPath": "",
"trojanGoWebsocketHost": "",
"trojanGoSsEnable": 0,
"trojanGoSsMethod": "",
"trojanGoSsPassword": "",
"hysteriaProtocol": "",
"hysteriaObfs": "",
"hysteriaUpMbps": 0,
"hysteriaDownMbps": 0,
"hysteriaServerName": "",
"hysteriaInsecure": 0,
"hysteriaFastOpen": 0,
"naiveProxyUsername": ""
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
nodeServerId | 是 | 服务器id |
nodeSubId | 是 | 节点分表id |
nodeTypeId | 是 | 节点类型id |
name | 是 | 名称 |
domain | 是 | 域名/IP |
port | 是 | 端口 |
priority | 是 | 优先级 |
createTime | 是 | 创建时间 |
uuid | 是 | UUID |
alterId | 是 | Alter ID |
xrayProtocol | 是 | Xray 协议名称 |
xrayFlow | 是 | Xray 流控 |
xraySSMethod | 是 | Xray Shadowsocks加密方式 |
realityPbk | 是 | Xray reality的公钥 |
xraySettingsEntity | 是 | Xray settings 参考Xray文档 |
xrayStreamSettingsEntity | 是 | Xray streamSettings 参考Xray文档 |
xrayTag | 是 | Xray tag |
xraySniffing | 是 | Xray sniffing |
xrayAllocate | 是 | Xray allocate |
trojanGoSni | 是 | TrojanGo sni |
trojanGoMuxEnable | 是 | TrojanGo 是否开启多路复用 0/关闭 1/开启 |
trojanGoWebsocketEnable | 是 | TrojanGo 是否开启websocket 0/否 1/是 |
trojanGoWebsocketPath | 是 | TrojanGo websocket路径 |
trojanGoWebsocketHost | 是 | TrojanGo websocket host |
trojanGoSsEnable | 是 | TrojanGo 是否开启ss加密 0/否 1/是 |
trojanGoSsMethod | 是 | TrojanGo ss加密方式 |
trojanGoSsPassword | 是 | TrojanGo ss密码 |
hysteriaProtocol | 是 | Hysteria 协议名称 udp/faketcp |
hysteriaObfs | 是 | Hysteria 混淆密码 |
hysteriaUpMbps | 是 | Hysteria 单客户端最大上传速度 单位:Mbps |
hysteriaDownMbps | 是 | Hysteria 单客户端最大下载速度 单位:Mbps |
hysteriaServerName | 是 | Hysteria 用于验证服务端证书的 hostname |
hysteriaInsecure | 是 | Hysteria 忽略一切证书错误 |
hysteriaFastOpen | 是 | Hysteria 启用 Fast Open (降低连接建立延迟) |
naiveProxyUsername | 是 | NaiveProxy用户名 |
# 查询节点连接信息
接口地址: /api/node/selectNodeInfo
请求方式: GET
请求示例:
/api/node/selectNodeInfo?id=1
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"id": 1,
"nodeServerId": 1,
"nodeSubId": 1,
"nodeTypeId": 1,
"name": "vless-reality",
"domain": "trojanpanel.github.io",
"port": 443,
"priority": 100,
"createTime": "2023-08-19T23:20:27+08:00",
"password": "oGAAXuoQe8KKuFOydY0fXtbn0-T5jiJKNvmZLHeqNhqTn8ny",
"uuid": "7a57ec2e-bb05-5544-9c30-05814b376eba",
"alterId": 0,
"xrayProtocol": "vless",
"xrayFlow": "xtls-rprx-vision",
"xraySSMethod": "aes-256-gcm",
"realityPbk": "JraCqHw8lrQ-YdgrBSpBVTA4fhqHLfTUpZiP45x5gRI",
"xraySettingsEntity": {
"fallbacks": [
{
"name": "",
"alpn": "",
"path": null,
"dest": "80",
"xver": 0
}
],
"network": "tcp"
},
"xrayStreamSettingsEntity": {
"network": "tcp",
"security": "reality",
"tlsSettings": {
"serverName": "",
"alpn": [
"h2",
"http/1.1"
],
"allowInsecure": false,
"fingerprint": "chrome"
},
"realitySettings": {
"dest": "trojanpanel.github.io:8863",
"xver": 0,
"serverNames": [
"trojanpanel.github.io"
],
"fingerprint": "chrome",
"privateKey": "GCRTXDZm1zuBdsQSM3Up9awTqxuzNwF6yXr5kxVT11w",
"shortIds": [
"c6b6b5bf30c98f05"
],
"spiderX": "/SCalpsSw"
},
"wsSettings": {
"path": "/trojan-panel-websocket-path",
"headers": {
"Host": ""
}
}
},
"xrayTag": "user",
"xraySniffing": "",
"xrayAllocate": "",
"trojanGoSni": "",
"trojanGoMuxEnable": 0,
"trojanGoWebsocketEnable": 0,
"trojanGoWebsocketPath": "",
"trojanGoWebsocketHost": "",
"trojanGoSsEnable": 0,
"trojanGoSsMethod": "",
"trojanGoSsPassword": "",
"hysteriaProtocol": "",
"hysteriaObfs": "",
"hysteriaUpMbps": 0,
"hysteriaDownMbps": 0,
"hysteriaServerName": "",
"hysteriaInsecure": 0,
"hysteriaFastOpen": 0,
"naiveProxyUsername": ""
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
nodeServerId | 是 | 服务器id |
nodeSubId | 是 | 节点分表id |
nodeTypeId | 是 | 节点类型id |
name | 是 | 名称 |
domain | 是 | 域名/IP |
port | 是 | 端口 |
priority | 是 | 优先级 |
createTime | 是 | 创建时间 |
password | 是 | 连接密码 |
uuid | 是 | UUID |
alterId | 是 | Alter ID |
xrayProtocol | 是 | Xray 协议名称 |
xrayFlow | 是 | Xray 流控 |
xraySSMethod | 是 | Xray Shadowsocks加密方式 |
realityPbk | 是 | Xray reality的公钥 |
xraySettingsEntity | 是 | Xray settings 参考Xray文档 |
xrayStreamSettingsEntity | 是 | Xray streamSettings 参考Xray文档 |
xrayTag | 是 | Xray tag |
xraySniffing | 是 | Xray sniffing |
xrayAllocate | 是 | Xray allocate |
trojanGoSni | 是 | TrojanGo sni |
trojanGoMuxEnable | 是 | TrojanGo 是否开启多路复用 0/关闭 1/开启 |
trojanGoWebsocketEnable | 是 | TrojanGo 是否开启websocket 0/否 1/是 |
trojanGoWebsocketPath | 是 | TrojanGo websocket路径 |
trojanGoWebsocketHost | 是 | TrojanGo websocket host |
trojanGoSsEnable | 是 | TrojanGo 是否开启ss加密 0/否 1/是 |
trojanGoSsMethod | 是 | TrojanGo ss加密方式 |
trojanGoSsPassword | 是 | TrojanGo ss密码 |
hysteriaProtocol | 是 | Hysteria 协议名称 udp/faketcp |
hysteriaObfs | 是 | Hysteria 混淆密码 |
hysteriaUpMbps | 是 | Hysteria 单客户端最大上传速度 单位:Mbps |
hysteriaDownMbps | 是 | Hysteria 单客户端最大下载速度 单位:Mbps |
hysteriaServerName | 是 | Hysteria 用于验证服务端证书的 hostname |
hysteriaInsecure | 是 | Hysteria 忽略一切证书错误 |
hysteriaFastOpen | 是 | Hysteria 启用 Fast Open (降低连接建立延迟) |
naiveProxyUsername | 是 | NaiveProxy用户名 |
# 创建节点
接口地址: /api/node/createNode
请求方式: POST
请求示例:
{
"nodeServerId": 1,
"nodeTypeId": 1,
"name": "vless-reality",
"domain": "trojanpanel.github.io",
"port": 443,
"priority": 100,
"xrayProtocol": "vless",
"xrayFlow": "xtls-rprx-vision",
"xraySSMethod": "aes-256-gcm",
"realityPbk": "JraCqHw8lrQ-YdgrBSpBVTA4fhqHLfTUpZiP45x5gRI",
"xraySettings": "{\"clients\":[],\"fallbacks\":[{\"name\":\"\",\"alpn\":\"\",\"dest\":\"80\",\"xver\":0}],\"network\":\"tcp\",\"decryption\":\"none\"}",
"xrayStreamSettings": "{\"network\":\"tcp\",\"security\":\"reality\",\"tlsSettings\":{\"serverName\":\"\",\"alpn\":[\"h2\",\"http/1.1\"],\"allowInsecure\":false,\"fingerprint\":\"chrome\"},\"realitySettings\":{\"dest\":\"trojanpanel.github.io:8863\",\"xver\":0,\"serverNames\":[\"trojanpanel.github.io\"],\"fingerprint\":\"chrome\",\"privateKey\":\"GCRTXDZm1zuBdsQSM3Up9awTqxuzNwF6yXr5kxVT11w\",\"shortIds\":[\"c6b6b5bf30c98f05\"],\"spiderX\":\"/SCalpsSw\"},\"wsSettings\":{\"path\":\"/trojan-panel-websocket-path\",\"headers\":{\"Host\":\"\"}}}",
"xrayTag": "user",
"xraySniffing": "",
"xrayAllocate": "",
"trojanGoSni": "",
"trojanGoMuxEnable": 1,
"trojanGoWebsocketEnable": 0,
"trojanGoWebsocketPath": "/trojan-panel-websocket-path",
"trojanGoWebsocketHost": "",
"trojanGoSsEnable": 0,
"trojanGoSsMethod": "AES-128-GCM",
"trojanGoSsPassword": "",
"hysteriaProtocol": "udp",
"hysteriaObfs": "",
"hysteriaUpMbps": 100,
"hysteriaDownMbps": 100,
"hysteriaServerName": "",
"hysteriaInsecure": 0,
"hysteriaFastOpen": 0
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
nodeServerId | 是 | 服务器id |
nodeTypeId | 是 | 节点类型id |
name | 是 | 名称 |
domain | 是 | 域名/IP |
port | 是 | 端口 |
priority | 是 | 优先级 |
xrayProtocol | 否 | Xray 协议名称 |
xrayFlow | 否 | Xray 流控 |
xraySSMethod | 否 | Xray Shadowsocks加密方式 |
realityPbk | 否 | Xray reality的公钥 |
xraySettings | 否 | Xray settings |
xrayStreamSettings | 否 | Xray streamSettings |
xrayTag | 否 | Xray tag |
xraySniffing | 否 | Xray sniffing |
xrayAllocate | 否 | Xray allocate |
trojanGoSni | 否 | TrojanGo sni |
trojanGoMuxEnable | 是 | TrojanGo 是否开启多路复用 0/关闭 1/开启 |
trojanGoWebsocketEnable | 是 | TrojanGo 是否开启websocket 0/否 1/是 |
trojanGoWebsocketPath | 否 | TrojanGo websocket路径 |
trojanGoWebsocketHost | 否 | TrojanGo websocket host |
trojanGoSsEnable | 是 | TrojanGo 是否开启ss加密 0/否 1/是 |
trojanGoSsMethod | 否 | TrojanGo ss加密方式 |
trojanGoSsPassword | 否 | TrojanGo ss密码 |
hysteriaProtocol | 否 | Hysteria 协议名称 udp/faketcp |
hysteriaObfs | 否 | Hysteria 混淆密码 |
hysteriaUpMbps | 是 | Hysteria 单客户端最大上传速度 单位:Mbps |
hysteriaDownMbps | 是 | Hysteria 单客户端最大下载速度 单位:Mbps |
hysteriaServerName | 否 | Hysteria 用于验证服务端证书的 hostname |
hysteriaInsecure | 否 | Hysteria 忽略一切证书错误 |
hysteriaFastOpen | 否 | Hysteria 启用 Fast Open (降低连接建立延迟) |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 分页查询节点
接口地址: /api/node/selectNodePage
请求方式: GET
请求示例:
/api/node/selectNodePage?pageNum=1&pageSize=20&name=vless-reality&nodeServerId=1
参数说明:
参数 | 必须 | 说明 |
---|---|---|
pageNum | 是 | 页号 |
pageSize | 是 | 页大小 |
name | 否 | 名称 |
nodeServerId | 否 | 服务器id |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"nodes": [
{
"id": 1,
"nodeServerId": 2,
"nodeSubId": 1,
"nodeTypeId": 1,
"name": "vless-reality",
"domain": "trojanpanel.github.io",
"port": 443,
"priority": 100,
"createTime": "2023-08-19T23:20:27+08:00",
"status": 1
}
],
"pageNum": 1,
"pageSize": 20,
"total": 1
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
pageNum | 是 | 页号 |
pageSize | 是 | 页大小 |
total | 是 | 总数 |
nodes | 否 | 节点 |
id | 否 | 主键 |
nodeServerId | 否 | 服务器id |
nodeSubId | 否 | 节点分表id |
nodeTypeId | 否 | 节点类型id |
name | 否 | 名称 |
domain | 否 | 域名/IP |
port | 否 | 端口 |
createTime | 否 | 创建时间 |
status | 否 | 状态 0/异常 1/正常 |
# 删除节点
接口地址: /api/node/deleteNodeById
请求方式: POST
请求示例:
{
"id": 1
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 更新节点
接口地址: /api/node/updateNodeById
请求方式: POST
请求示例:
{
"id": 1,
"nodeServerId": 2,
"nodeSubId": 1,
"nodeTypeId": 1,
"name": "vless-reality",
"domain": "trojanpanel.github.io",
"port": 443,
"priority": 100,
"xrayProtocol": "vless",
"xrayFlow": "xtls-rprx-vision",
"xraySSMethod": "aes-256-gcm",
"realityPbk": "JraCqHw8lrQ-YdgrBSpBVTA4fhqHLfTUpZiP45x5gRI",
"xraySettings": "{\"clients\":[],\"fallbacks\":[{\"name\":\"\",\"alpn\":\"\",\"path\":null,\"dest\":\"80\",\"xver\":0}],\"network\":\"tcp\",\"decryption\":\"none\"}",
"xrayStreamSettings": "{\"network\":\"tcp\",\"security\":\"reality\",\"tlsSettings\":{\"serverName\":\"\",\"alpn\":[\"h2\",\"http/1.1\"],\"allowInsecure\":false,\"fingerprint\":\"chrome\"},\"realitySettings\":{\"dest\":\"trojanpanel.github.io:8863\",\"xver\":0,\"serverNames\":[\"trojanpanel.github.io\"],\"fingerprint\":\"chrome\",\"privateKey\":\"GCRTXDZm1zuBdsQSM3Up9awTqxuzNwF6yXr5kxVT11w\",\"shortIds\":[\"c6b6b5bf30c98f05\"],\"spiderX\":\"/SCalpsSw\"},\"wsSettings\":{\"path\":\"/trojan-panel-websocket-path\",\"headers\":{\"Host\":\"\"}}}",
"xrayTag": "user",
"xraySniffing": "",
"xrayAllocate": "",
"trojanGoSni": "",
"trojanGoMuxEnable": 1,
"trojanGoWebsocketEnable": 0,
"trojanGoWebsocketPath": "/trojan-panel-websocket-path",
"trojanGoWebsocketHost": "",
"trojanGoSsEnable": 0,
"trojanGoSsMethod": "AES-128-GCM",
"trojanGoSsPassword": "",
"hysteriaProtocol": "udp",
"hysteriaObfs": "",
"hysteriaUpMbps": 100,
"hysteriaDownMbps": 100,
"hysteriaServerName": "",
"hysteriaInsecure": 0,
"hysteriaFastOpen": 0
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
nodeServerId | 是 | 服务器id |
nodeSubId | 是 | 节点分表id |
nodeTypeId | 是 | 节点类型id |
name | 是 | 名称 |
domain | 是 | 域名/IP |
port | 是 | 端口 |
priority | 是 | 优先级 |
xrayProtocol | 否 | Xray 协议名称 |
xrayFlow | 否 | Xray 流控 |
xraySSMethod | 否 | Xray Shadowsocks加密方式 |
realityPbk | 否 | Xray reality的公钥 |
xraySettings | 否 | Xray settings |
xrayStreamSettings | 否 | Xray streamSettings |
xrayTag | 否 | Xray tag |
xraySniffing | 否 | Xray sniffing |
xrayAllocate | 否 | Xray allocate |
trojanGoSni | 否 | TrojanGo sni |
trojanGoMuxEnable | 是 | TrojanGo 是否开启多路复用 0/关闭 1/开启 |
trojanGoWebsocketEnable | 是 | TrojanGo 是否开启websocket 0/否 1/是 |
trojanGoWebsocketPath | 否 | TrojanGo websocket路径 |
trojanGoWebsocketHost | 否 | TrojanGo websocket host |
trojanGoSsEnable | 是 | TrojanGo 是否开启ss加密 0/否 1/是 |
trojanGoSsMethod | 否 | TrojanGo ss加密方式 |
trojanGoSsPassword | 否 | TrojanGo ss密码 |
hysteriaProtocol | 否 | Hysteria 协议名称 udp/faketcp |
hysteriaObfs | 否 | Hysteria 混淆密码 |
hysteriaUpMbps | 是 | Hysteria 单客户端最大上传速度 单位:Mbps |
hysteriaDownMbps | 是 | Hysteria 单客户端最大下载速度 单位:Mbps |
hysteriaServerName | 否 | Hysteria 用于验证服务端证书的 hostname |
hysteriaInsecure | 否 | Hysteria 忽略一切证书错误 |
hysteriaFastOpen | 否 | Hysteria 启用 Fast Open (降低连接建立延迟) |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 获取节点二维码
接口地址: /api/node/nodeQRCode
请求方式: POST
请求示例:
{
"id": 1,
"clientType": "Shadowrocket"
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
clientType 是 | 客户端类型 Shadowrocket/v2rayN |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": "iVBORw0KGgoAAAANSUhEUgAAAQAAAAEAAQMAAABmvDolAAAABlBMVEX///8AAABVwtN+AAAEvElEQVR42uyZMY77rhPFB1HQhQtE5hopLHGllO6go8yVkFzkGlh7gUlHgXh/DZvsbp/Yxf/3pdiV1p+VkJn3eDOmf+u/tRSAGCyar4bU1ijwo5+JDAPIBwGFdAx2Il8N204+Bp7II3EhfRSwYU0RE+m8WLU1A5wc8hJ4w/pBAIyvdjFQnTyi2opHPRqIdnJrDWSBe7zaThqgA4FCOrHdir5Ha4uu4aY2tGWhP4e1NwAg3ex0ni8LP7b1nm6n6Twvy9+ifQ+QZSKjkAHZojNZW846Gv4jv50BtYn0uOhRD0AOrFAoJH7u8RCgzWSt+8oezJMIkB3WKrXxKQDrCljXfDaWVDbVqqKByjQ9j/sIoC1XVmW+GEtuRbW2n2cy5PpRABFpsGi9BpykOPjRSVeDol4luT/g83K1W6FLsKyQTZR6ILLj5ycAhawB2102kRSaSTipMgeMfz0MmOlqi8a9gl2mELtDJmPRX5vcGyDVfCVMrl0Cn9RazY1U8XVhcmv+CKC2TAGEr2aqBdanuk2ynWY6COgaNVA560xspfjjA8XHRTw4HwQUnQ1jGx77/W6G+SxWFX8QIMqrooHZJJJNjmqcF4PiftT/HqD6TMuVim4e9jT5ulwfKBqRfs5if0Ckd8N09tmMCy6xhWQYyBs6CJBfV6IzmUSnSfJDn87z68knACK9Jtgi/s2kMgVW2xfqwpNaDwJGJgrsykwLussXuvKkxfKwNToKaLoS4Xt1nw2IXFsWfjntAUCRv0mA8pFJrYhk0WaTfrX5LjDyIiSq+WgtUAOUlH0CNhwEKKzZ3ECkc8BDUnGk6UwLSaSgg4Di13QTBV4WthKbge2rhcrbz5t8FwCyYd4KmThS8RK6azqB1Ss/7A6Qk6ZXWgEkq4Bq+FF0DhX4boIOABSa5AfJMBW2+xxGVEuJp1fv/zawrStu1hWPyKdJ32tQRY+zeN6b+wPk2rxcbXHyNlSXu7tPLtMC95Te/oBsMkWWFwVrsebFjiYI1m2ZDgK6zoFR5MbhR58vdKWJdCRM6mPA7OuVJ9d8tCj6Xq+i+CSuOh8G+BbAkzQJjK2ZSuMsxnWXjwJIp5tFIyPJfM1BgsNag32NON4Him+BIS4XxtCMrt9mzhO9jHRvQFrMaMeEbCG7rXK7yLkEbC8L2h0Qp10sF7dmY22ZTWJ8D5jcrxXvDBB5JLEgfU90UisQx2wtcXHPUc/bgLS5oOLWujC67EFJcUQ8U/EBgCrkwfS9L5JmENjKbOqfwd3eAE26BR5bjfaBdiFCd2J8T+l9AKDZJ6Do9krFkPYPsO41uNsdGKEwQMJ4YNlkiH0ijYhfbe4NjLh4o63oOxhoBhLYGi3c1W+e3BeQuLhcGW2WY5LgOnpeE3/aqA8ATddgpQEJdjy6PTp5qbzDgNFjspThuF+1RLV+FqdV35faAcD4CkPcdb4YVtuKdBtqBG/b72ea94BCEoG7yz5ZyaImorhm8Bv+9wfEuZm6Qx3zk2qg8LVKE/Tn88QRAHcthttdo8DoI1S9avIgADxpORk5phgeKL6anwzzPjC+qUF9SSKVBoSu3YnI+aWLAwDpfiLccLnTRCaNHIUK91u0OwP/1v/P+l8AAAD//4gWpbFrY3nEAAAAAElFTkSuQmCC"
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
data | 是 | 二维码Base64 |
# 复制URL
接口地址: /api/node/nodeURL
请求方式: POST
请求示例:
{
"id": 1,
"clientType": "Shadowrocket"
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
clientType 是 | 客户端类型 Shadowrocket/v2rayN |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": "vless://7a57ec2e-bb05-5544-9c30-05814b376eba@trojanpanel.github.io:443?type=tcp\u0026security=reality\u0026flow=xtls-rprx-vision\u0026pbk=JraCqHw8lrQ-YdgrBSpBVTA4fhqHLfTUpZiP45x5gRI\u0026fp=chrome\u0026spx=%2FSCalpsSw\u0026sid=c6b6b5bf30c98f05\u0026sni=trojanpanel.github.io#vless-reality"
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
data | 是 | 分享链接 |
# 节点部分属性的默认值
接口地址: /api/node/nodeDefault
请求方式: GET
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"publicKey": "JraCqHw8lrQ-YdgrBSpBVTA4fhqHLfTUpZiP45x5gRI",
"privateKey": "GCRTXDZm1zuBdsQSM3Up9awTqxuzNwF6yXr5kxVT11w",
"shortId": "c6b6b5bf30c98f05",
"spiderX": "/SCalpsSw"
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
publicKey | 是 | Xray reality公钥 |
privateKey | 是 | Xray reality私钥 |
shortId | 是 | Xray reality shortId |
spiderX | 是 | Xray reality spiderX |
# 节点类型
# 查询节点类型列表
接口地址: /api/nodeType/selectNodeTypeList
请求方式: GET
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": [
{
"id": 1,
"name": "xray"
},
{
"id": 2,
"name": "trojan-go"
},
{
"id": 3,
"name": "hysteria"
},
{
"id": 4,
"name": "naiveproxy"
}
]
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
name | 是 | 名称 |
# 系统设置
# 查询系统设置
接口地址: /api/system/selectSystemByName
请求方式: GET
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"id": 1,
"registerEnable": 1,
"registerQuota": 1024,
"registerExpireDays": 1,
"resetDownloadAndUploadMonth": 0,
"trafficRankEnable": 1,
"captchaEnable": 1,
"expireWarnEnable": 0,
"expireWarnDay": 0,
"emailEnable": 0,
"emailHost": "",
"emailPort": 0,
"emailUsername": "",
"emailPassword": "",
"systemName": "Trojan Panel",
"clashRule": "rules:\n - RULE-SET,applications,DIRECT\n - DOMAIN,clash.razord.top,DIRECT\n - DOMAIN,yacd.haishan.me,DIRECT\n - RULE-SET,private,DIRECT\n - RULE-SET,reject,REJECT\n - RULE-SET,icloud,DIRECT\n - RULE-SET,apple,DIRECT\n - RULE-SET,google,DIRECT\n - RULE-SET,proxy,PROXY\n - RULE-SET,direct,DIRECT\n - RULE-SET,lancidr,DIRECT\n - RULE-SET,cncidr,DIRECT\n - RULE-SET,telegramcidr,PROXY\n - GEOIP,,DIRECT\n - GEOIP,CN,DIRECT\n - MATCH,PROXY\n\nrule-providers:\n reject:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/reject.txt\"\n path: ./ruleset/reject.yaml\n interval: 86400\n\n icloud:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/icloud.txt\"\n path: ./ruleset/icloud.yaml\n interval: 86400\n\n apple:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/apple.txt\"\n path: ./ruleset/apple.yaml\n interval: 86400\n\n google:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/google.txt\"\n path: ./ruleset/google.yaml\n interval: 86400\n\n proxy:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/proxy.txt\"\n path: ./ruleset/proxy.yaml\n interval: 86400\n\n direct:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/direct.txt\"\n path: ./ruleset/direct.yaml\n interval: 86400\n\n private:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/private.txt\"\n path: ./ruleset/private.yaml\n interval: 86400\n\n gfw:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/gfw.txt\"\n path: ./ruleset/gfw.yaml\n interval: 86400\n\n greatfire:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/greatfire.txt\"\n path: ./ruleset/greatfire.yaml\n interval: 86400\n\n tld-not-cn:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/tld-not-cn.txt\"\n path: ./ruleset/tld-not-cn.yaml\n interval: 86400\n\n telegramcidr:\n type: http\n behavior: ipcidr\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/telegramcidr.txt\"\n path: ./ruleset/telegramcidr.yaml\n interval: 86400\n\n cncidr:\n type: http\n behavior: ipcidr\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/cncidr.txt\"\n path: ./ruleset/cncidr.yaml\n interval: 86400\n\n lancidr:\n type: http\n behavior: ipcidr\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/lancidr.txt\"\n path: ./ruleset/lancidr.yaml\n interval: 86400\n\n applications:\n type: http\n behavior: classical\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/applications.txt\"\n path: ./ruleset/applications.yaml\n interval: 86400",
"xrayTemplate": "{\n \"log\": {\n \"loglevel\": \"warning\"\n },\n \"api\": {\n \"tag\": \"api\",\n \"services\": [\n \"HandlerService\",\n \"LoggerService\",\n \"StatsService\"\n ]\n },\n \"dns\": null,\n \"routing\": {\n \"rules\": [\n {\n \"inboundTag\": [\n \"api\"\n ],\n \"outboundTag\": \"api\",\n \"type\": \"field\"\n }\n ]\n },\n \"policy\": {\n \"levels\": {\n \"0\": {\n \"statsUserUplink\": true,\n \"statsUserDownlink\": true\n }\n },\n \"system\": {\n \"statsInboundUplink\": true,\n \"statsInboundDownlink\": true\n }\n },\n \"inbounds\": [],\n \"outbounds\": [\n {\n \"protocol\": \"freedom\"\n }\n ],\n \"transport\": null,\n \"stats\": {},\n \"reverse\": null,\n \"fakeDns\": null\n}"
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
registerEnable | 是 | 是否开放注册 0/否 1/是 |
registerQuota | 是 | 注册用户默认配额 单位/MB |
registerExpireDays | 是 | 注册用户过期天数 单位/天 |
resetDownloadAndUploadMonth | 是 | 是否每月重设下载和上传流量 |
trafficRankEnable | 是 | 是否开启流量排行 0/否 1/是 |
captchaEnable | 是 | 是否开启验证码登录 0/否 1/是 |
expireWarnEnable | 是 | 是否开启到期警告 0/否 1/是 |
expireWarnDay | 是 | 到期警告 单位/天 |
emailEnable | 是 | 是否开启邮箱功能 0/否 1/是 |
emailHost | 是 | 系统邮箱设置 host |
emailPort | 是 | 系统邮箱设置 port |
emailUsername | 是 | 系统邮箱设置 username |
emailPassword | 是 | 系统邮箱设置 password |
systemName | 是 | 系统名称 |
clashRule | 是 | Clash模板 |
xrayTemplate | 是 | Xray模板 |
# 更新系统配置
接口地址: /api/system/updateSystemById
请求方式: POST
请求示例:
{
"id": 1,
"registerEnable": 0,
"registerQuota": 1024,
"registerExpireDays": 1,
"resetDownloadAndUploadMonth": 0,
"trafficRankEnable": 1,
"captchaEnable": 1,
"expireWarnEnable": 0,
"expireWarnDay": 0,
"emailEnable": 0,
"emailHost": "",
"emailPort": 0,
"emailUsername": "",
"emailPassword": "",
"systemName": "Trojan Panel",
"clashRule": "rules:\n - RULE-SET,applications,DIRECT\n - DOMAIN,clash.razord.top,DIRECT\n - DOMAIN,yacd.haishan.me,DIRECT\n - RULE-SET,private,DIRECT\n - RULE-SET,reject,REJECT\n - RULE-SET,icloud,DIRECT\n - RULE-SET,apple,DIRECT\n - RULE-SET,google,DIRECT\n - RULE-SET,proxy,PROXY\n - RULE-SET,direct,DIRECT\n - RULE-SET,lancidr,DIRECT\n - RULE-SET,cncidr,DIRECT\n - RULE-SET,telegramcidr,PROXY\n - GEOIP,,DIRECT\n - GEOIP,CN,DIRECT\n - MATCH,PROXY\n\nrule-providers:\n reject:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/reject.txt\"\n path: ./ruleset/reject.yaml\n interval: 86400\n\n icloud:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/icloud.txt\"\n path: ./ruleset/icloud.yaml\n interval: 86400\n\n apple:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/apple.txt\"\n path: ./ruleset/apple.yaml\n interval: 86400\n\n google:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/google.txt\"\n path: ./ruleset/google.yaml\n interval: 86400\n\n proxy:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/proxy.txt\"\n path: ./ruleset/proxy.yaml\n interval: 86400\n\n direct:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/direct.txt\"\n path: ./ruleset/direct.yaml\n interval: 86400\n\n private:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/private.txt\"\n path: ./ruleset/private.yaml\n interval: 86400\n\n gfw:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/gfw.txt\"\n path: ./ruleset/gfw.yaml\n interval: 86400\n\n greatfire:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/greatfire.txt\"\n path: ./ruleset/greatfire.yaml\n interval: 86400\n\n tld-not-cn:\n type: http\n behavior: domain\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/tld-not-cn.txt\"\n path: ./ruleset/tld-not-cn.yaml\n interval: 86400\n\n telegramcidr:\n type: http\n behavior: ipcidr\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/telegramcidr.txt\"\n path: ./ruleset/telegramcidr.yaml\n interval: 86400\n\n cncidr:\n type: http\n behavior: ipcidr\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/cncidr.txt\"\n path: ./ruleset/cncidr.yaml\n interval: 86400\n\n lancidr:\n type: http\n behavior: ipcidr\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/lancidr.txt\"\n path: ./ruleset/lancidr.yaml\n interval: 86400\n\n applications:\n type: http\n behavior: classical\n url: \"https://cdn.jsdelivr.net/gh/Loyalsoldier/clash-rules@release/applications.txt\"\n path: ./ruleset/applications.yaml\n interval: 86400",
"xrayTemplate": "{\n \"log\": {\n \"loglevel\": \"warning\"\n },\n \"api\": {\n \"tag\": \"api\",\n \"services\": [\n \"HandlerService\",\n \"LoggerService\",\n \"StatsService\"\n ]\n },\n \"dns\": null,\n \"routing\": {\n \"rules\": [\n {\n \"inboundTag\": [\n \"api\"\n ],\n \"outboundTag\": \"api\",\n \"type\": \"field\"\n }\n ]\n },\n \"policy\": {\n \"levels\": {\n \"0\": {\n \"statsUserUplink\": true,\n \"statsUserDownlink\": true\n }\n },\n \"system\": {\n \"statsInboundUplink\": true,\n \"statsInboundDownlink\": true\n }\n },\n \"inbounds\": [],\n \"outbounds\": [\n {\n \"protocol\": \"freedom\"\n }\n ],\n \"transport\": null,\n \"stats\": {},\n \"reverse\": null,\n \"fakeDns\": null\n}"
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
registerEnable | 是 | 是否开放注册 0/否 1/是 |
registerQuota | 是 | 注册用户默认配额 单位/MB |
registerExpireDays | 是 | 注册用户过期天数 单位/天 |
resetDownloadAndUploadMonth | 是 | 是否每月重设下载和上传流量 |
trafficRankEnable | 是 | 是否开启流量排行 0/否 1/是 |
captchaEnable | 是 | 是否开启验证码登录 0/否 1/是 |
expireWarnEnable | 是 | 是否开启到期警告 0/否 1/是 |
expireWarnDay | 是 | 到期警告 单位/天 |
emailEnable | 是 | 是否开启邮箱功能 0/否 1/是 |
emailHost | 是 | 系统邮箱设置 host |
emailPort | 是 | 系统邮箱设置 port |
emailUsername | 是 | 系统邮箱设置 username |
emailPassword | 是 | 系统邮箱设置 password |
systemName | 是 | 系统名称 |
clashRule | 是 | Clash模板 |
xrayTemplate | 是 | Xray模板 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 上传静态网站文件
接口地址: /api/system/uploadWebFile
请求方式: POST
请求示例:
Form Data
file: (binary)
参数说明:
参数 | 必须 | 说明 |
---|---|---|
file | 是 | 文件二进制 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 上传logo
接口地址: /api/system/uploadLogo
请求方式: POST
请求示例:
Form Data
file: (binary)
参数说明:
参数 | 必须 | 说明 |
---|---|---|
file | 是 | 文件二进制 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 黑名单
# 分页查询黑名单
接口地址: /api/blackList/selectBlackListPage
请求方式: GET
请求示例:
/api/blackList/selectBlackListPage?pageNum=1&pageSize=20&ip=143.201.86.91
参数说明:
参数 | 必须 | 说明 |
---|---|---|
pageNum | 是 | 页号 |
pageSize | 是 | 页大小 |
ip | 否 | IP地址 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"pageNum": 1,
"pageSize": 20,
"total": 1,
"blackLists": [
{
"id": 1,
"ip": "143.201.86.91",
"createTime": "2023-08-19T16:24:58+08:00"
}
]
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
pageNum | 是 | 页号 |
pageSize | 是 | 页大小 |
total | 是 | 总数 |
blackLists | 否 | 黑名单 |
id | 否 | 主键 |
ip | 否 | IP地址 |
createTime | 否 | 创建时间 |
# 删除黑名单
接口地址: /api/blackList/deleteBlackListByIp
请求方式: POST
请求示例:
{
"ip": "143.201.86.91"
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
IP | 是 | IP地址 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 创建黑名单
接口地址: /api/blackList/createBlackList
请求方式: POST
请求示例:
{
"ip": "143.201.86.91"
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
ip | 是 | IP地址 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 邮件
# 查询邮件发送记录
接口地址: /api/emailRecord/selectEmailRecordPage
请求方式: GET
请求示例:
/api/emailRecord/selectEmailRecordPage?pageNum=1&pageSize=20&toEmail=123&state=1
参数说明:
参数 | 必须 | 说明 |
---|---|---|
pageNum | 是 | 页号 |
pageSize | 是 | 页大小 |
toEmail | 否 | 收件人 |
state | 否 | 状态 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"emailRecords": [],
"pageNum": 1,
"pageSize": 20,
"total": 1
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
pageNum | 是 | 页号 |
pageSize | 是 | 页大小 |
total | 是 | 总数 |
emailRecords | 否 | 发送记录 |
id | 否 | 主键 |
toEmail | 否 | 收件人邮箱 |
subject | 否 | 主题 |
content | 否 | 内容' |
state | 否 | 状态 0/未发送 1/发送成功 -1/发送失败 |
createTime | 否 | 创建时间 |
# 文件任务
# 分页查询文件任务
接口地址: /api/fileTask/selectFileTaskPage
请求方式: GET
请求示例:
/api/fileTask/selectFileTaskPage?pageNum=1&pageSize=20&accountUsername=sysadmin
参数说明:
参数 | 必须 | 说明 |
---|---|---|
pageNum | 是 | 页号 |
pageSize | 是 | 页大小 |
accountUsername | 否 | 创建人 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"fileTasks": [
{
"id": 1,
"name": "batchCreateAccountExport-20230819161912.json",
"type": 1,
"status": 2,
"errMsg": "",
"accountUsername": "sysadmin",
"createTime": "2023-08-19T16:19:12+08:00"
}
],
"pageNum": 1,
"pageSize": 20,
"total": 1
}
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
pageNum | 是 | 页号 |
pageSize | 是 | 页大小 |
total | 是 | 总数 |
fileTasks | 否 | 文件任务 |
id | 否 | 主键 |
name | 否 | 文件名称 |
type | 否 | 类型 1/用户导入 2/服务器导入 3/用户导出 4/服务器导出 |
status | 否 | 状态 -1/失败 0/等待 1/正在执行 2/成功 |
errMsg | 否 | 错误信息 |
accountUsername | 否 | 登录用户名 |
createTime | 否 | 创建时间 |
# 删除文件任务
接口地址: /api/fileTask/deleteFileTaskById
请求方式: POST
请求示例:
{
"id": 1
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
返回示例:
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
# 下载文件任务的文件
接口地址: /api/fileTask/downloadFileTask
请求方式: POST
请求示例:
{
"id": 1
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
返回示例:
Content-Type: application/octet-stream
[
{
"username": "83tBsbt6dJ0j",
"pass": "83tBsbt6dJ0j"
},
{
"username": "BxjLbz4rQyYd",
"pass": "BxjLbz4rQyYd"
},
{
"username": "XLtcPBGHMEJz",
"pass": "XLtcPBGHMEJz"
},
{
"username": "foxXLpN0KQkp",
"pass": "foxXLpN0KQkp"
},
{
"username": "bX3pahuM7Lma",
"pass": "bX3pahuM7Lma"
}
]
参数说明:
参数 | 必须 | 说明 |
---|---|---|
username | 是 | 登录用户名 |
pass | 是 | 登录密码 |
# 获取文件模板
接口地址: /api/fileTask/downloadTemplate
请求方式: POST
请求示例:
{
"id": 1
}
参数说明:
参数 | 必须 | 说明 |
---|---|---|
id | 是 | 主键 |
返回示例:
[
{
"grpc_port": 8100,
"ip": "127.0.0.1",
"name": "example"
}
]
参数说明:
参数 | 必须 | 说明 |
---|---|---|
ip | 是 | 服务器IP |
name | 是 | 服务器名称 |
grpc_port | 是 | API端口 |