flex与C# Socket通信

原文地址:http://blog.csdn.net/LX10752p/archive/2011/04/27/6366526.aspx

Socket 通信没什么好说,一个服务端,多个客户端,很容易搭建环境,网上代码一大片,这里主要的问题是as进行socket通信,必须跨A域B域,这时问题出现了,flash player会阻止你跨域访问,这时,flash player会自动检查安全策略。

在Adobe Flash Player升级到9.0.124后,由于安全策略的更改,使得在socket或xmlsocket的应用里,原先如用http方式加载安全策略的手段不能继续使用了,类似此类应用必须使用xmlsocket:

flashplayer的安全策略检测过程如下:

1,首先检测目标服务器的843端口是否提供安全策略

2,如果843端口没有检测到策略,则检测actionscript是否使用了

Security.loadPolicyFile(xmlsocket:ip:端口)//使用其他特定端口提供安全策略

3,检测目标服务器目标端口是否提供安全策略

C#利用socket提供安全策略,我们可以通过多种方式实现,如Window应用窗台,控制台应用程序,或者打包成服务等等

下面以控制台为例子

view plaincopy to clipboardprint?using System;  using System.Collections.Generic;  using System.Linq;  using System.Text;  using System.Net;  using System.Net.Sockets;  using System.Threading;  using System.Collections;   namespace serverSocket  {      class Program      {          private Thread Beginthread, receivethread;          private Socket serverSocket, ClientSocket;          //主程序          static void Main(string[] args)          {              Program program = new Program();              IPEndPoint remotePoint = new IPEndPoint(IPAddress.Any, 843);// 可以尝试 Security.loadPolicyFile(xmlsocket:ip:端口),使用其他的端口              program.serverSocket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);              program.serverSocket.Bind(remotePoint);              program.serverSocket.Listen(10);              Console.WriteLine("Listening...");              program.Beginthread = new Thread(new ThreadStart(program.BeginListen));              program.Beginthread.Start();          }          //循环监听          private void BeginListen()          {              while (true)              {                  ClientSocket = serverSocket.Accept();                  receivethread = new Thread(new ThreadStart(receive));                  receivethread.Start();              }          }          //等待客户端请求 <policy-file-request/>          private void receive()          {              IPEndPoint clienTep = (IPEndPoint)ClientSocket.RemoteEndPoint;              int bytes = 0;              while (true)              {                  Byte[] buffer = new Byte[24];                  bytes = ClientSocket.Receive(buffer);                  if (bytes > 0)                  {                      string clientCommand = Encoding.UTF8.GetString(buffer, 0, bytes);                      String policy = "<cross-domain-policy><allow-access-from domain=\"*\" to-ports=\"1111\" /></cross-domain-policy>\0";                      buffer = System.Text.Encoding.UTF8.GetBytes(policy.ToCharArray());                      ClientSocket.Send(buffer, buffer.Length, 0);                  }                  else                  {                      break;                  }              }              ClientSocket.Close();              receivethread.Abort();          }      }  }   
as socket程序更简单如下view plaincopy to clipboardprint?package Socket  {      import flash.events.Event;      import flash.events.IOErrorEvent;      import flash.events.ProgressEvent;      import flash.net.Socket;      import flash.utils.ByteArray;            public class SPSocket      {          /**          * Socket 套接字          */          public var socket:Socket=new Socket();          /**          * 域名或者主机Ip          */          public var host:String="localhost";          /**          * 通讯端口          */          public var port:int=1111;          /**          * 接收数据的类型          */          public var RecieveDataType:String="";          /**          * 发送数据的类型          */          public var SendDataType:String="";                    /**          * 通讯状态          */          private var stateMap:Object;          /**          * 当前通讯状态          */          private var currentState:int;          /**          * 字符类型          */          public static const CHARS:String="chars";          /**          * 字节类型          */          public static const BYTES:String="bytes";                              public function SPSocket()          {              socket.addEventListener(Event.CONNECT,onConnect);              socket.addEventListener(Event.CLOSE,onClose);              socket.addEventListener(IOErrorEvent.IO_ERROR,onIoError);              socket.addEventListener(ProgressEvent.SOCKET_DATA,onSocketData);          }                    public function connect():void{              if(!socket.connected){                  socket.connect(host,port);              }          }                    public function close():void{              socket.close();          }          /**          * 处理Socket接收数据          */          private function onSocketData(e:ProgressEvent):void{              if(RecieveDataType==BYTES){                  var bytes:ByteArray;                  socket.readBytes(bytes);                  /*trace("收到的数据:"+socket.bytesAvailable+"b/s");                 while(socket.bytesAvailable){                     var data:int=socket.readByte();                     trace(data);                 }*/              }else if(RecieveDataType==CHARS){                  var recieveData:String=socket.readUTFBytes(socket.bytesAvailable);              }          }          /**          * 写入数据          */          public function WriteDate():void{              if(socket.connected){                                }          }          private function onConnect(e:Event):void{              trace("正在连接服务器...");          }          private function onClose(e:Event):void{              trace("正在与服务器断开连接...");          }          private function onIoError(e:Event):void{              trace("正在与服务器断开连接...");          }      }  }   演示结果:

收藏于 2011-05-25

来自于百度空间

时间: 2024-10-01 03:04:07

flex与C# Socket通信的相关文章

TCP及socket通信原理

一.网络互联模型 因特网在刚面世时,只有同一制造商生产的计算机才能彼此通信,制定网络互联模型的目的就是为异种的计算机互连提供一个共同的基础和标准框架,并为保持相关标准的一致性和兼容性提供共同的参考. 互联参考模型: OSI七层模型(Open System Interconnect):应用层.表示层.会话层.传输层.网络层.数据链路层.物理层 DoD四层模型:是OSI七层模型的浓缩版,包括 进程/应用层.主机到主机层.因特网层.网络接入层 以上两种模型是层次型的,分层模型的优点主要在于: ①将网络

java socket通信-传输文件图片--传输图片

ClientTcpSend.java   客户端发送类 package com.yjf.test; import java.io.DataOutputStream; import java.io.File; import java.io.FileInputStream; import java.net.InetSocketAddress; import java.net.Socket; public class ClientTcpSend { public static String clien

c# socket通信较完善方案

c#的socket通信应用.文件较多.附件为工程.  core AbstractBytesWorker.cs    字节工作器(基类),用于用于同一不同功能的字节工作器 BinaryHand.cs  2进制处理器.  ThDispose.cs 处理回收相关 crc  entity ThPersonInfo.cs manager ThSocketManager.cs  ThSocketManagerBusiness.cs 所有的业务 request RequestCode.cs  请求码 ThPr

深入浅出讲解:php的socket通信

深入浅出讲解:php的socket通信 对TCP/IP.UDP.Socket编程这些词你不会很陌生吧?随着网络技术的发展,这些词充斥着我们的耳朵.那么我想问: 1.         什么是TCP/IP.UDP?2.         Socket在哪里呢?3.         Socket是什么呢?4.         你会使用它们吗? 什么是TCP/IP.UDP? TCP/IP(Transmission Control Protocol/Internet Protocol)即传输控制协议/网间协

Android简单Socket通信demo

一.Android Socket 通信简介 Android与服务器的通信方式主要有两种,一是Http通信,一是Socket通信.两者的最大差异在于,http连接使用的是“请求—响应方式”,即在请求时建立连接通道,当客户端向服务器发送请求后,服务器端才能向客户端返回数据.而Socket通信则是在双方建立起连接后就可以直接进行数据的传输,在连接时可实现信息的主动推送,而不需要每次由客户端想服务器发送请求. 那么,什么是socket?Socket又称套接字,在程序内部提供了与外界通信的端口,即端口通信

php的socket通信

对TCP/IP.UDP.Socket编程这些词你不会很陌生吧?随着网络技术的发展,这些词充斥着我们的耳朵.那么我想问: 1.         什么是TCP/IP.UDP?2.         Socket在哪里呢?3.         Socket是什么呢?4.         你会使用它们吗? 什么是TCP/IP.UDP? TCP/IP(Transmission Control Protocol/Internet Protocol)即传输控制协议/网间协议,是一个工业标准的协议集,它是为广域网

Socket通信(转)

一.Socket通信简介 Android与服务器的通信方式主要有两种,一是Http通信,一是Socket通信.两者的最大差异在于,http连接使用的是“请求—响应方式”,即在请求时建立连接通道,当客户端向服务器发送请求后,服务器端才能向客户端返回数据.而Socket通信则是在双方建立起连接后就可以直接进行数据的传输,在连接时可实现信息的主动推送,而不需要每次由客户端想服务器发送请求. 那么,什么是socket?Socket又称套接字,在程序内部提供了与外界通信的端口,即端口通信.通过建立sock

基于Java NIO的Socket通信

Java NIO模式的Socket通信,是一种同步非阻塞IO设计模式,它为Reactor模式实现提供了基础. 下面看看,Java实现的一个服务端和客户端通信的例子. NIO模式的基本原理描述如下: 服务端打开一个通道(ServerSocketChannel),并向通道中注册一个选择器(Selector),这个选择器是与一些感兴趣的操作的标识(SelectionKey,即通过这个标识可以定位到具体的操作,从而进行响应的处理)相关联的,然后基于选择器(Selector)轮询通道(ServerSock

Socket通信

1:ServerSocket. 构造方法:ServerSocket(int port) : 创建一个绑定端口号的服务器 accept();监听并且接受Socket,并且返回一个Socket通信包. 2:Socket. 构造方法:Socket(String host,int port); 字节流: getOutputStream(); 输出流方法 (outputStream类) getInputStream();输入流方法 字符流: PrintWriter pw = new printWriter