下面是在flex下的客户端:
- <?xml version="1.0" encoding="utf-8"?>
- <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" creationComplete="initApp()">
- <mx:Script>
- <![CDATA[
- import flash.events.SecurityErrorEvent;
- import flash.events.IOErrorEvent;
- import flash.events.ProgressEvent;
- import flash.net.Socket;
- import flash.utils.ByteArray;
- private var socket:Socket = new Socket();
- internal function initApp():void
- {
- socket.addEventListener(Event.CLOSE,closeHandler);
- socket.addEventListener(Event.CONNECT,connectHandler);
- socket.addEventListener(IOErrorEvent.IO_ERROR,ioErrorHandler);
- socket.addEventListener(SecurityErrorEvent.SECURITY_ERROR,securityErrorHandler);
- socket.addEventListener(ProgressEvent.SOCKET_DATA,socketDataHandler);
- }
- internal function closeHandler(evt:Event):void
- {
- output("connect fail and close");
- }
- internal function connectHandler(evt:Event):void
- {
- output("connect success");
- }
- internal function ioErrorHandler(evt:IOErrorEvent):void
- {
- output("io error:"+evt.text);
- }
- internal function securityErrorHandler(evt:SecurityErrorEvent):void
- {
- output("security error :"+evt.text);
- }
- internal function doConnect():void
- {
- var server:String = server_txt.text;
- var port:Number =Number(port_txt.text);
- socket.connect(server,port);
- }
- internal function socketDataHandler(evt:ProgressEvent):void
- {
- var msg:String;
- while(socket.bytesAvailable)
- msg+=socket.readMultiByte(socket.bytesAvailable,"utf8");
- var arr:Array = msg.split('\n');
- for(var i:int=0;i<arr.length;i++)
- {
- if(arr[i].length>1)
- {
- var myPattern:RegExp=/\r/;
- arr[i]=arr[i].replace(myPattern,'');
- output(arr[i]);
- }
- }
- }
- internal function sendMessage(msg:String):void
- {
- var message:ByteArray = new ByteArray();
- message.writeUTFBytes(msg+"\r\n");
- socket.writeBytes(message);
- socket.flush();
- }
- internal function output(msg:String):void
- {
- msg=msg+"\n";
- output_txt.text+=msg;
- }
- ]]>
- </mx:Script>
- <mx:Panel x="368" y="25" width="360" height="336" layout="absolute" title="输出信息">
- <mx:TextArea x="10" y="77" width="100%" height="213" id="output_txt"/>
- <mx:TextInput x="23" y="37" id="input_txt" text="输入信息" enter="sendMessage(input_txt.text)"/>
- <mx:Button x="246" y="37" label="发送" click="sendMessage(input_txt.text)"/>
- </mx:Panel>
- <mx:Panel x="40" y="78" width="250" height="200" layout="absolute" title="登陆窗口">
- <mx:Label x="10" y="10" text="服务器地址"/>
- <mx:TextInput x="73" y="8" width="147" id="server_txt" text="127.0.0.1"/>
- <mx:Label x="10" y="51" text="端口"/>
- <mx:TextInput x="73" y="49" width="147" id="port_txt" text="80"/>
- <mx:Button x="73" y="109" label="连接" click="doConnect()"/>
- </mx:Panel>
- </mx:Application>
下面是c++服务器端:
- // server.cpp : 定义控制台应用程序的入口点。
- //
- #include "stdafx.h"
- #include <winsock2.h>
- #include <windows.h>
- #include <iostream>
- using namespace std;
- #pragma comment(lib,"ws2_32.lib")
- void main(){
- WORD wVersionRequested;
- WSADATA wsaData;
- int err;
- short port=80;//端口号
- 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));
- //接收数据
- 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(send(sockConn,rbuf,strlen(rbuf)+1,0)==SOCKET_ERROR){
- printf("发送数据失败!");
- exit(-1);
- }
- printf("Message to %s: %s\n",inet_ntoa(addrClient.sin_addr),rbuf);
- //清理套接字占用的资源
- closesocket(sockConn);
- }
- }
相关推荐
web flex应用通过socket与C++编写的服务端进行通讯的一个例子,包括服务端代码(VC编译),flex的mxml文件(flex3builder新建web flex工程后,用该mxml文件直接替换src里的mxml文件即可)
基于QT - SOCKET 的 C++ 实现矩阵压力数据采集及压力云图现实。 基于QT - SOCKET 的 C++ 实现矩阵压力数据采集及压力云图现实。 基于QT - SOCKET 的 C++ 实现矩阵压力数据采集及压力云图现实。 基于QT - SOCKET 的 ...
socket通信库,c++编写,只需调用几个函数即可完成socket通信过程。简单易用,C#等其他语言可调用.问题沟通可发送邮件至gaocongly@126.com
c++实现SOCKET通信Demo,供TCP/IP通信进行测试。vc6.0、vs2010都支持,下载可编译。
服务端和客户端中分别对socket进行的操作,进行socket连接
客服端使用Flash编写,使用了Flash的Socket实现网络通信 服务端采用C++编写 简单实现二者的网络通信
android与c++通过socket通信 vc6.0开发环境 android与c++通过socket通信 vc6.0开发环境 android与c++通过socket通信 vc6.0开发环境
C#利用Socket实现客户端之间直接通信 实验功能: 设计程序,分别构建通信的两端:服务器端和客户端应用程序,套接字类型为面向连接的Socket,自己构建双方的应答模式,实现双方的数据的发送和接收(S发给C,C发给S)...
基于c++的socket通信框架,windows版本,HP-SOCKET ..
c++ socket类,实现网络通信
Socket实现客户端与服务端通信源码 程序说明: 开发工具:Visual Studio 2005 本程序演示了Socket通信的基本原理,非常适合初学者。程序分为两部分:服务器端与客户端,实际上客户端也可以充当服务器端,本程序两端...
C++实现简单Socket通信,最基本的代码。可以作为初始学习socket功能使用,仅供参考...................
c++ socket 通信demo
java与c++通过socket通信。其中java作为客户端,c++作为服务器。主要解决了C++中的结构体在java中如何实现和模拟。还有int,float,及字符串的处理。极具代表性。
利用socket实现客户端与服务器之间的简单通信,快速熟悉掌握三次握手与四次挥手。。。
c++,socket的应用例子,能实现发送消息
C C++ socket编程教程:1天玩转socket通信技术 _
自己编写的简单的socket通信程序。 采用C++编写。 共2个工程:server和client。 已经在VC6.0上运行通过。
java和c++通信,支持多用户并发,采用java非阻塞式socket通信。
C#的Socket实现UDP协议通信 CSharp