我编写了一个连接到后端服务器以交换数据的 Flash (Flex) 客户端。
我还从头开始编写了我的服务器,它有两个目的:
(1) Web (HTTP) 服务器 - 默认情况下监听端口 80
(2) 套接字/应用程序服务器 - 默认监听端口 443
仅供引用,出于方便原因,两个服务器都在同一进程空间中运行。他们预计不会处理大量负载,所以我对此很满意。
一旦 Flash 客户端从 HTTP 套接字提供给浏览器,客户端就会尝试打开到套接字/应用程序服务器的 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/