2016-06-23 68 views
0

嗨,大家好我想從Java應用程序發送一個xmpp消息。我已經在ejabberd中配置了mod_rest。 Java方法發送XMPP消息如下:無法發送郵件使用mod_rest在Ejabberd 14.05

public String sendmessage() { 
     String response = null; 
     HttpHeaders headers = new HttpHeaders(); 
     headers.setContentType(MediaType.APPLICATION_XML); 
     String xmppMessage = "<message from='[email protected]<ip>'"+ 
       " to='[email protected]<ip>'"+ 
       ">"+ 
       "<body>Hello</body>"+ 
      "</message>"; 

     headers.set("Host",ip+":"+port); 
     headers.set("Accept-Charset","*/*"); 
     headers.setContentType(MediaType.APPLICATION_XML); 

     HttpEntity<String> request = new HttpEntity<String>(xmppMessage,headers); 
     response = restTemplate.postForObject("http://ip:port/rest", request, String.class); 

     return response; 
    } 

雖然我得到HTTP 406錯誤:

Jun 23, 2016 11:32:14 AM org.springframework.web.client.RestTemplate handleResponseError 
WARNING: POST request for "http://ip/rest" resulted in 406 (Not Acceptable); invoking error handler 
Exception in thread "main" org.springframework.web.client.HttpClientErrorException: 406 Not Acceptable 
    at org.springframework.web.client.DefaultResponseErrorHandler.handleError(DefaultResponseErrorHandler.java:91) 
    at org.springframework.web.client.RestTemplate.handleResponseError(RestTemplate.java:576) 
    at org.springframework.web.client.RestTemplate.doExecute(RestTemplate.java:532) 
    at org.springframework.web.client.RestTemplate.execute(RestTemplate.java:489) 
    at org.springframework.web.client.RestTemplate.postForObject(RestTemplate.java:318) 
    at ejabberd.rest.service.impl.JabberServiceImpl.sendmessage(JabberServiceImpl.java:377) 
    at ejabberd.rest.service.impl.JabberServiceImpl.main(JabberServiceImpl.java:386) 

雖然ejabberd.log我得到不好的匹配誤差

2016-06-23 11:55:16.838 [info] <0.813.0>@ejabberd_listener:accept:313 (#Port<0.6091>) Accepted connection ip1 -> ejabberdIP:port 
2016-06-23 11:55:16.839 [debug] <0.1069.0>@ejabberd_http:init:145 S: [{[<<"rest">>],mod_rest},{[<<"captcha">>],ejabberd_captcha},{[<<"admin">>],ejabberd_web_admin},{[<<"http-bind">>],mod_http_bind},{[<<"http-poll">>],ejabberd_http_poll}] 
2016-06-23 11:55:16.839 [info] <0.1069.0>@ejabberd_http:init:149 started: {gen_tcp,#Port<0.6091>} 
2016-06-23 11:55:16.839 [debug] <0.1069.0>@ejabberd_http:process_header:277 (#Port<0.6091>) http query: 'POST' /rest 
2016-06-23 11:55:16.839 [debug] <0.1069.0>@ejabberd_http:process_request:438 client data: <<"<message from='[email protected]' to='[email protected]'><body>Hello</body></message>">> 
2016-06-23 11:55:16.840 [debug] <0.1069.0>@ejabberd_http:process:350 [<<"rest">>] matches [<<"rest">>] 
2016-06-23 11:55:16.841 [debug] <0.1069.0>@ejabberd_http:process:354 [{'Content-Length',<<"97">>},{'Connection',<<"keep-alive">>},{'Host',<<"ip:port">>},{'User-Agent',<<"Java/1.7.0_45">>},{'Accept-Charset',<<"big5, big5-hkscs, euc-jp, euc-kr, gb18030, gb2312, gbk, ibm-thai, ibm00858, ibm01140, ibm01141, ibm01142, ibm01143, ibm01144, ibm01145, ibm01146, ibm01147, ibm01148, ibm01149, ibm037, ibm1026, ibm1047, ibm273, ibm277, ibm278, ibm280, ibm284, ibm285, ibm290, ibm297, ibm420, ibm424, ibm437, ibm500, ibm775, ibm850, ibm852, ibm855, ibm857, ibm860, ibm861, ibm862, ibm863, ibm864, ibm865, ibm866, ibm868, ibm869, ibm870, ibm871, ibm918, iso-2022-cn, iso-2022-jp, iso-2022-jp-2, iso-2022-kr, iso-8859-1, iso-8859-13, iso-8859-15, iso-8859-2, iso-8859-3, iso-8859-4, iso-8859-5, iso-8859-6, iso-8859-7, iso-8859-8, iso-8859-9, jis_x0201, jis_x0212-1990, koi8-r, koi8-u, shift_jis, tis-620, us-ascii, utf-16, utf-16be, utf-16le, utf-32, utf-32be, utf-32le, utf-8, windows-1250, windows-1251, windows-1252, windows-1253, windows-1254, windows-1255, windows-1256, windows-1257, windows-1258, windows-31j, x-big5-hkscs-2001, x-big5-solaris, x-euc-jp-linux, x-euc-tw, x-eucjp-open, x-ibm1006, x-ibm1025, x-ibm1046, x-ibm1097, x-ibm1098, x-ibm1112, x-ibm1122, x-ibm1123, x-ibm1124, x-ibm1364, x-ibm1381, x-ibm1383, x-ibm300, x-ibm33722, x-ibm737, x-ibm833, x-ibm834, x-ibm856, x-ibm874, x-ibm875, x-ibm921, x-ibm922, x-ibm930, x-ibm933, x-ibm935, x-ibm937, x-ibm939, x-ibm942, x-ibm942c, x-ibm943, x-ibm943c, x-ibm948, x-ibm949, x-ibm949c, x-ibm950, x-ibm964, x-ibm970, x-iscii91, x-iso-2022-cn-cns, x-iso-2022-cn-gb, x-iso-8859-11, x-jis0208, x-jisautodetect, x-johab, x-macarabic, x-maccentraleurope, x-maccroatian, x-maccyrillic, x-macdingbat, x-macgreek, x-machebrew, x-maciceland, x-macroman, x-macromania, x-macsymbol, x-macthai, x-macturkish, x-macukraine, x-ms932_0213, x-ms950-hkscs, x-ms950-hkscs-xp, x-mswin-936, x-pck, x-sjis_0213, x-utf-16le-bom, x-utf-32be-bom, x-utf-32le-bom, x-windows-50220, x-windows-50221, x-windows-874, x-windows-949, x-windows-950, x-windows-iso2022jp">>},{'Content-Type',<<"application/xml">>},{'Accept',<<"text/plain, */*">>}] 
2016-06-23 11:55:16.841 [debug] <0.1069.0>@mod_rest:process:53 Error when processing REST request: 
Data: <<"<message from='[email protected]' to='[email protected]'><body>Hello</body></message>">> 
Error: {badmatch,false} 

消息的格式有什麼問題或缺少什麼? 非常感謝你們的幫助

編輯1

sessionID : Problem 'error function_clause' occurred executing the command. 
Stacktrace: [{ejabberd_commands,'-check_access_commands/5-fun-0-', 
       [{rest,[{registered_users,[all]},{connected_users,[all]}]}], 
       [{file,"src/ejabberd_commands.erl"},{line,372}]}, 
      {lists,'-filter/2-lc$^0/1-0-',2,[{file,"lists.erl"},{line,1284}]}, 
      {ejabberd_commands,check_access_commands,5, 
       [{file,"src/ejabberd_commands.erl"},{line,371}]}, 
      {ejabberd_commands,execute_command,4, 
       [{file,"src/ejabberd_commands.erl"},{line,308}]}, 
      {ejabberd_ctl,call_command,3, 
       [{file,"src/ejabberd_ctl.erl"},{line,293}]}, 
      {ejabberd_ctl,try_call_command,3, 
       [{file,"src/ejabberd_ctl.erl"},{line,269}]}, 
      {ejabberd_ctl,process2,3, 
       [{file,"src/ejabberd_ctl.erl"},{line,218}]}, 
      {mod_rest,maybe_post_request,3, 
       [{file,"src/mod_rest.erl"},{line,140}]}] 
+0

爲什麼不使用send_message方法,而不是發送XML節 –

+0

只是檢查您是否可以從ejabberdctl命令send_message使用u發送。如果是的話,那麼你可以用它來達到你的要求。 –

回答

1

我會做更喜歡使用send_message方法來發送,而不是發送XML節的消息。請在mod_admin_extra或mod_admin模塊中查找send_message命令,並使用它從後臺發送消息。

public String sendmessage() { 
     String response = null; 
     String request = "send_message chat " + actor_id + "@" + chatServer + "/backend " + target_id + "@" + chatServer + " " + " Message " + "\"" 
        + "Hello" + "\""; 
     response = restTemplate.postForObject("http://ip:port/rest", request, String.class); 

     return response; 
    } 
+0

嗨kumar現在我可以發送滿足我的目的的xml節,但命令send_message_chat命令不起作用。請檢查編輯後的錯誤消息 – sujays

+0

@SujaySudeep命令是** send_message **。 –

+0

我使用的是舊版本的mod_admin_extra,它有兩個命令send_message_chat和send_message_headline – sujays