这个是v2ray python调用api的实例,可以根据这个实例调用所有的api,本例子的主要是增加用户
- 最开始写这个的驱动是我要调用官方api,最后发现网上是没有python调用相关的信息,只找到了一个可能是官方开发写的一个教程,是go语言的,直接调用了源代码里面的各种库,但是那个是go啊,咱们又不会,而且直接依赖源代码,这个很麻烦,于是就想着用python重新写
- go的调用例子url:api go 调用实例
- 本项目主要含有两个主要文件,client.py和get_proto.py,get_proto.py是前置处理文件,client.py是api调用文件
- 其他非go语言调用均可参照此项目
因为v2ray的api使用了gRPC,gRPC又需要protobuf,所有我们的项目也依赖这俩,除此之外我们还依赖了gRPC的编译工具,关于python gRPC更多的信息参见gRPC
安装gRPC和gRPC-tool
python -m pip install grpcio
python -m pip install grpcio-tools
这个文件主要是把v2ray里面的proto文件编译成为.py的文件,所有我们需要去下载v2ray的项目源码
使用方式如下:
python get_proto.py -d 源代码目录地址
例如:
python get_proto.py -d c:\\v2ray-master
里面主要是文件夹的复制、删除、移动等操作,核心的是运行了一条命令
python -m grpc.tools.protoc -I=. --python_out=grpc_dir --grpc_python_out=grpc_dir *.proto *.proto (各种proto同文件)
这个就比较简单了,直接按照go api调用过程翻译就行了,当新增方法是,主要查看.proto文件的类描述,里面很多时候使用了v2ray.com.core.common.serial.typed_message的这个类
三个service的.proto文件在以下路径:
- v2ray/com/core/app/proxyman/command/command.proto
- v2ray/com/core/app/stats/command/command.proto
- v2ray/com/core/app/log/command/config.proto