flash as3的socket连接服务器,安全策略问题(linux c)

        近日做flash客户端连接服务器代码,网上找了很多资料,都是和JAVA,或者windows下的c有关。由于我用的是linux嵌入式系统作为服务器端,所以就只能查资料,然后自己解决了。

(一)        flash部分代码:

        socket = new Socket(   );

socket.addEventListener(Event.CLOSE,closeHandler);
socket.addEventListener( Event.CONNECT, connectHandler );
socket.addEventListener( ProgressEvent.SOCKET_DATA, onSocketData );
socket.addEventListener(IOErrorEvent.IO_ERROR, connectError);
socket.addEventListener(SecurityErrorEvent.SECURITY_ERROR,securityErrorHandler);


Security.loadPolicyFile("xmlsocket://192.168.25.6:9221"); //不解释,很多资料都有

try {
trace( "正在连接服务器192.168.25.6。。。");
socket.connect( "192.168.25.6", 9221 );                       //此处的地址填写服务器ip,端口为服务器的监听端口
} catch (err:IOErrorEvent) {
trace("无法连接服务器");
}


说明:flash部分的代码为常规代码,并无特殊

(二) 服务器部分C代码
//bind,listen,accept等部分的代码略去,不解释

//以下为accept后,读取client端的请求消息

while(1) {
byteReceived = recv( clientsock, requestBuf, sizeof(requestBuf),MSG_NOSIGNAL);
if(byteReceived >0) {

requestBuf[byteReceived] = '\0';

//以下为重点

if(strcmp(requestBuf,"<policy-file-request\/>") == 0) {

char msg[8192];

sprintf(msg,"%s","<cross-domain-policy><allow-access-from domain=\"*\" to-ports=\"9221\" /></cross-domain-policy>\0");
 //主要是to-ports这个参数,需要为服务器socket监听的端口号

                         int sendlen = send(clientsock,msg,strlen(msg) + 1,0);  //clientsock为客户端请求安全策略文件的套接字。

                        //将策略文件内容发送给客户端,客户端即可获取安全策略文件内容,从而使客户端和服务端建立连接。

}

}

  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值