内容简介:Firefly 4.7.0 增加了新的 WebSocket APIs,改进了 HTTP 2 编解码器的性能,并修复了一些 bug。 新的 WebSocket APIs 例如: public static void main(String[] args) { SimpleWebSocketServer s...
Firefly 4.7.0 增加了新的 WebSocket APIs,改进了 HTTP 2 编解码器的性能,并修复了一些 bug。
新的 WebSocket APIs 例如:
public static void main(String[] args) { SimpleWebSocketServer server = $.createWebSocketServer(); server.webSocket("/helloWebSocket") .onConnect(conn -> conn.sendText("OK.")) .onText((text, conn) -> System.out.println("The server received: " + text)) .listen("localhost", 8080); SimpleWebSocketClient client = $.createWebSocketClient(); client.webSocket("ws://localhost:8080/helloWebSocket") .onText((text, conn) -> System.out.println("The client received: " + text)) .connect() .thenAccept(conn -> conn.sendText("Hello server.")); }
也增加了 Kotlin DSL 版 APIs,例如:
fun main(args: Array<String>) { val scheduler = Schedulers.createScheduler() val p = Paths.get(HttpServer::class.java.getResource("/").toURI()) HttpServer { router { httpMethod = HttpMethod.GET paths = listOf("/favicon.ico", "/static/*") handler(StaticFileHandler(p.toAbsolutePath().toString())) } router { httpMethod = HttpMethod.GET path = "/" asyncHandler { renderTemplate("template/websocket/index.mustache") } } webSocket("/helloWebSocket") { onConnect { val future = scheduler.scheduleAtFixedRate( { it.sendText("Current time: " + Date()) }, 0, 1, TimeUnit.SECONDS) it.onClose { future.cancel() } } onText { text, _ -> println("Server received: " + text) } } }.listen("localhost", 8080) }
这个例子中 WebSocket 服务和 HTTP 服务公用一个端口。
更多详情请参考 WebSocket 文档
更新日志:
增加新的 WebSocket DSL APIs。
优化 HTTP 2 编解码性能。
修复了 HTTP1 Upgrade 机制时效的问题。
修复了 TCP Session 在并发调用 close 和 write 方法的情况下有可能无法正确关闭的问题。
【声明】文章转载自:开源中国社区 [http://www.oschina.net]
以上所述就是小编给大家介绍的《Firefly 4.7.0 正式版发布,增加新的 WebSocket APIs》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- JavaBaas 2.0.0 正式版发布:增加数据原子操作
- Firefly 4.8.1 正式版发布,增加 MDC 实现
- UCKeFu 4.0.0 正式版发布,增加集群和企业知识管理系统
- LNMP 一键安装包 V1.5 正式版发布,增加 PHP 7.2 支持
- React 17 正式版发布
- Eclipse 4.9 正式版发布!
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。