こんにちは、私はcometd + jquery + javaを使って次の問題を報告しています。CometD + Java + jQuery:1回の呼び出しで多すぎます
これは私のweb.xml、イムcometdの注釈実装を使用して、次のとおりです。
<!-- Cometd Servlet -->
<servlet>
<servlet-name>cometd</servlet-name>
<servlet-class>org.cometd.java.annotation.AnnotationCometdServlet</servlet-class>
<init-param>
<param-name>timeout</param-name>
<param-value>60000</param-value>
</init-param>
<init-param>
<param-name>logLevel</param-name>
<param-value>3</param-value>
</init-param>
<init-param>
<param-name>services</param-name>
<param-value>com.api.services.UserStatusService</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
<async-supported>true</async-supported>
</servlet>
<servlet-mapping>
<servlet-name>cometd</servlet-name>
<url-pattern>/do/cometd/*</url-pattern>
</servlet-mapping>
は、これは私が登録されているサービスである:
package com.api.services;
import java.util.HashMap;
import javax.inject.Inject;
import org.cometd.bayeux.Message;
import org.cometd.bayeux.client.ClientSession;
import org.cometd.bayeux.client.ClientSessionChannel;
import org.cometd.bayeux.server.BayeuxServer;
import org.cometd.java.annotation.Service;
import org.cometd.java.annotation.Session;
import org.cometd.java.annotation.Subscription;
@Service
public class UserStatusService
{
@Inject
private BayeuxServer bayeux;
@Session
private ClientSession bayeuxClient;
@Subscription("/userStatus")
public void userStatus (Message message)
{
HashMap<String, String> mapa = new HashMap<String,String>();
String channel = message.getChannel();
System.out.println("*** The Channel is "+channel+" ***");
ClientSessionChannel chann = bayeuxClient.getChannel(channel);
mapa.put("canal", channel);
mapa.put("mensaje", "Hola Wi!!");
mapa.put("ServChan", bayeux.getChannels().get(0).toString());
chann.publish(mapa);
}
}
そして、これはするために使用してJSのjQueryコードイムですサブスクライブして公開する(大きなオブジェクトの一部ですので、これに関連する主要なものを貼り付けるだけです)。
/** On document ready i call this one **/
initBroad:function(){
$.cometd.unregisterTransport('websocket');
$.cometd.init('http://localhost/MyApp/do/cometd');
console.log("Set cometd initialization");
main.broadListener();
},
count:0,
subscription:null,
refresh:function(){
this.appUnsubscribe();
this.appSubscribe();
},
appUnsubscribe:function(){
if (this.subscription)
$.cometd.unsubscribe(this.subscription);
this.subscription = null;
},
appSubscribe:function(){
func = function(msg){
/** I had to do this in order to avoid ALL the 500 times it does it :S **/
if(main.count < 1){
console.log(main.count + ": " + msg.data.mensaje);
}
main.count++;
};
this.subscription = $.cometd.subscribe("/userStatus",func);
},
broadListener:function(){
console.log("Set the broadListener");
main.refresh();
},
publishBroad:function(){
main.refresh();
$.cometd.publish('/userStatus', {mensaje:"Hola"});
},
さて、コンソール上でpublishBroadメソッドを実行しようとすると、実際には実行されますが、1回のクリック/リクエストで450-500回サーバー上で実行されます(はい、ブラウザからJavaサーバーへのリクエストは1回だけです)回はサーバー側でのみ繰り返され、何度もその応答でブラウザに到達します)。
どうしたのですか?私の最新のcometd.jsとjquery.cometd.jsをcometd公式サイトから使用しています。
また、コンソール(JBoss AS7を使用しています)でこれをチェックすると、私の呼び出しがメソッドを入力したかどうかを確認する出力ログ行が残っていました(The channel is:そのログ行のJBossコンソールの450〜500倍!
誰もが
感謝!!
私は気づいたtho私は '(this._subscription) $ .cometd.unsubscribe(this.subscription); this.subscription = null; '余分なアンダースコアがあると思います –
この行を修正しましたが、問題を抱えていますが、js cometd publishメソッドを呼び出すと、サーバーのサービス:( –