Heim > Java > javaLernprogramm > Java Websocket-Entwicklungspraxis: Lösung von domänenübergreifenden Zugriffsproblemen

Java Websocket-Entwicklungspraxis: Lösung von domänenübergreifenden Zugriffsproblemen

王林
Freigeben: 2023-12-02 10:17:31
Original
1602 Leute haben es durchsucht

Java Websocket开发实战:解决跨域访问问题

Java Websocket-Entwicklungspraxis: Lösung von domänenübergreifenden Zugriffsproblemen

Mit der Weiterentwicklung von Internetanwendungen steigt auch die Nachfrage der Menschen nach Echtzeitkommunikation und Datenübertragung. Websocket ist ein neues Protokoll, das Echtzeitkommunikation und bidirektionale Datenübertragung unterstützt. Als leistungsstarke Programmiersprache bietet Java auch Unterstützung für die WebSocket-API. In diesem Artikel stellen wir vor, wie Sie mit Java Websocket eine Technologie implementieren, die domänenübergreifende Zugriffsprobleme löst, und stellen einige spezifische Codebeispiele bereit.

  1. Problem beim domänenübergreifenden Zugriff

Bei der Websocket-Kommunikation treten aufgrund von Browsereinschränkungen beim domänenübergreifenden Zugriff Probleme mit dem domänenübergreifenden Zugriff auf, wenn sich Client und Server unter unterschiedlichen Domänennamen befinden. In diesem Fall kann der Client ohne spezielle Verarbeitung keine Daten normal vom Server empfangen. Daher müssen wir das Problem des domänenübergreifenden Zugriffs mit technischen Mitteln lösen.

  1. Verwenden Sie Java Websocket, um domänenübergreifende Zugriffsprobleme zu lösen

Java Websocket bietet einige flexible APIs, die durch Konfiguration einen domänenübergreifenden Zugriff erreichen können. Bei der Verwendung von Java Websocket müssen wir auf folgende Punkte achten:

2.1 Konfigurieren Sie den Parameter „allowOrigin“ des Websocket-Servers.

Der Parameter „allowOrigin“ wird verwendet, um eine Liste von Domänennamen anzugeben, die einen domänenübergreifenden Zugriff ermöglichen. Wir können den Parameter „allowOrigin“ über den folgenden Code konfigurieren:

// 创建一个WebSocketServer对象
WebSocketServer server = new WebSocketServer(new InetSocketAddress(8080)){

  // 重写onOpen方法
  @Override
  public void onOpen(WebSocket conn, ClientHandshake handshake) {
      // 设置allowOrigin参数
      conn.setAttachment("allowOrigin", "*");
  }

  // ...
};
Nach dem Login kopieren

Der obige Code legt den Parameter „allowOrigin“ als Platzhalter fest, was bedeutet, dass alle Domänennamen für den domänenübergreifenden Zugriff zugelassen sind. Wenn Sie domänenübergreifende Anfragen einschränken möchten, können Sie den Parameter „allowOrigin“ auf einen angegebenen Domänennamen oder eine bestimmte IP-Adresse festlegen.

2.2 Legen Sie den Ursprungsparameter im Websocket-Client fest

Im Websocket-Client können wir domänenübergreifende Anforderungen implementieren, indem wir den Ursprungsparameter festlegen. Der folgende Code zeigt, wie der Ursprungsparameter im Websocket-Client festgelegt wird:

var ws = new WebSocket('ws://example.com:8080/');
ws.onopen = function(event){
  // 设置origin参数
  ws.send('Hello, World!', {'origin': 'http://example.com'});
};
Nach dem Login kopieren

Im obigen Code legen wir den Ursprungsparameter beim Senden der Nachricht fest und geben damit an, dass die Nachricht von http://example.com stammt. Auf diese Weise kann ein domänenübergreifender Zugriff erreicht werden.

  1. Vollständiges Java-Websocket-Beispiel

Im Folgenden finden Sie ein vollständiges Java-Websocket-Beispiel, das die Konfiguration des domänenübergreifenden Zugriffs umfasst. In diesem Beispiel erstellen wir ein WebSocketServer-Objekt und legen den Parameter „allowOrigin“ in der Methode „onOpen“ fest. Der Client sendet eine Nachricht, indem er die Sendemethode von WebSocket aufruft und beim Senden den Ursprungsparameter festlegt.

import java.net.InetSocketAddress;
import org.java_websocket.WebSocket;
import org.java_websocket.handshake.ClientHandshake;
import org.java_websocket.server.WebSocketServer;

public class MyWebSocketServer extends WebSocketServer{

    public MyWebSocketServer(InetSocketAddress address){
        super(address);
    }

    @Override
    public void onOpen(WebSocket conn, ClientHandshake handshake){
        // 设置allowOrigin参数
        conn.setAttachment("allowOrigin", "*");
    }

    @Override
    public void onClose(WebSocket conn, int code, String reason, boolean remote){}

    @Override
    public void onMessage(WebSocket conn, String message){
        // 接收到消息
        System.out.println("Received Message: " + message);
    }

    @Override
    public void onError(WebSocket conn, Exception ex){
        // 处理错误
        ex.printStackTrace();
    }

    public static void main(String[] args){
        MyWebSocketServer server = new MyWebSocketServer(new InetSocketAddress(8080));
        server.start();
        System.out.println("WebSocketServer started on port: " + server.getPort());
    }

}
Nach dem Login kopieren

Im Client verwenden wir JavaScript, um ein WebSocket-Objekt zu erstellen und den Ursprungsparameter festzulegen, wenn wir die Sendemethode aufrufen, um eine Nachricht zu senden. Das Folgende ist der Client-Beispielcode:

var ws = new WebSocket('ws://example.com:8080/');
ws.onopen = function(event){
    // 设置origin参数
    ws.send('Hello, World!', {'origin': 'http://example.com'});
};
Nach dem Login kopieren

Anhand dieses Java-Websocket-Beispiels können wir sehen, wie der Parameter „allowOrigin“ in WebSocketServer konfiguriert und der Parameter „origin“ in WebSocket mithilfe von JavaScript festgelegt wird. Diese technischen Mittel können uns helfen, domänenübergreifende Zugriffsprobleme zu lösen und eine effiziente und sichere Websocket-Kommunikation zu erreichen.

Das obige ist der detaillierte Inhalt vonJava Websocket-Entwicklungspraxis: Lösung von domänenübergreifenden Zugriffsproblemen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage