V2ray WebApi对接

功能:V2RayController

对应后端程序

本章节包含了VNet-V2ray 以及 V2ray-Posidon的对接内容

本章节重点为V2ray获取节点,用户信息与上报域名证书信息

注意

  • 节点后端与面板使用的时间误差不应该超过5分钟,否则API授权验证失败

  • 使用WebApi后,用户设置中的节点设置信息将不再采用,而是统一获取节点的配置信息;用户的个人配置信息仅适用于DB版本

获取节点信息

GET https://api.proxypanel.ml/api/v2ray/v1/node/:id

V2ray后端启动和重载时获取节点信息

Path Parameters

NameTypeDescription

id*

integer

节点ID:int(10) unsigned

Headers

NameTypeDescription

key*

string

由管理后台线路系统,线路授权处取得授权密钥

timestamp*

integer

每次请求的10位时间戳

{
    "status": "success",
    "code": 200,
    "data": {
        "id": 2,
        "is_udp": true,
        "speed_limit": 6555555,
        "client_limit": 1,
        "push_port": 8081,
        "secret": "tdcpxpip",
        "key": "",
        "pem": "",
        "v2_license": "234234",
        "v2_alter_id": 0,
        "v2_port": 10085,
        "v2_method": "aes-128-gcm",
        "v2_net": "ws",
        "v2_type": "http",
        "v2_host": "v1.vnetpanel.com",
        "v2_path": "/3l1iop1tev35tov9",
        "v2_tls": true,
        "v2_tls_provider": "{\"provider\": \"cloudflare\", \"email\": \"admin@vnetpanel.com\", \"api_key\": \"vnetpanel\"}"
    },
    "message": "获取节点信息成功"
}

获取用户列表

GET https://api.proxypanel.ml/api/v2ray/v1/userList/:id

V2ray后端启动和重载时获取用户列表

Path Parameters

NameTypeDescription

id*

integer

节点ID:int(10) unsigned

Headers

NameTypeDescription

key*

string

由管理后台线路系统,线路授权处取得授权密钥

timestamp*

integer

每次请求的10位时间戳

{
    "status": "success",
    "code": 200,
    "data": [
        {
            "uid": 1,
            "vmess_uid": "1727ed1f-78d0-675a-5cc8-a9a002fdf1a4",
            "speed_limit": 134217728
        },
        {
            "uid": 2,
            "vmess_uid": "d86a54d1-00a3-3677-f356-91df194adf35",
            "speed_limit": 131072
        }
    ],
    "message": "获取用户列表成功",
    "updateTime": 1565172630
}

上报伪装域名证书信息

POST https://api.proxypanel.ml/api/v2ray/v1/certificate/:id

后端根据获取节点信息中返回的v2_hostkeypem字段来判断:如果v2_host有值,但keypem为空,则由后端自动签证书并上报给管理系统用于记录,用于解决后端重启后无需在重新签一张新的证书的问题

Path Parameters

NameTypeDescription

id*

integer

节点ID:int(10) unsigned

Headers

NameTypeDescription

key*

string

由管理后台线路系统,线路授权处取得授权密钥

timestamp*

integer

每次请求的10位时间戳

Request Body

NameTypeDescription

key*

string

证书KEY

pem*

string

证书PEM

{
    "status": "success",
    "code": 200,
    "data": "",
    "message": "上报节点伪装域名证书成功"
}

传入参数示例

{"key":"xxxxxxxxxxxxxxxx","pem":"xxxxxxxxxxxxxxxxxxx"}

最后更新于