C#与C++通过socket传送结构体
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传送结构体的更多相关文章
- 通过TCP传送结构体的问题
这个问题在其他博客中已经给出了解决方案,这里结合自己的Demo说一下. 函数调用的库文件是基于TCP协议的封装,在传送消息体的时候,发送消息结果大体如下: XXXXPost(srcid, EVENT, ...
- socket发送结构体
struct send_info {char info_from[20]; //发送者IDchar info_to[20]; //接收者IDint info_length; //发送的消息主体的长度c ...
- C# Socket 入门4 UPD 发送结构体(转)
今天我们来学 socket 发送结构体 1. 先看要发送的结构体 using System; using System.Collections.Generic; using System.Text; ...
- Linux C Socket编程发送结构体、文件详解及实例
利用Socket发送文件.结构体.数字等,是在Socket编程中经常需要用到的.由于Socket只能发送字符串,所以可以使用发送字符串的方式发送文件.结构体.数字等等. 本文:http://www.c ...
- 2. socket结构体——表示socket地址
一.两种通用socket结构体 1. sockaddr struct sockaddr { sa_family_t sa_family; // 地址族 char sa_data[14]; // 存放s ...
- C++学习(二十四)(C语言部分)之 结构体1
1.结构体 存放多个不同类型的数据 但是是相关联的 数组 存放多个相同类型的数据 结构体是存放多个相关联的不同类型的数组 struct 定义一个结构体类型 自定义类型 2.结构体定义方式 定义类型最通 ...
- C#结构体数组间的转化
转自:http://developer.51cto.com/art/200908/143779.htm 解决C#结构体数组间的转化问题的由来:在写C#TCP通信程序时,发送数据时,如果是和VC6.0等 ...
- java socket传送一个结构体给用C++编写的服务器解析的问题
另一端是Java写客户端程序,两者之间需要通信.c++/c接收和发送的都是结构体,而Java是直接发送的字节流或者byte 数组.解决方法:c++/c socket 在发送结构体的时候其实发送的也是字 ...
- C与C# socket 跨平台通讯传输结构体
最近需要写一个C组成的服务器端与C#的客户端进行交互的软件,刚开始写的时候发现C#端解析时候出现了故障,经过仔细研究后发现原因是发送方传输太快,出现了所谓粘包的现象.也就是在C#端的Receive() ...
随机推荐
- Java - 线程封闭
保证并发安全性的方式有三: 不共享.不可变.同步 前两种方式相对第三种要简单一些. 这一篇不说语言特性和API提供的相关同步机制,主要记录一下关于共享的一些思考. 共享(shared),可以简单地认为 ...
- webservice log4net日志写入失败
原因1:如果webservice和调用者都部署在一台机器上,日志有可能写到了项目所在目录中,虽然你添加的服务引用是部署在iis下的,但不会写到这.暂时解决办法,把webservice部署到内网服务器上 ...
- SSM+PageHelper+jqGrid实现数据分页
前言 前几天自己写了一个分页功能,代码逻辑写的很乱今天发现jqGrid这个工具是真好用,故记录下来方便以后使用首先是PageHelper后台分页工具PageHelper的原理是基于拦截器实现的 具体流 ...
- docker 安装ElasticSearch的中文分词器IK
首先确保ElasticSearch镜像已经启动 安装插件 方式一:在线安装 进入容器 docker exec -it elasticsearch /bin/bash 在线下载并安装 ./bin/ela ...
- Linux下查看Tomcat的控制台输出信息
Linux下查看Tomcat的控制台输出信息 首先使用SSH连接到数据库,然后点击window创建一个new terminal, 进入tomcat/logs/文件夹下,输出控制台信息,命令如下: cd ...
- 2013 Warm up 3 -- Skill --- dp
题意:求n位数字,满足非递减的个数. dp[ i ] [ j ] = sum( dp[i -1] [ k ] ); k =>( j , 9); #include<iostream> ...
- 【转】OkHttp使用进阶 译自OkHttp Github官方教程
作者:GavinCT 出处:http://www.cnblogs.com/ct2011/ 英文版原版地址 Recipes · square/okhttp Wiki 同步get 下载一个文件,打印他的响 ...
- Android输入法架构学习总结
此文为本人学习输入法之后所做的一个总结报告.与大家分享. 安卓输入法框架(Input Method Framework)IMF 一.输入法框架简介 自Android平台1.5版本以后,Google开放 ...
- Caffe&Torch&Theano&TensorFlow
https://www.youtube.com/watch?v=Qynt-TxAPOs&index=12&list=PL16j5WbGpaM0_Tj8CRmurZ8Kk1gEBc7fg ...
- ubuntu 18 设置语言环境
1. 查看语言环境 ubuntu系统中,存在两个系统变量:$LANG和$LANGUAGE 分别控制语言环境和地区,这两个变量是从/etc/default/locale中读取的: 方法一: echo $ ...