我正在尝试做一些休息请求(没有OAuth)但是ejabberd响应总是“HTTP / 1.1 400 Bad Request”
以下是详细信息:
ejabberd版本: 16.02
ejabberd配置
port: 5280
ip: "::"
module: ejabberd_http
request_handlers:
##"/websocket": ejabberd_http_ws
##"/oauth": ejabberd_oauth
"/api": mod_http_api
## "/pub/archive": mod_http_fileserver
web_admin: true
http_bind: true
http_poll: true
## register: true
captcha: false
commands_admin_access: configure
commands:
- add_commands: user
oauth_expire: 3600
oauth_access: all
请求
curl -v -X POST -H "X-Admin: true" -H "Authorization: Basic YWRtaW5AcHJqLmlvOmFkbWlu" -H "Content-Type:application/json" http://prj.io:5280/api/status -d '{}'
日志
2016-03-26 04:38:04.711 [debug] <0.490.0>@ejabberd_http:process_header:281 (#Port<0.16265>) http query: 'POST' <<"/api/status">>
2016-03-26 04:38:04.711 [debug] <0.490.0>@ejabberd_http:extract_path_query:395 client data: <<"{}">>
2016-03-26 04:38:04.711 [debug] <0.490.0>@ejabberd_http:process:353 [<<"api">>,<<"status">>] matches [<<"api">>]
2016-03-26 04:38:04.711 [info] <0.490.0>@mod_http_api:log:388 Admin call status [] from ::FFFF:192.168.117.1:53583
请帮助我理解ejabberd的行为以及向mod_http_api
发布一些请求的方式。
答案 0 :(得分:0)
尝试以下......
commands_admin_access: configure commands: - add_commands: - status
答案 1 :(得分:0)
在请求中,您已经提供了
curl -v -X POST -H "X-Admin: true" -H "Authorization: Basic YWRtaW5AcHJqLmlvOmFkbWlu" -H "Content-Type:application/json" http://prj.io:5280/api/status -d '{}'
。
没有这样的终点状态
尝试使用以下其中一项作为终点