Web API¶
GOST可以通过web API服务使用RESTful API和GOST进程进行交互。
开启服务¶
API服务支持两种运行方式:全局服务和普通服务。
当使用全局服务,采用web API方式进行配置重载时,服务将不受影响。
全局服务¶
通过命令行-api
或配置文件中的api
对象来定义API服务。
开启认证并设置选项
也可以只开启API服务,后续通过API来动态配置服务和其他组件。
普通服务¶
采用普通服务运行时,可以使用服务所支持的所有功能。
路径前缀¶
通过pathPrefix
参数可以设置URL路径前缀。
例如默认路径为http://localhost:18080/config,当设置pathPrefix
为/api
后变为http://localhost:18080/api/config。
访问日志¶
通过accesslog
参数开启接口访问日志,默认不输出访问日志。
身份认证¶
身份认证采用HTTP Basic Auth方式。
配置文件中通过auth
或auther
选项可以设置身份认证信息,如果设置了auther
选项,auth
选项则会被忽略。
在线测试¶
你可以使用线上环境进行测试,或在下面的swaggerUI中直接尝试。接口说明请参考在线API文档。
GOST程序已经内置了swagger API文档,如果本地开启了Web API服务,也可以通过https://api.gost.run/swagger-ui/?url=http://localhost:18080/docs/swagger.yaml来尝试配置本地服务(这里假设本地Web API服务运行在18080端口)。
Scheme切换
SwaggerUI中默认的scheme为HTTPS,如果要测试本地服务则需要手动切换到HTTP。