用php的socket跟flash的socket通信

用php的socket跟flash的socket通信

关于socket不多说了,这个网上的资料很多,关于flash的资料也很多,这里只说在网上找不到资料或者资料很少的哦东西

php的socket资料可谓少之又少,光是在google上搜php socket,出来的结果页就是那么三四篇文章,点进去看看,基本都是

从手册上抄下来的,一点问题都起不了,以至于我花了两天时间才使php和flash成功通信,呵呵

其实,php和flash的socket通信不是问题的难点,难点在于flash的安全策略,特别是socket,特别是在flash player 10中要求更加

严格.

下面分几个部分来说:php的socket\flash的socket\flash的安全策略\怎么用php解决这个策略

希望对缺乏资料的人有所帮助,如果你用的其他后台语言与flash交互,可能比php简单,因为php的确不是个做socket的好东西,

但是或许某个时刻你就会用到这个

(1)php的socket:

先贴一段代码,就是我实现通信的程序中的代码:
  1. <?php
  2. set_time_limit(0);
  3. $address = "127.0.0.1";
  4. ob_implicit_flush();


  5. $port = '8083';

  6. if (($sock = socket_create(AF_INET, SOCK_STREAM, SOL_TCP)) < 0) {
  7. echo "socket_create() failed: reason: " . socket_strerror($sock) . "\n";
  8. }

  9. if (($ret = socket_bind($sock, $address, $port)) < 0) {
  10. echo "socket_bind() failed: reason: " . socket_strerror($ret) . "\n";
  11. }

  12. if (($ret = socket_listen($sock, 5)) < 0) {
  13. echo "socket_listen() failed: reason: " . socket_strerror($ret) . "\n";
  14. }
  15. do {
  16. if (!($msgsock = socket_accept($sock))) {
  17. echo "socket_accept() failed: reason: " . socket_strerror($msgsock) . "\n";
  18. break;
  19. }


  20. do {

  21. //如果是安全策略请求,则传输安全策略文件内容
  22. if($buf = socket_read($msgsock, 2048)){
  23. if(strpos($buf,'policy-file-request')){
  24. $msg ="<cross-domain-policy><allow-access-from domain='*' to-ports='*' /></cross-domain-policy>";
  25. socket_write($msgsock, $msg."\0", strlen($msg."\0"));
  26. }

  27. //答复数据

  28. $talkback = "PHP: You said '$buf'.\n";
  29. socket_write($msgsock, $talkback, strlen($talkback));

  30. }

  31. } while (true);
  32. socket_close($msgsock);
  33. } while (true);
  34. //socket_close($spawn);
  35. //socket_close($socket);
  36. ?>
复制代码
(2)flash的socket通信:

flash的socket通信也是资料比较多,直接贴代码
  1. package
  2. {
  3. import fl.controls.TextArea;
  4. import fl.core.UIComponent;

  5. import flash.events.*;
  6. import flash.net.Socket;
  7. import flash.system.*;
  8. import flash.utils.ByteArray;
  9. import flash.utils.setTimeout;

  10. public class CustomSocket
  11. {
  12. private const CR:int = 13; // Carriage Return (CR)
  13. private const WILL:int = 0xFB; // 251 - WILL (option code)
  14. private const WONT:int = 0xFC; // 252 - WON'T (option code)
  15. private const DO:int = 0xFD; // 253 - DO (option code)
  16. private const DONT:int = 0xFE; // 254 - DON'T (option code)
  17. private const IAC:int = 0xFF; // 255 - Interpret as Command (IAC)

  18. private var serverURL:String;
  19. private var portNumber:int;
  20. private var socket:Socket;
  21. private var ta:TextArea;
  22. private var state:int = 0;
  23. System.useCodePage = false;
  24. public function CustomSocket(server:String, port:int, output:TextArea)
  25. {
  26. serverURL = server;
  27. portNumber = port;
  28. ta = output;
  29. socket = new Socket();
  30. socket.addEventListener(Event.CONNECT, connectHandler);
  31. socket.addEventListener(Event.CLOSE, closeHandler);
  32. socket.addEventListener(ErrorEvent.ERROR, errorHandler);
  33. socket.addEventListener(IOErrorEvent.IO_ERROR, ioErrorHandler);
  34. socket.addEventListener(ProgressEvent.SOCKET_DATA, dataHandler);

  35. //        Security.loadPolicyFile("xmlsocket://" + serverURL + ":"+portNumber);

  36. try
  37. {
  38. msg("Trying to connect to" + serverURL + ":" + portNumber + "\n");
  39. socket.connect(serverURL,portNumber);
  40. }
  41. catch (error:Error)
  42. {
  43. msg(error.message + "\n");
  44. // socket.close();
  45. }
  46. }
  47. public function ioErrorHandler(event:IOErrorEvent):void
  48. {
  49. msg("Unable to connect: socket error.\n");
  50. }
  51. public function writeBytesToSocket():void {
  52. socket.writeUTFBytes("sssssssssssssssssssss");
  53. socket.flush();
  54. }
  55. private function connectHandler(event:Event):void {
  56. if (socket.connected) {
  57. msg("connected...\n");

  58. } else {
  59. msg("unable to connect\n");
  60. }
  61. }
  62. private function closeHandler(event:Event):void
  63. {
  64. msg("closed...\n");
  65. }
  66. private function errorHandler(event:ErrorEvent):void {
  67. msg(event.text + "\n");
  68. }
  69. private function dataHandler(event:ProgressEvent):void {
  70. while ( socket.bytesAvailable ) {
  71. // Read a byte from the socket and display it
  72. var data = socket.readUTFBytes(socket.bytesAvailable);
  73. ta.text+=data;
  74. }
  75. }
  76. private function msg(value:String):void {
  77. ta.text += value;
  78. ta.dispatchEvent(new Event(Event.CHANGE));
  79. setTimeout(setScroll, 100);
  80. }
  81. public function setScroll():void {
  82. ta.verticalScrollPosition = ta.maxVerticalScrollPosition;
  83. }
  84. public function closeSocket():void{
  85. socket.close();
  86. }
  87. public function sendM(e:String):void
  88. {
  89. socket.writeUTFBytes(e);
  90. socket.flush();
  91. }
  92. }

  93. }
复制代码
(3).安全策略

基本内容见此文章:http://wangleifire.iteye.com/blog/335034

flash的安全策略是很严格的,特别是在flash 10中,当使用socket的时候必须存在策略文件才能继续传输数据,这个文件以前可以直接存放在根目录即可,而现在要求必须

在socket中直接传输才行,默认情况下flash会在服务器的843端口寻找这个策略文件的传输socket,可是php中开多个端口传输很有问题,不能实现多线程是主要问题,所以

这个方法不太好,也不太直接,其实还有一个非常直接的方法,就是不用任何端口或者开辟其他通信,flash在向某个端口请求数据的时候,第一次会发送一个字符串

"<policy-file-request/>",如果服务器收到这个字符窜,直接回复一个策略文件格式的字符串,即可通过安全验证,然后就可以传输数据了,我做过实验,的确可以通信了,

但是因为是php,一直执行某个网页才能监听socket,所以不能放在服务器上给大家来测试,如果感兴趣可以找我探讨:qq:676588498;
  1. if($buf = socket_read($msgsock, 2048)){
  2. if(strpos($buf,'policy-file-request')){
  3. $msg ="<cross-domain-policy><allow-access-from domain='*' to-ports='*' /></cross-domain-policy>";
  4. socket_write($msgsock, $msg."\0", strlen($msg."\0"));
  5. }

  6. //答复数据

  7. $talkback = "PHP: You said '$buf'.\n";
  8. socket_write($msgsock, $talkback, strlen($talkback));

  9. }
复制代码
上面这部分php代码正是实现了安全策略文件传送的作用,这个是很重要的,没有这句判断的话,在flash ide里测试的话或者在flex builder里测试的话是可以正常通信的,但是

当你将flash放在服务器上或者独立运行的时候就会无法连接服务器,提示安全策略失败什么的,这是因为在测试环境中,Adobe忽略了策略文件请求这一部,可以方便开发者,但是

也容易让人忽视安全问题.o了,罗嗦到这,今晚又熬过头了
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值