C#服务端:

using System;
using System.Net.Sockets;
using System.Net;
using System.IO;
using System.Diagnostics;
using System.Threading;
using System.Runtime.InteropServices;      [StructLayout(LayoutKind.Sequential, Pack = )]
public struct PaketHead
{
public UInt32 OPCode;
public byte DiskFlag;
public long DiskSize;
public long OPOffSet;
public long OPByteCount; [MarshalAs(UnmanagedType.ByValArray, SizeConst = )]
public byte[] Authentic;
public byte Encrypt;
public byte Ver;
[MarshalAs(UnmanagedType.ByValArray, SizeConst = )]
public byte[] AddIn;
[MarshalAs(UnmanagedType.ByValArray, SizeConst = )]
public byte[] Reserve;
public byte Zero;
public int SizeOfHead;
} protected byte[] Struct2Bytes<T>(T obj)
{
int size = Marshal.SizeOf(obj);
byte[] bytes = new byte[size];
IntPtr arrPtr = Marshal.UnsafeAddrOfPinnedArrayElement(bytes, );
Marshal.StructureToPtr(obj, arrPtr, true);
return bytes;
} protected T Bytes2Struct<T>(byte[] bytes)
{
IntPtr arrPtr = Marshal.UnsafeAddrOfPinnedArrayElement(bytes, );
return (T)Marshal.PtrToStructure(arrPtr, typeof(T));
} protected void ReadPacketHead(BinaryReader ClientReader, BinaryWriter ClientWriter)
{
byte[] test = null;
test = ClientReader.ReadBytes(); PaketHead Paket = Bytes2Struct<PaketHead>(test); Console.WriteLine(Paket.OPCode);
Console.WriteLine(Paket.DiskFlag);
Console.WriteLine(Paket.DiskSize);
Console.WriteLine(Paket.OPOffSet);
Console.WriteLine(Paket.OPByteCount);
Console.WriteLine(System.Text.Encoding.ASCII.GetString(Paket.Authentic));
Console.WriteLine(Paket.Encrypt);
Console.WriteLine(Paket.Ver);
Console.WriteLine(System.Text.Encoding.ASCII.GetString(Paket.AddIn));
Console.WriteLine(System.Text.Encoding.ASCII.GetString(Paket.Reserve));
Console.WriteLine(Paket.Zero);
Console.WriteLine(Paket.SizeOfHead);
/////////////////////////////////
test = Struct2Bytes<PaketHead>(Paket);
ClientWriter.Write(test);
}

C++ Client:

 #include <winsock2.h>
#pragma comment( lib, "ws2_32.lib" ) #pragma pack(push, 1)//取消内存大小自动对齐 typedef struct _PaketHead2
{
UINT OPCode;/////////////
UCHAR DiskFlag;//////////
__int64 DiskSize;////////
__int64 OPOffSet;////////
__int64 OPByteCount;/////
UCHAR Authentic[];//
UCHAR Encrypt;////////
UCHAR Ver;////////////
UCHAR AddIn[];//////
UCHAR Reserve[];////
UCHAR Zero;///////////
UINT SizeOfHead;/////////
}PaketHead2,*pPaketHead2; #pragma pack(pop) //template <class T>
//void ConvertToByteArray(T arg,unsigned char * Buffer)
//{
// for (int i=0;i<sizeof(T); i++)
// {
// int offset = i*8;
// Buffer[i] = (arg& (0xff << offset)) >> offset;
// }
//}
//
//template <class T>
//T ConvertBytesTo(byte *buf)
//{
// T ret = 0x0;
// for (int i=0;i<sizeof(T); i++)
// {
// int offset = i*8;
// ret |= buf[i] << offset;
// }
// return (ret);
//} int ConnTest()
{
SOCKET mySocket;
WORD wVersionRequested;
WSADATA wsaData;
int err; wVersionRequested = MAKEWORD( , ); WSAStartup( wVersionRequested, &wsaData ); try
{
err = WSAStartup( wVersionRequested, &wsaData );
if ( err != ) {
printf("Couldn't find a WinSock DLL\n");
return ;
} if ( LOBYTE( wsaData.wVersion ) != ||
HIBYTE( wsaData.wVersion ) != )
{
printf("Couldn't find the right version for WinSock 2.2\n");
WSACleanup( );
return ;
} SOCKADDR_IN ServerAddr; mySocket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
ServerAddr.sin_family = AF_INET;
ServerAddr.sin_port = htons();
ServerAddr.sin_addr.s_addr = inet_addr("192.168.0.5"); if (connect(mySocket, (SOCKADDR *) &ServerAddr, sizeof(ServerAddr)))
{
int error_code = WSAGetLastError();
printf("Error connecting socket: %d\n",error_code);
return ;
} ///////// PaketHead2 testhead2; memset(&testhead2,0x00,sizeof(PaketHead2)); testhead2.DiskFlag = 0x1;
testhead2.OPCode = ;
testhead2.DiskSize = ;
testhead2.OPOffSet = ;
testhead2.OPByteCount = ;
memcpy(testhead2.Authentic,"9876543210ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghij1234567\0",);
memcpy(testhead2.AddIn,"9876543210ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghij1234567\0",);
memcpy(testhead2.Reserve,"abcdefghij12345\0",); testhead2.Encrypt = 0x2;
testhead2.Ver = 0x4;
testhead2.Zero = 0x0;
testhead2.SizeOfHead = sizeof(PaketHead2); send(mySocket,(char*)(&testhead2),sizeof(PaketHead2),NULL); memset(&testhead2,0x00,sizeof(PaketHead2));
recv(mySocket,(char*)(&testhead2),sizeof(PaketHead2),NULL); /*testhead2.Authentic[63] = 0;
testhead2.AddIn[63] = 0;
testhead2.Reserve[15] = 0;*/ printf("%d\n",testhead2.OPCode);
printf("%d\n",testhead2.DiskFlag); printf("%ld\n",testhead2.DiskSize);
printf("%ld\n",testhead2.OPOffSet);
printf("%ld\n",testhead2.OPByteCount); printf("%s\n",testhead2.Authentic);
printf("%d\n",testhead2.Encrypt);
printf("%d\n",testhead2.Ver); printf("%s\n",testhead2.AddIn);
printf("%s\n",testhead2.Reserve); printf("%d\n",testhead2.Zero); printf("%d\n",testhead2.SizeOfHead);
//////////////////////////////////////////////////
closesocket(mySocket);
WSACleanup( );
}
catch()
{
printf("Error!\n");
}
}

引文链接:

C#与C++通过socket传送结构体

C#通过TCP传送结构体

C#与C++通过socket传送结构体的更多相关文章

  1. 通过TCP传送结构体的问题

    这个问题在其他博客中已经给出了解决方案,这里结合自己的Demo说一下. 函数调用的库文件是基于TCP协议的封装,在传送消息体的时候,发送消息结果大体如下: XXXXPost(srcid, EVENT, ...

  2. socket发送结构体

    struct send_info {char info_from[20]; //发送者IDchar info_to[20]; //接收者IDint info_length; //发送的消息主体的长度c ...

  3. C# Socket 入门4 UPD 发送结构体(转)

    今天我们来学 socket  发送结构体 1. 先看要发送的结构体 using System; using System.Collections.Generic; using System.Text; ...

  4. Linux C Socket编程发送结构体、文件详解及实例

    利用Socket发送文件.结构体.数字等,是在Socket编程中经常需要用到的.由于Socket只能发送字符串,所以可以使用发送字符串的方式发送文件.结构体.数字等等. 本文:http://www.c ...

  5. 2. socket结构体——表示socket地址

    一.两种通用socket结构体 1. sockaddr struct sockaddr { sa_family_t sa_family; // 地址族 char sa_data[14]; // 存放s ...

  6. C++学习(二十四)(C语言部分)之 结构体1

    1.结构体 存放多个不同类型的数据 但是是相关联的 数组 存放多个相同类型的数据 结构体是存放多个相关联的不同类型的数组 struct 定义一个结构体类型 自定义类型 2.结构体定义方式 定义类型最通 ...

  7. C#结构体数组间的转化

    转自:http://developer.51cto.com/art/200908/143779.htm 解决C#结构体数组间的转化问题的由来:在写C#TCP通信程序时,发送数据时,如果是和VC6.0等 ...

  8. java socket传送一个结构体给用C++编写的服务器解析的问题

    另一端是Java写客户端程序,两者之间需要通信.c++/c接收和发送的都是结构体,而Java是直接发送的字节流或者byte 数组.解决方法:c++/c socket 在发送结构体的时候其实发送的也是字 ...

  9. C与C# socket 跨平台通讯传输结构体

    最近需要写一个C组成的服务器端与C#的客户端进行交互的软件,刚开始写的时候发现C#端解析时候出现了故障,经过仔细研究后发现原因是发送方传输太快,出现了所谓粘包的现象.也就是在C#端的Receive() ...

随机推荐

  1. [android] socket在手机上的应用

    1.手机助手 1.1 USB链接 可以读取手机的PID和VID,确定唯一的设备,可以给手机安装对应的驱动等 socket在固定端口通信 1.2 WIFI链接 pc在电脑在整个网段发送UDP数据包,手机 ...

  2. Redis安装、配置

    一.Redis安装 Linux安装 下载tar包,移至Linux目录下 解压:tar -zxvf redis-4.0.1.tar.gz 安装gcc:yum install gcc-c++(编译失败需安 ...

  3. php explode时间分割

    <?php $str = "2017-02-27 13:40:42"; $first=explode(' ',$str); $second=explode('-', $fir ...

  4. AMD 规范与CMD 规范概要

    命名冲突和文件依赖,是前端开发过程中的两个经典问题.通过模块化开发来解决. AMD 规范在这里:https://github.com/amdjs/amdjs-api/wiki/AMD CMD 规范在这 ...

  5. php编程--二叉树遍历算法实现

    今天使用php来实现二叉树的遍历 创建的二叉树如下图所示 php代码如下所示:   <?php   class Node {   public $value;   public $child_l ...

  6. Regular Expression学习笔记

    正则写法 var re = /a/;//简写 /.../里不能为空,因为会误以为是注释: var re = new RegExp('a'); 新建一个RegExp对象:和新建Array对象,Objec ...

  7. angular之$on、$emit、$broadcast

    1.$scope.$on view事件 //View被加载但是DOM树构建之前时: $scope.$on('$viewContentLoading', function(event, viewConf ...

  8. UTF8文件带BOM引起的问题

    起因是公司iOS端竟然加载除了HTML代码,百思不得其解,查文献,原来如此... UTF-8 不需要 BOM,尽管 Unicode 标准允许在 UTF-8 中使用 BOM.所以不含 BOM 的 UTF ...

  9. 基础架构之Docker私有库

    由于项目要容器化,所有搭建自己的镜像库也是很有必要的,不然发到直接使用官方的镜像库,速度绝对能让你头疼,这篇文章就介绍搭建自己的镜像私有库. (一)  环境要求 Centos 7.5.1804 Doc ...

  10. .NET开源工作流RoadFlow-流程运行-任务收回

    如果一个任务则发送,又觉得还要想修改可以立即收回刚刚发送的任务. 任务收回条件:任务发送后下一步处理人还没有打开该任务,则在已办事项中会看到 收回 按钮,否则不能收回. 点击收回按钮再确认即可收回刚刚 ...