花生壳:HTTP协议
目录
1 检测IP变化
1.1 直接连接
1.2 网站IP检测
2 更新协议
2.1 HTTP请求
2.2 例子
2.2.1 1使用URL验证
2.2.2 2原始HTTP GET请求
2.3 更新参数
3 返回代码
3.1 代码列表
检测IP变化
要确定客户端是否应该更新,它必须有一个可靠的方式来确定当前的IP地址是什么,以便比较最后一次更新的地址。以下有两种方式。
直接连接
客户端自行判断并获取其连接到互联网的公网IP地址。
网站IP检测
通过网站IP检测的方式,获取当前机器公网IP地址。
Oray DDNS提供CheckIP的服务,可通过下面地址检测: http://ddns.oray.com/checkip
更新协议
当客户端发现IP地址变化或是用户修改设置时,客户端应该进行更新。 所有的更新都基本于标准的HTTP请求发送。 服务器会传回一个返回代码,客户端需要解析。
HTTP请求
主机名:ddns.oray.com
HTTP端口:80
HTTPS 端口:443
请求支持HTTP和基于SSL的HTTPS协议(HTTPS需要付费用户才能使用) 所有客户端必须发送一个完整的User-Agent文件头,用于区分不同的设备,空值或非法参数将导致请求失败。
例子
1.使用URL验证
适用于浏览器或应用程序(fetch, curl, lwp-request),可以在URL中包含验证信息。
http://username:password@ddns.oray.com/ph/update?hostname=yourhostname&myip=ipaddress
实际的HTTP请求,类似下面的代码。 其中 base-64-authorization 请使用 Base64 加密 username:password 后的字符替换。
GET /ph/update?hostname=yourhostname&myip=ipaddress HTTP/1.0
Host: ddns.oray.com
Authorization: Basic base-64-authorization
User-Agent: Oray
请注意必须使用GET请求,POST是不被允许的。
目前仅允许提交以下参数
参数 | 说明 |
---|---|
hostname | 需要更新的域名,此域名必须是开通花生壳服务。多个域名使用,分隔,默认为空,则更新护照下所有激活的域名。例:hostname=test.oray.com,customtest.oray.com |
myip | 需要更新的IP地址,可以不填。如果不指定,则由服务器获取到的IP地址为准 |
返回代码
参数 | 说明 |
---|---|
good | 更新成功,域名的IP地址已经更新,同时会返回本次更新成功的IP,用空格隔开,如:good 1.2.3.4 |
nochg | 更新成功,但没有改变IP。一般这种情况为本次提交的IP跟上一次的一样 |
notfqdn | 未有激活花生壳的域名 |
nohost | 域名不存在或未激活花生壳 |
nochg | 更新成功,但没有改变IP。一般这种情况为本次提交的IP跟上一次的一样 |
abuse | 请求失败,频繁请求或验证失败时会出现 |
!donator | 表示此功能需要付费用户才能使用,如https |
911 | 系统错误 |