flex安全沙箱 java_Flex Socket 安全沙箱问题解决

Flex使用Socket与C++通讯时遇到了安全沙箱问题,NND,折腾我半天,这是我的解决方法:

1):策略文件与主套接字在同一端口,只需调用 Socket.connect() 或 XMLSocket.connect() 方法;

2):策略文件与主套接字在不同端口,需使用特殊的“xmlsocket”语法调用 Security.loadPolicyFile() 方法,如下所示:Security.loadPolicyFile("xmlsocket://server.com:2525");先调用 Security.loadPolicyFile() 方法,然后再调用

Socket.connect() 或 XMLSocket.connect() 方法。

服务器端代码如下:

#include

#include

#include

using namespace std;

#pragma comment(lib,"ws2_32.lib")

void main()

{

WORD wVersionRequested;

WSADATA wsaData;

int err;

short port=1800;//端口号

wVersionRequested = MAKEWORD( 1, 1 );

err = WSAStartup( wVersionRequested, &wsaData );//初始化套接字

if ( err != 0 )

{

return;

}

if ( LOBYTE( wsaData.wVersion ) != 1 || HIBYTE( wsaData.wVersion ) != 1 )

{

WSACleanup( );

return;

}

SOCKET sockSrv=socket(AF_INET,SOCK_STREAM,0);//创建套接字

SOCKET sockConn;//用来和客户端通信的套接字

SOCKADDR_IN addrSrv;//用来和客户端通信的套接字地址

addrSrv.sin_addr.S_un.S_addr=htonl(INADDR_ANY);

addrSrv.sin_family=AF_INET;

addrSrv.sin_port=htons(port);

bind(sockSrv,(SOCKADDR*)&addrSrv,sizeof(SOCKADDR));//绑定端口

listen(sockSrv,5);//侦听

printf("Server %d is listening....../n",port);

SOCKADDR_IN addrClient;

int len=sizeof(SOCKADDR);

char buf[4096];//接收的数据

char rbuf[100]=

" "

""

" ";//套接字策略文件

while(1)

{

//接受连接

sockConn=accept(sockSrv,(SOCKADDR*)&addrClient,&len);

printf("Accept connection from %s/n",inet_ntoa(addrClient.sin_addr));

recv:

//接收数据

int bytes;

if((bytes=recv(sockConn,buf,sizeof(buf),0))==SOCKET_ERROR)

{

printf("接收数据失败!/n");

exit(-1);

}

buf[bytes]=‘/0‘;

printf("Message from %s: %s/n",inet_ntoa(addrClient.sin_addr),buf);

if (0 == strcmp(buf,""))

{

//发送数据

if(send(sockConn,rbuf,strlen(rbuf)+1,0)==SOCKET_ERROR)

{

printf("发送数据失败!");

exit(-1);

}

printf("Message to %s: %s/n",inet_ntoa(addrClient.sin_addr),rbuf);

}

else

{

//Echo

if(send(sockConn,buf,strlen(buf)+1,0)==SOCKET_ERROR)

{

printf("发送数据失败!");

exit(-1);

}

printf("Message to %s: %s/n",inet_ntoa(addrClient.sin_addr),buf);

goto recv;

}

//清理套接字占用的资源

closesocket(sockConn);

}

}

原文:http://www.cnblogs.com/fuland/p/3854352.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值