为 Flash 开启 843 端口
Flash 发起 socket 连接远程服务端时,首先会到对应服务端的 843 端口请求一个安全策略文件。否则 Flash 无法建立与服务端的连接。在 Workerman 中可以用如下方法开启一个 843 端口,返回安全策略文件。
php
<?php
use Workerman\Worker;
use Workerman\Connection\TcpConnection;
require_once __DIR__ . '/vendor/autoload.php';
$flash_policy = new Worker('tcp://0.0.0.0:843');
$flash_policy->onMessage = function(TcpConnection $connection, $message)
{
$connection->send('<?xml version="1.0"?><cross-domain-policy><site-control permitted-cross-domain-policies="all"/><allow-access-from domain="*" to-ports="*"/></cross-domain-policy>'."\0");
};
if(!defined('GLOBAL_START'))
{
Worker::runAll();
}
其中 xml 的安全策略内容可以根据你的需要进行自定义设置。