Ich entwickle WebSocket Server mit Netty Frame Arbeit Version 4.1.6. ich von netty example site den Beispielcode verwenden Dieser mein Server-Quellcode:sichere Websocket Verbindung zwischen Javascript Client und Netty Server
public class WebSocketServer
{
static final int PORT = 4466;
public static void main(String[] args)
{
final SslContext sslCtx;
EventLoopGroup bossGroup = new NioEventLoopGroup(1);
EventLoopGroup workerGroup = new NioEventLoopGroup();
try {
SelfSignedCertificate ssc = new SelfSignedCertificate();
sslCtx = SslContextBuilder.forServer(ssc.certificate(), ssc.privateKey()).build();
ServerBootstrap b = new ServerBootstrap();
b.group(bossGroup, workerGroup)
.channel(NioServerSocketChannel.class)
.handler(new LoggingHandler(LogLevel.INFO))
.childHandler(new WebSocketServerInitializer(sslCtx));
Channel ch = b.bind(PORT).sync().channel();
System.out.println("Open your web browser and navigate to " +
"http://127.0.0.1:" + PORT + '/');
ch.closeFuture().sync();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
bossGroup.shutdownGracefully();
workerGroup.shutdownGracefully();
}
}
}
Einen WebSocketServerInitializer Quellcode:
public class WebSocketServerInitializer extends ChannelInitializer<SocketChannel>
{
private static final String WEBSOCKET_PATH = "/websocket";
private final SslContext sslCtx;
public WebSocketServerInitializer(SslContext sslCtx) {
this.sslCtx = sslCtx;
}
@Override
public void initChannel(SocketChannel ch) throws Exception {
ChannelPipeline pipeline = ch.pipeline();
pipeline.addLast(sslCtx.newHandler(ch.alloc()));
pipeline.addLast(new HttpServerCodec());
pipeline.addLast(new HttpObjectAggregator(65536));
pipeline.addLast(new WebSocketServerCompressionHandler());
pipeline.addLast(new WebSocketServerProtocolHandler(WEBSOCKET_PATH, null, true));
// pipeline.addLast(new WebSocketIndexPageHandler(WEBSOCKET_PATH));
pipeline.addLast(new WebSocketFrameHandler());
}
}
Das ist mein HTML-Code:
<html>
<head>
<script type="text/javascript">
// Let us open a web socket
var ws = null;
function WebSocketTest()
{
if ("WebSocket" in window)
{
alert("WebSocket is supported by your Browser!");
// Let us open a web socket
ws = new WebSocket("wss://localhost:4466/websocket");
ws.onopen = function()
{
// Web Socket is connected, send data using send()
ws.send("Message to send");
alert("Message is sent...");
};
ws.onmessage = function (evt)
{
var received_msg = evt.data;
alert(received_msg);
//alert("Message is received...");
};
ws.onclose = function()
{
// websocket is closed.
alert("Connection is closed...");
};
window.onbeforeunload = function(event) {
socket.close();
};
}
else
{
// The browser doesn't support WebSocket
alert("WebSocket NOT supported by your Browser!");
}
}
</script>
</head>
<body>
<div id="sse">
<a href="javascript:WebSocketTest()">Run WebSocket</a>
</div>
</body>
</html>
I Durchsuchen Sie die Seite mit dem Chrome-Browser und erhalten Sie die folgende Meldung, wenn ich auf den Link auf der Webseite klicke.
WebSocket-Verbindung zu 'WSS: // localhost: 4466/websocket' ist fehlgeschlagen: Fehler beim Verbindungsaufbau: net :: ERR_INSECURE_RESPONSE
Nach einigen Diskussionen hier, und der netty websocket Beispielcode, wss muss von HTTPS weitergeleitet werden. Allerdings, wenn ich die folgende JavaScript-Anweisung in meiner Web-Seite ändern:
ws = new WebSocket("wss://localhost:4466/websocket");
zu
ws = new WebSocket("wss://echo.websocket.org");
Es funktioniert gut. Es macht mich verwirrend, warum die Seite echo.websocket.org ohne https funktionieren kann? Warum kann mein Server nicht? fehlt etwas in meinem Serverquellcode?
PS: das echo.websocket.org Beispiel in der folgenden URL gefunden:
http://jsbin.com/muqamiqimu/edit?js,console
danke für Ihre Erklärung. –