gpt4 book ai didi

apache-flex - 如何实现 HTTP 隧道

转载 作者:可可西里 更新时间:2023-11-01 16:29:22 24 4
gpt4 key购买 nike

我编写了一个连接到后端服务器以交换数据的 Flash (Flex) 客户端。

我也从头开始编写我的服务器,它有两个目的:

(1) Web (HTTP) 服务器- 默认监听端口 80

(2) Socket/Application- Server - 默认监听端口 443

仅供引用,为方便起见,两个服务器都在同一进程空间中运行。他们预计不会处理大量负载,所以我对此没有意见。

一旦从 HTTP 套接字向浏览器提供 Flash 客户端服务,客户端就会尝试打开到套接字/应用程序服务器的 XMLSocket。

我现在想实现 HTTP 隧道,这样即使用户在防火墙后面,我的客户端也可以连接到应用程序服务器。我不想涉及任何外部服务器(代理等)- 只需使用我已有的服务器即可。

我的问题:

(1) 使用端口 443 是否更好? (它能更好地愚弄防火墙吗?)

(2) 据我所知,我需要做的只是确保我的实际应用程序数据被简单地封装在来自客户端和服务器的 HTTP 结构中(前面是一个虚拟 HTTP header )双方。是这样还是我在这里遗漏了什么?

(3) 我是否需要在通过套接字发送的每条消息中继续隐藏/封装我的数据,还是可以在打开连接时只封装第一条消息?

先谢谢大家了!模糊

最佳答案

不要重新发明轮子 - 通过 AMF 协议(protocol)使用远程处理。 AMF 是一种基于 HTTP 的二进制格式,可在 ActionScript (MXML) 和服务器端语言之间执行序列化。从技术上讲,这是 HTTP 隧道。Adobe 为 AS/Java 提供了 AMF 的 BlazeDS(开源)和 LCDS(商业)实现,但也有用于 AS/PHP、AS/Python、AS/Ruby、AS/.Net 的第三方 AMF 实现。

顺便说一句,AMF 是一种开源格式。

关于apache-flex - 如何实现 HTTP 隧道,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1184521/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com