[SPRING] 스프링 웹 소켓 데모를 실행할 수 없음
SPRING스프링 웹 소켓 데모를 실행할 수 없음
스프링 웹 소켓의 데모를 실행하려고하지만 완전히 테스트 할 수는 없습니다. 자바 7과 톰캣 7.0.50을 사용하고 있습니다. 서버를 시작하는 동안 오류가 발생하지 않지만 js에서 연결을 만드는 웹 페이지를 열면 404 페이지를 찾을 수 없습니다. 구성을 실행하기 위해 무엇인가 놓치고 있는지, 그리고 js 측면에서 어떻게 연결할 수 있는지 확실하지 않습니다.
나는 다음과 같은 XML 파일을 가지고있다 :
<beans ....>
<context:annotation-config />
<websocket:message-broker
application-destination-prefix="/app">
<websocket:stomp-endpoint path="/hello">
<websocket:sockjs />
</websocket:stomp-endpoint>
<websocket:simple-broker prefix="/topic" />
</websocket:message-broker>
</beans>
내 컨트롤러 클래스는 다음과 같습니다.
@Controller
public class SwsService {
@MessageMapping("/hello")
@SendTo("/topic/greetings")
public Greeting greeting(HelloMessage message) throws Exception {
return new Greeting("Hello, " + message.getName() + "!");
}
public String getGreeting() {
return "Hello, you are in!";
}
}
내가 이것을 부르는 js는 :
var sock = new SockJS("/hello");
sock.onopen = function () {
console.log("open");
};
sock.onclose = function () {
console.log("closed");
};
sock.onmessage = function (message) {
console.log("msg", message);
};
바람둥이를 실행할 때 콘솔 출력 :
Feb 19, 2014 3:28:47 PM org.apache.catalina.core.AprLifecycleListener init
INFO: The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: C:\Program Files\Java\jre7\bin;C:\Windows\Sun\Java\bin;C:\Windows\system32;C:\Windows;C:/Program Files/Java/jre6/bin/client;C:/Program Files/Java/jre6/bin;C:/Program Files/Java/jre6/lib/i386;C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Windows\System32\WindowsPowerShell\v1.0\;C:\Program Files\Intel\OpenCL SDK\2.0\bin\x86;C:\Program Files\TortoiseGit\bin;C:\Python24;C:\Program Files\TortoiseSVN\bin;C:\Program Files\nodejs\;C:\Program Files\Git\cmd;C:\Users\harsh\AppData\Roaming\npm;E:\IDE\eclipse_indigo;;.
Feb 19, 2014 3:28:47 PM org.apache.tomcat.util.digester.SetPropertiesRule begin
WARNING: [SetPropertiesRule]{Server/Service/Engine/Host/Context} Setting property 'source' to 'org.eclipse.jst.jee.server:SWS' did not find a matching property.
Feb 19, 2014 3:28:48 PM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler ["http-bio-8080"]
Feb 19, 2014 3:28:48 PM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler ["ajp-bio-8009"]
Feb 19, 2014 3:28:48 PM org.apache.catalina.startup.Catalina load
INFO: Initialization processed in 1412 ms
Feb 19, 2014 3:28:48 PM org.apache.catalina.core.StandardService startInternal
INFO: Starting service Catalina
Feb 19, 2014 3:28:48 PM org.apache.catalina.core.StandardEngine startInternal
INFO: Starting Servlet Engine: Apache Tomcat/7.0.50
Feb 19, 2014 3:28:51 PM org.apache.catalina.core.ApplicationContext log
INFO: No Spring WebApplicationInitializer types detected on classpath
Feb 19, 2014 3:28:51 PM org.apache.catalina.core.ApplicationContext log
INFO: Initializing Spring root WebApplicationContext
Feb 19, 2014 3:28:51 PM org.springframework.web.context.ContextLoader initWebApplicationContext
INFO: Root WebApplicationContext: initialization started
Feb 19, 2014 3:28:51 PM org.springframework.context.support.AbstractApplicationContext prepareRefresh
INFO: Refreshing Root WebApplicationContext: startup date [Wed Feb 19 15:28:51 IST 2014]; root of context hierarchy
Feb 19, 2014 3:28:52 PM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
INFO: Loading XML bean definitions from ServletContext resource [/WEB-INF/classes/conf/SwsContext.xml]
Feb 19, 2014 3:28:53 PM org.springframework.scheduling.concurrent.ExecutorConfigurationSupport initialize
INFO: Initializing ExecutorService 'clientInboundChannelExecutor'
Feb 19, 2014 3:28:53 PM org.springframework.scheduling.concurrent.ExecutorConfigurationSupport initialize
INFO: Initializing ExecutorService 'clientOutboundChannelExecutor'
Feb 19, 2014 3:28:53 PM org.springframework.scheduling.concurrent.ExecutorConfigurationSupport initialize
INFO: Initializing ExecutorService 'messageBrokerSockJsScheduler'
Feb 19, 2014 3:28:53 PM org.springframework.web.servlet.handler.AbstractUrlHandlerMapping registerHandler
INFO: Mapped URL path [/hello/**] onto handler of type [class org.springframework.web.socket.sockjs.support.SockJsHttpRequestHandler]
Feb 19, 2014 3:28:53 PM org.springframework.context.support.DefaultLifecycleProcessor$LifecycleGroup start
INFO: Starting beans in phase 2147483647
Feb 19, 2014 3:28:53 PM org.springframework.web.context.ContextLoader initWebApplicationContext
INFO: Root WebApplicationContext: initialization completed in 2173 ms
Feb 19, 2014 3:28:53 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["http-bio-8080"]
Feb 19, 2014 3:28:53 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["ajp-bio-8009"]
Feb 19, 2014 3:28:53 PM org.apache.catalina.startup.Catalina start
INFO: Server startup in 5842 ms
브라우저 콘솔 출력 :
GET http://localhost:8080/hello/info 404 (Not Found) sockjs-0.3.min.js:27
closed
어떻게 성공적으로 테스트 할 수 있습니까?
업데이트
또한 여기에서 포트폴리오 예제를 실행 해 보았습니다. https://github.com/rstoyanchev/spring-websocket-portfolio @jhadesdev에서 제안했습니다.
그러나 또한 도움이되지 않습니다. mvn tomcat7 : run을 실행하면 다음과 같은 결과가 표시되고 브라우저의 url에 404가 표시됩니다.
[INFO] Scanning for projects...
[INFO]
[INFO] Using the builder org.apache.maven.lifecycle.internal.builder.singlethrea
ded.SingleThreadedBuilder with a thread count of 1
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building spring-websocket-portfolio 1.0.0-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO]
[INFO] >>> tomcat7-maven-plugin:2.2:run (default-cli) @ spring-websocket-portfol
io >>>
[INFO]
[INFO] --- maven-resources-plugin:2.5:resources (default-resources) @ spring-web
socket-portfolio ---
[debug] execute contextualize
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] skip non existing resourceDirectory E:\libraries\spring-websocket-portfol
io\src\main\resources
[INFO]
[INFO] --- maven-compiler-plugin:2.3.2:compile (default-compile) @ spring-websoc
ket-portfolio ---
[INFO] No sources to compile
[INFO]
[INFO] <<< tomcat7-maven-plugin:2.2:run (default-cli) @ spring-websocket-portfol
io <<<
[INFO]
[INFO] --- tomcat7-maven-plugin:2.2:run (default-cli) @ spring-websocket-portfol
io ---
[INFO] Running war on http://localhost:8080/spring-websocket-portfolio
[INFO] Using existing Tomcat server configuration at E:\libraries\spring-websock
et-portfolio\target\tomcat
[INFO] create webapp with contextPath: /spring-websocket-portfolio
Feb 27, 2014 10:20:46 AM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler ["http-bio-8080"]
Feb 27, 2014 10:20:46 AM org.apache.catalina.core.StandardService startInternal
INFO: Starting service Tomcat
Feb 27, 2014 10:20:46 AM org.apache.catalina.core.StandardEngine startInternal
INFO: Starting Servlet Engine: Apache Tomcat/7.0.47
Feb 27, 2014 10:20:49 AM org.apache.catalina.core.ApplicationContext log
INFO: No Spring WebApplicationInitializer types detected on classpath
Feb 27, 2014 10:20:49 AM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["http-bio-8080"]
그것은 거기 붙어서 앞으로 나아 가지 않습니다.
해결법
-
==============================
1.나는 똑같은 문제에 직면했다. 이 스레드는 문제 해결을위한 충분한 단서를 제공했습니다. 고마워.
나는 똑같은 문제에 직면했다. 이 스레드는 문제 해결을위한 충분한 단서를 제공했습니다. 고마워.
해결책: web.xml에 Spring MVC Dispatcher 서블릿이 설정되어 있고 아래 그림과 같이 url 패턴으로 매핑되어있는 경우
<servlet-mapping> <servlet-name>dispatcher</servlet-name> <url-pattern>/webui/*</url-pattern> </servlet-mapping>
그런 다음 아래와 같이 SockJS 인스턴스를 만들어야합니다.
var socket = new SockJS('/contextPath/webui/hello');
참고 : contextPath를 응용 프로그램 컨텍스트 경로로 바꾸십시오.
-
==============================
2.모든 stomp 및 sockjs.js 파일을 사용할 수 있도록 webapp 내에 assets 폴더를 추가하십시오. mvn clean install jetty : run과 함께 실행될 수있는이 실행중인 응용 프로그램 예제를 살펴보십시오.
모든 stomp 및 sockjs.js 파일을 사용할 수 있도록 webapp 내에 assets 폴더를 추가하십시오. mvn clean install jetty : run과 함께 실행될 수있는이 실행중인 응용 프로그램 예제를 살펴보십시오.
문제는 sockjs가 서버에 없거나 경로가 잘못되었다는 것입니다. 링크의 예제를 기반으로 stomp 끝점을 다음과 같이 구성 할 수 있습니다.
@EnableWebSocketMessageBroker public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer { @Override public void registerStompEndpoints(StompEndpointRegistry registry) { registry.addEndpoint("/portfolio").withSockJS(); } }
자바 스크립트에서 다음과 같이 끝점을 호출 할 수 있습니다.
var socket = new SockJS('/spring-websocket-portfolio/portfolio') var stompClient = Stomp.over(socket);
여기서 / spring-websocket-portfolio는 응용 프로그램의 루트 배포 경로입니다.
-
==============================
3.이 Chrome 확장 프로그램은 웹 소켓 테스트에 도움이됩니다.
이 Chrome 확장 프로그램은 웹 소켓 테스트에 도움이됩니다.
또한 웹 부트를 사용하는 간단한 채팅 프로젝트를 살펴볼 수도 있습니다.
-
==============================
4.귀하의 응용 프로그램이 좋아 보인다.
귀하의 응용 프로그램이 좋아 보인다.
언급 된 jhadesdev처럼, 자바 스크립트 요청에 응용 프로그램의 루트 컨텍스트를 반드시 추가해야합니다.
응용 프로그램이 추가 필터를 등록하거나 messageconverters를 사용자 정의합니까? 다른 구성 요소가 여기에 간섭하는 것일 수 있습니다.
최신 포트폴리오 예제가 확실히 작동해야합니다. 다음은 몇 가지 질문입니다.
-
==============================
5.DispatcherServlet은 어떻게 매핑됩니까? 여기 당신이 찾고있는 것일 수도 있습니다.
DispatcherServlet은 어떻게 매핑됩니까? 여기 당신이 찾고있는 것일 수도 있습니다.
from https://stackoverflow.com/questions/21877373/not-able-to-run-spring-web-socket-demo by cc-by-sa and MIT license
'SPRING' 카테고리의 다른 글
[SPRING] 스프링 부트 프로젝트에서 CSS와 같은 정적 파일을 어디에 둘까요? (0) | 2019.04.15 |
---|---|
[SPRING] @Configuration 클래스의 주석으로 구동되는 트랜잭션 설정하기 (0) | 2019.04.15 |
[SPRING] @ExceptionHandler에서 @RequestBody를 얻는 방법 (Spring REST) (0) | 2019.04.15 |
[SPRING] Spring에서 'Rejected bean name - URL 경로가 식별되지 않음'을 처리하는 방법? (0) | 2019.04.15 |
[SPRING] 알 수없는 속성에서 PUT 및 POST가 실패 함 Spring 다른 동작 (0) | 2019.04.15 |