3

Spring WebSockets 4.1.6、Tomcat 7.0.54、および Apache 2.4.16 を Web サーバーとして使用して単純なアプリケーションを実行する際に問題が発生しています。

私はインターネットで多くの投稿を読みましたが、何が起こっているのかわかりません。サーバーは問題なく起動します。WebSocket 接続を開始するサーバー プロジェクトで公開された index.html があります。

このファイルに Tomcat から直接アクセスすると、問題なく動作します。

http://localhost:8080/myserver/messaging/index.html

しかし、Apache Server からこのファイルにアクセスすると、うまくいきません。

http://localhost/messages/messaging/index.html

私のApacheサーバーでは、プロキシパスを構成しました:

ProxyPass           /messages http://localhost:8080/myserver
ProxyPassReverse    /messages http://localhost:8080/myserver

私のサーバーの WebSocket 構成は次のようになります。

@Configuration
@EnableWebSocketMessageBroker
public class PuiWebSocketConfig extends
    AbstractWebSocketMessageBrokerConfigurer {

    @Override
    public void configureMessageBroker(MessageBrokerRegistry config) {
        config.setApplicationDestinationPrefixes("/app");
        config.enableSimpleBroker("/user", "/topic");
    }

    @Override
    public void registerStompEndpoints(StompEndpointRegistry registry) {
        registry.addEndpoint("/puimessaging").withSockJS();
    }
}

そして、私のクライアントは次のように接続します:

function connect() {
    var socket = new SockJS('/server/puimessaging');
    var stompClient = Stomp.over(socket);
    var headers = {
        puiSessionId : 'a1234567890z'
    };
    stompClient.connect(headers, function(frame) {
        setConnected(true);
        stompClient.subscribe('/user/a1234567890z/response', function(data) {
            ...
        });
    });
}

サーバーは、非同期サポートを有効にする必要があるというエラーをスローしますが、どうすればよいかわかりません。

Async support must be enabled on a servlet and for all filters involved
in async request processing. This is done in Java code using the Servlet
API or by adding "<async-supported>true</async-supported>" to servlet and
filter declarations in web.xml. Also you must use a Servlet 3.0+ container

web.xml ファイルにプロパティを追加しようとしましたが、うまくいきません:

<servlet>
    <servlet-name>spring-mvc</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
    <async-supported>true</async-supported>
</servlet>

<servlet-mapping>
    <servlet-name>spring-mvc</servlet-name>
    <url-pattern>/*</url-pattern>
</servlet-mapping>

何か案が?

前もって感謝します。

マルク

4

4 に答える 4

1

WebSocketsではなくxhr_streamingを介して動作します。私の構成は次のようになります。

Web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app id="webApp" xmlns="http://java.sun.com/xml/ns/javaee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
    version="3.0">

    <servlet>
        <servlet-name>spring-mvc</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <load-on-startup>1</load-on-startup>
        <async-supported>true</async-supported>
    </servlet>

    <servlet-mapping>
        <servlet-name>spring-mvc</servlet-name>
        <url-pattern>/*</url-pattern>
    </servlet-mapping>

    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>

    <filter>
        <filter-name>encodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>UTF-8</param-value>
        </init-param>
        <init-param>
            <param-name>forceEncoding</param-name>
            <param-value>true</param-value>
        </init-param>
        <async-supported>true</async-supported>
    </filter>
    <filter-mapping>
        <filter-name>encodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
</web-app>

Tomcat (server.xml):

<Connector URIEncoding="UTF-8" connectionTimeout="20000"
        port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
        redirectPort="8443" />

アパッチ httpd:

...
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_ajp_module modules/mod_proxy_ajp.so
LoadModule proxy_balancer_module modules/mod_proxy_balancer.so
LoadModule proxy_connect_module modules/mod_proxy_connect.so
LoadModule proxy_express_module modules/mod_proxy_express.so
LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so
LoadModule proxy_ftp_module modules/mod_proxy_ftp.so
# LoadModule proxy_html_module modules/mod_proxy_html.so
LoadModule proxy_http_module modules/mod_proxy_http.so
LoadModule proxy_scgi_module modules/mod_proxy_scgi.so
LoadModule proxy_wstunnel_module modules/mod_proxy_wstunnel.so
...
ProxyPass   /pideweb-gijon  http://localhost:8080/pideweb_gijon
ProxyPassReverse    /pideweb-gijon  http://localhost:8080/pideweb_gijon
ProxyPass   /pideweb-gijon/endpointpuisocket/   ws://localhost:8080/pideweb_gijon/endpointpuisocket/
ProxyPassReverse    /pideweb-gijon/endpointpuisocket/   ws://localhost:8080/pideweb_gijon/endpointpuisocket/

春の構成:

@Configuration
@EnableWebSocketMessageBroker
public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer {

    @Autowired
    private WebSocketService websocketService;

    @Override
    public void configureMessageBroker(MessageBrokerRegistry config) {
        config.setApplicationDestinationPrefixes("/app");
        config.enableSimpleBroker("/user", "/topic");
        // config.setUserDestinationPrefix("/user");
        // config.enableSimpleBroker("/queue", "/topic");
    }

    @Override
    public void registerStompEndpoints(StompEndpointRegistry registry) {
        registry.addEndpoint("/endpointpuisocket").withSockJS();
    }

    @Override
    public void configureClientInboundChannel(ChannelRegistration registration) {
        ChannelInterceptorAdapter interceptor = new ChannelInterceptorAdapter() {

            @Override
            public Message<?> preSend(Message<?> message, MessageChannel channel) {
                // store or remove the Session ID in the list depending on the
                // message is for Connecting or Disconnecting
                StompHeaderAccessor accessor = StompHeaderAccessor
                        .wrap(message);
                StompCommand command = accessor.getCommand();
                List<String> headersSessionId = accessor
                        .getNativeHeader("puiSessionId");
                if (!CollectionUtils.isEmpty(headersSessionId)) {
                    String sessionId = headersSessionId.get(0);

                    switch (command) {
                    case CONNECT:
                        // add the session ID
                        websocketService.addSession(sessionId);
                        break;
                    case DISCONNECT:
                        // remove the session ID
                        websocketService.removeSession(sessionId);
                        break;
                    default:
                        break;
                    }
                }

                return message;
            }
        };
        registration.setInterceptors(interceptor);
    }

}

Javascript クライアント:

function(gst) {
    var url = '/pideweb-gijon/endpointpuisocket';
    var socket = new SockJS(url);
    var stompClient = Stomp.over(socket);
    var headers = {
        puiSessionId : gst
    };

    var self = this;
    stompClient.connect(headers, function(frame) {
        console.log('Connected: ' + frame);
        self.stompClient.subscribe('/user/' + gst + '/response', function(data) {
            console.log(data.body);
        });
    });
};

これにより、クライアントに入ると、自動的にサーバーに接続しようとします。私はChromeを使用しています。これはリクエストのスタックです:

情報リクエスト 情報リクエスト

Websocket リクエスト ウェブソケットリクエスト

XHR_ストリーミング リクエスト xhr_streaming リクエスト

Websocket リクエストで何が起こっているのか知っている人はいますか?

ありがとう!

于 2015-05-14T07:13:09.227 に答える
0

このためには、Tomcat コネクタを更新する必要があります。Tomcat ディレクトリ --> conf --> server.xml に移動します。以下の行を見つけます。

<Connector connectionTimeout="20000" maxThreads="1000" port="8080" protocol="org.apache.coyote.http1.1"/> 

似ているはずです。プロトコルに注意して、次のように変更します。

<Connector connectionTimeout="20000" maxThreads="1000" port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"/>

Tomcat を再起動します。

于 2015-05-12T09:55:12.203 に答える
0

@Marc Gil Sendraの同じ問題と解決策が私のために働いています。WebSocket プロトコル用に Apache から Proxypass を構成する必要があります。

ProxyPass /pideweb-gijon/endpointpuisocket/ ws://localhost:8080/pideweb_gijon/endpointpuisocket/

ProxyPassReverse /pideweb-gijon/endpointpuisocket/ ws://localhost:8080/pideweb_gijon/endpointpuisocket/

Bitnami EC2 (Apache + Tomcat) でテストしました。次のファイル構成として構成します: /opt/bitnami/apache-tomcat/conf/apache-tomcat-prefix.conf

<Location /AppContext/endpointpuisocket> ProxyPass ws://localhost:8080/AppContext/endpointpuisocket </Location>

于 2015-09-11T09:14:37.540 に答える