javax.websocket 클라이언트 단순 예시
웹소켓 클라이언트의 사용 예를 들어주세요.javax.websocket
?
웹 소켓(ws://socket.example.com:1234), 메시지 보내기(채널 추가)에 연결하여 메시지를 듣고 싶습니다.모든 메시지(송신 및 수신)는 JSON 형식입니다.
그리고 이 라이브러리는 단순한 웹 소켓 통신에 가장 적합한가요?
이 기능을 사용하는 좋은 예를 찾았습니다.javax.websocket
여기:
http://www.programmingforliving.com/2013/08/jsr-356-java-api-for-websocket-client-api.html
위에 링크된 예를 기반으로 한 코드입니다.
다음과 같습니다TestApp.java
.
package testapp;
import java.net.URI;
import java.net.URISyntaxException;
public class TestApp {
public static void main(String[] args) {
try {
// open websocket
final WebsocketClientEndpoint clientEndPoint = new WebsocketClientEndpoint(new URI("wss://real.okcoin.cn:10440/websocket/okcoinapi"));
// add listener
clientEndPoint.addMessageHandler(new WebsocketClientEndpoint.MessageHandler() {
public void handleMessage(String message) {
System.out.println(message);
}
});
// send message to websocket
clientEndPoint.sendMessage("{'event':'addChannel','channel':'ok_btccny_ticker'}");
// wait 5 seconds for messages from websocket
Thread.sleep(5000);
} catch (InterruptedException ex) {
System.err.println("InterruptedException exception: " + ex.getMessage());
} catch (URISyntaxException ex) {
System.err.println("URISyntaxException exception: " + ex.getMessage());
}
}
}
다음과 같습니다WebsocketClientEndpoint.java
.
package testapp;
import java.net.URI;
import javax.websocket.ClientEndpoint;
import javax.websocket.CloseReason;
import javax.websocket.ContainerProvider;
import javax.websocket.OnClose;
import javax.websocket.OnMessage;
import javax.websocket.OnOpen;
import javax.websocket.Session;
import javax.websocket.WebSocketContainer;
/**
* ChatServer Client
*
* @author Jiji_Sasidharan
*/
@ClientEndpoint
public class WebsocketClientEndpoint {
Session userSession = null;
private MessageHandler messageHandler;
public WebsocketClientEndpoint(URI endpointURI) {
try {
WebSocketContainer container = ContainerProvider.getWebSocketContainer();
container.connectToServer(this, endpointURI);
} catch (Exception e) {
throw new RuntimeException(e);
}
}
/**
* Callback hook for Connection open events.
*
* @param userSession the userSession which is opened.
*/
@OnOpen
public void onOpen(Session userSession) {
System.out.println("opening websocket");
this.userSession = userSession;
}
/**
* Callback hook for Connection close events.
*
* @param userSession the userSession which is getting closed.
* @param reason the reason for connection close
*/
@OnClose
public void onClose(Session userSession, CloseReason reason) {
System.out.println("closing websocket");
this.userSession = null;
}
/**
* Callback hook for Message Events. This method will be invoked when a client send a message.
*
* @param message The text message
*/
@OnMessage
public void onMessage(String message) {
if (this.messageHandler != null) {
this.messageHandler.handleMessage(message);
}
}
@OnMessage
public void onMessage(ByteBuffer bytes) {
System.out.println("Handle byte buffer");
}
/**
* register message handler
*
* @param msgHandler
*/
public void addMessageHandler(MessageHandler msgHandler) {
this.messageHandler = msgHandler;
}
/**
* Send a message.
*
* @param message
*/
public void sendMessage(String message) {
this.userSession.getAsyncRemote().sendText(message);
}
/**
* Message handler.
*
* @author Jiji_Sasidharan
*/
public static interface MessageHandler {
public void handleMessage(String message);
}
}
TooTallNate는 클라이언트 측 https://github.com/TooTallNate/Java-WebSocket이 단순합니다.
dist 폴더의 java_websocket.jar를 프로젝트에 추가합니다.
import org.java_websocket.client.WebSocketClient;
import org.java_websocket.drafts.Draft_10;
import org.java_websocket.handshake.ServerHandshake;
import org.json.JSONException;
import org.json.JSONObject;
WebSocketClient mWs = new WebSocketClient( new URI( "ws://socket.example.com:1234" ), new Draft_10() )
{
@Override
public void onMessage( String message ) {
JSONObject obj = new JSONObject(message);
String channel = obj.getString("channel");
}
@Override
public void onOpen( ServerHandshake handshake ) {
System.out.println( "opened connection" );
}
@Override
public void onClose( int code, String reason, boolean remote ) {
System.out.println( "closed connection" );
}
@Override
public void onError( Exception ex ) {
ex.printStackTrace();
}
};
//open websocket
mWs.connect();
JSONObject obj = new JSONObject();
obj.put("event", "addChannel");
obj.put("channel", "ok_btccny_ticker");
String message = obj.toString();
//send message
mWs.send(message);
// 및 웹 소켓을 닫습니다.
mWs.close();
Arun Gupta의 Java EE 7 예를 참조하십시오.
기써브에 갈랐어요.
주된
/**
* @author Arun Gupta
*/
public class Client {
final static CountDownLatch messageLatch = new CountDownLatch(1);
public static void main(String[] args) {
try {
WebSocketContainer container = ContainerProvider.getWebSocketContainer();
String uri = "ws://echo.websocket.org:80/";
System.out.println("Connecting to " + uri);
container.connectToServer(MyClientEndpoint.class, URI.create(uri));
messageLatch.await(100, TimeUnit.SECONDS);
} catch (DeploymentException | InterruptedException | IOException ex) {
Logger.getLogger(Client.class.getName()).log(Level.SEVERE, null, ex);
}
}
}
클라이언트 엔드 포인트
/**
* @author Arun Gupta
*/
@ClientEndpoint
public class MyClientEndpoint {
@OnOpen
public void onOpen(Session session) {
System.out.println("Connected to endpoint: " + session.getBasicRemote());
try {
String name = "Duke";
System.out.println("Sending message to endpoint: " + name);
session.getBasicRemote().sendText(name);
} catch (IOException ex) {
Logger.getLogger(MyClientEndpoint.class.getName()).log(Level.SEVERE, null, ex);
}
}
@OnMessage
public void processMessage(String message) {
System.out.println("Received message in client: " + message);
Client.messageLatch.countDown();
}
@OnError
public void processError(Throwable t) {
t.printStackTrace();
}
}
이 라이브러리 org.java_websocket 사용
먼저 그 라이브러리를 build.gradle로 Import해야 합니다.
repositories {
mavenCentral()
}
그런 다음 종속성으로 구현을 추가합니다{ }
implementation "org.java-websocket:Java-WebSocket:1.3.0"
그러면 이 코드를 사용할 수 있습니다.
액티비티에서 Websocket Client의 오브젝트를 선언하는 경우
private WebSocketClient mWebSocketClient;
콜백용으로 이 메서드를 추가합니다.
private void ConnectToWebSocket() {
URI uri;
try {
uri = new URI("ws://your web socket url");
} catch (URISyntaxException e) {
e.printStackTrace();
return;
}
mWebSocketClient = new WebSocketClient(uri) {
@Override
public void onOpen(ServerHandshake serverHandshake) {
Log.i("Websocket", "Opened");
mWebSocketClient.send("Hello from " + Build.MANUFACTURER + " " + Build.MODEL);
}
@Override
public void onMessage(String s) {
final String message = s;
runOnUiThread(new Runnable() {
@Override
public void run() {
TextView textView = (TextView)findViewById(R.id.edittext_chatbox);
textView.setText(textView.getText() + "\n" + message);
}
});
}
@Override
public void onClose(int i, String s, boolean b) {
Log.i("Websocket", "Closed " + s);
}
@Override
public void onError(Exception e) {
Log.i("Websocket", "Error " + e.getMessage());
}
};
mWebSocketClient.connect();
}
프로젝트에는 Spring 4.2가 있으며 SockJS Stomp의 많은 구현은 보통 Spring Boot 구현과 잘 연동됩니다.이 백둥의 구현은 (스프링 4.2에서 5로 변경하지 않고) 효과가 있었습니다.블로그에 기재되어 있는 의존관계를 사용한 후에도 Class Not Found Error가 표시되었습니다.저는 그것을 수정하기 위해 아래의 종속성을 추가했습니다.
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>4.2.3.RELEASE</version>
</dependency>
언급URL : https://stackoverflow.com/questions/26452903/javax-websocket-client-simple-example
'programing' 카테고리의 다른 글
stdint.h와 inttypes.h의 차이점 (0) | 2022.12.10 |
---|---|
암호의 정규식에는 최소 8자(숫자 하나 이상)와 소문자, 대문자 및 특수 문자를 모두 포함해야 합니다. (0) | 2022.12.10 |
값을 기준으로 다차원 어레이를 정렬하는 방법 (0) | 2022.12.10 |
ERROR 1054 (42S22):'필드 리스트'의 알 수 없는 열 ' ' (0) | 2022.12.10 |
mysqldump 명령줄 유틸리티를 사용하여 mysql 데이터베이스를 완전히 백업하는 방법 (0) | 2022.12.10 |