# API文档

# 开发前必读

  1. 接口认证和鉴权

    除了开放接口,其余接口必须设置请求头Authorization用于认证和鉴权

    Authorization值格式为Bearer ${Token}

    ${Token}可通过登录接口(/api/auth/login)获得

  2. 通用返回对象

    返回示例:

    {
      "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

接口地址: /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/普通用户
email 邮箱
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 登录密码
email 邮箱
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 登录用户名
email 邮箱
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"
}

参数说明:

参数 必须 说明
email 邮箱
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 过期时间
email 邮箱

返回示例:

{
  "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
}

接口地址: /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端口
Last Updated: 3/15/2024, 2:15:21 PM