询问个Socket打包发送数据的方法

kemee 2010-08-14 10:57:48
RT,想传个文件(其实传什么都无所谓了)

一开始 file.Read(buf,4000),这样读进来,然后想给打个包头,就用CString sendBuf.Format("%d;%s",1,buf);这样,然后发现文件流里肯定有0数据,这样字符串就截断掉了,sendBuf里数据不全,那用什么方法给4000长度的buf前面添加点标识呢??? memcpy???还是什么??
...全文
163 16 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
16 条回复
切换为时间正序
请发表友善的回复…
发表回复
kemee 2010-08-14
  • 打赏
  • 举报
回复
[Quote=引用 11 楼 summer_king 的回复:]

最笨的方法:

[/Quote]

琢磨这个倒是可行,但是那个file.Read(buf,4000)返回值的4000和strlen(buf)计算出来的数字,含义不一样么。。。竟然数值不相等
Summer_King 2010-08-14
  • 打赏
  • 举报
回复
好一点的:
BYTE buf[4000];
BYTE buff[4004];
file.Read(buf, 4000);
int i = 0;
buff[0] = '$';
buff[1] = '1';
buff[4002] = 0x0D;
buff[4003] = 0x0A;
::memcpy((void*)&buff[2], (void*)&buf[0], 4000);
send((void*)buff, 4004)// 上面的写错鸟
Summer_King 2010-08-14
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 kemee 的回复:]

引用 9 楼 w1881 的回复:

C/C++ code
BYTE buf[4000];
file.Read(buf,4000);
send((void*)buf, 4000)
;
直接发,不用转成其他类型


需要在buf头部插入一个标识符,比如数字1,*,#之类的,直接发是没问题
[/Quote]最笨的方法:
BYTE buf[4000];
BYTE buff[4004];
file.Read(buf,4000);
int i = 0;
buff[0] = '$';
buff[1] = '1';
buff[4002] = 0x0D;
buff[4003] = 0x0A;
for (i=0; i<4000; i++)
{
buff[i+2] = buf[i];
}
send((void*)buff, 4000)
kemee 2010-08-14
  • 打赏
  • 举报
回复
[Quote=引用 9 楼 w1881 的回复:]

C/C++ code
BYTE buf[4000];
file.Read(buf,4000);
send((void*)buf, 4000)
;
直接发,不用转成其他类型
[/Quote]

需要在buf头部插入一个标识符,比如数字1,*,#之类的,直接发是没问题
w1881 2010-08-14
  • 打赏
  • 举报
回复
BYTE buf[4000];
file.Read(buf,4000);
send((void*)buf, 4000)
;
直接发,不用转成其他类型
kemee 2010-08-14
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 hastings 的回复:]

一切数据以二进制方式对待~~
用char[]储存,memcpy复制数据。
[/Quote]

file.Read(buf,4000) 这个函数返回值是4000,然后strlen(buf)计算出来却是很小一个数字,截断?
hastings 2010-08-14
  • 打赏
  • 举报
回复
一切数据以二进制方式对待~~
用char[]储存,memcpy复制数据。
pshchao 2010-08-14
  • 打赏
  • 举报
回复
可以把文件直接独到Cstring中
kemee 2010-08-14
  • 打赏
  • 举报
回复
汗。。。周末人少啊,就是想确定一下是不是因为文件流里0被截断的问题,如果是的话只好改用 memcpy 了,也不知道不停的偏移指针再memcpy会不会出现问题,大家有没更加好的思路
wyx100 2010-08-14
  • 打赏
  • 举报
回复
buf读的不是字符串,是个文件,反正随便什么文件读出来都一样了
kemee 2010-08-14
  • 打赏
  • 举报
回复
buf读的不是字符串,是个文件,反正随便什么文件读出来都一样了
kemee 2010-08-14
  • 打赏
  • 举报
回复
这样貌似不行啊。。。。int len = file.Read(buf,4000); 读出来 len是4000, format到CString里20,185,反正什么大小都有,难道不是遇到0截断掉了?
pshchao 2010-08-14
  • 打赏
  • 举报
回复
直接连接没错啊。 即使buf数据里有0也不会截断的。

CString sendBuf.Format("%c;%s",'@',buf);

客户端接收到消息后,先检测第一个字符。根据第一个字符做处理
大昊 2010-08-14
  • 打赏
  • 举报
回复
CString与string都是遇到\0就结束的,计算长度也一样,一般都用char[]来存储发送数据,使用memcpy,如果你实在是想用string的话可以使用std::string的append方法。
悟迟 2010-08-14
  • 打赏
  • 举报
回复
[Quote=引用 13 楼 kemee 的回复:]

引用 11 楼 summer_king 的回复:

最笨的方法:



琢磨这个倒是可行,但是那个file.Read(buf,4000)返回值的4000和strlen(buf)计算出来的数字,含义不一样么。。。竟然数值不相等
[/Quote]文件没有这么长吧,文件长度可以由file.Read()的返回值获得,不要用strlen
羽飞 2010-08-14
  • 打赏
  • 举报
回复
用memcpy,这样就不会被截掉了

16,548

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧