-1

このリンクをたどって、tomcatを使用してwebsocketサーバーを作成しました。Websocket にアクセスしようとすると、Firefox は接続を確立できないと言いました。

これが私のコードです

public class WsChatServlet extends WebSocketServlet
{
private static final long serialVersionUID = 1L;
private static ArrayList<MyMessageInbound> mmiList = new ArrayList<MyMessageInbound>();

@Override
protected StreamInbound createWebSocketInbound(String string) {
    System.out.println("CreateWebSocketInbound()");
    return new MyMessageInbound();
}

private class MyMessageInbound extends MessageInbound
{
    WsOutbound myoutbound;

    @Override
    protected void onBinaryMessage(ByteBuffer bb) throws IOException {
        System.out.println("onBinaryMessage()");
    }

    @Override
    protected void onTextMessage(CharBuffer cb) throws IOException {            
        System.out.println("Accept Message : "+ cb);
        for (MyMessageInbound mmib : mmiList)
        {
            CharBuffer buffer = CharBuffer.wrap(cb);
            mmib.myoutbound.writeTextMessage(CharBuffer.wrap("Hello!"));
            mmib.myoutbound.flush();
        }
    }

    @Override
    protected void onOpen(WsOutbound outbound) {
        System.out.println("onOpen()");
        try {
            System.out.println("Open Client.");
            this.myoutbound = outbound;
            mmiList.add(this);
            outbound.writeTextMessage(CharBuffer.wrap("Hello!"));
        } catch (IOException ex) {
            Logger.getLogger(WsChatServlet.class.getName()).log(Level.SEVERE, null, ex);
        }
    }

    @Override
    protected void onClose(int status) {
        System.out.println("Close Client.");
        mmiList.remove(this);
    } 
}

サーバーログはこちら

24 Apr 13 22:53:09 org.apache.catalina.core.StandardWrapperValve invoke
SEVERE: Servlet.service() for servlet [WsChatServlet] in context with path [/HelloWebSocket] threw exception
java.lang.ClassCastException: org.netbeans.modules.web.monitor.server.MonitorRequestWrapper cannot be cast to org.apache.catalina.connector.RequestFacade
    at org.apache.catalina.websocket.WebSocketServlet.doGet(WebSocketServlet.java:126)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:621)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
    at org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:393)
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:225)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:169)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:98)
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:927)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:999)
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:565)
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:307)
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
    at java.lang.Thread.run(Thread.java:662)

この問題を解決する方法とログをコード形式で作成する方法を教えてください。

4

2 に答える 2

1

これは Tomcat 7.0.27 のバグでした。7.0.37 を使用するか、Atmosphereのようなフレームワークを使用することをお勧めします(このような問題から保護されます)。

-- ジャンフランソワ

于 2013-04-24T19:40:31.450 に答える
0

Tomcat のバージョンを確認します。Websocket は標準ではなく、サーバーごとに Websocket の実装が異なります。以前は tomcat で websocket を使用していましたが、以前は tomcat 7.0.27 でしか動作しませんでした。7.0.29でも動きませんでした。したがって、チュートリアルで使用したサーバーを見つけることができるかどうかを確認するか、別のバージョンで試してみることをお勧めします。

于 2013-04-24T16:15:00.710 に答える