通过空格,通过套接字接收数据

时间:2012-06-10 19:55:07

标签: html qt sockets qt4 large-data

我正在使用C ++和QT4。当我尝试发送大型html文件(在这种情况下,8kb)时,发送和接收的过程工作得很好。但收到的文件在html文件的每个字符之间都有空格。这是一个例子,文件发送方式如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN" "http://www.w3.org/TR/REC-html40/strict.dtd">
<html><head><meta name="qrichtext" content="1" /><style type="text/css">
p, li { white-space: pre-wrap; }
</style></head><body style=" font-family:'MS Shell Dlg 2'; font-size:8.25pt; font-weight:400; font-style:normal;">
<p style=" margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px;">a</p></body></html>

它收到了,就像这样:

  ¼ < ! D O C T Y P E   H T M L   P U B L I C   " - / / W 3 C / / D T D   H T M L   4 . 0 / / E N "   " h t t p : / / w w w . w 3 . o r g / T R / R E C - h t m l 4 0 / s t r i c t . d t d " > 
 < h t m l > < h e a d > < m e t a   n a m e = " q r i c h t e x t "   c o n t e n t = " 1 "   / > < s t y l e   t y p e = " t e x t / c s s " > 
 p ,   l i   {   w h i t e - s p a c e :   p r e - w r a p ;   } 
 < / s t y l e > < / h e a d > < b o d y   s t y l e = "   f o n t - f a m i l y : ' M S   S h e l l   D l g   2 ' ;   f o n t - s i z e : 8 . 2 5 p t ;   f o n t - w e i g h t : 4 0 0 ;   f o n t - s t y l e : n o r m a l ; " > 
 < p   s t y l e = " - q t - p a r a g r a p h - t y p e : e m p t y ;   m a r g i n - t o p : 0 p x ;   m a r g i n - b o t t o m : 0 p x ;   m a r g i n - l e f t : 0 p x ;   m a r g i n - r i g h t : 0 p x ;   - q t - b l o c k - i n d e n t : 0 ;   t e x t - i n d e n t : 0 p x ; " > < / p > < / b o d y > < / h t m l >

我用于发送和接收的代码:

发送代码:

qDebug() << "Connected. Sending file to the server"; QString text = ui->QuestHtmlText->toPlainText();

if(text.length() < 1024)
{
    QByteArray block;
    QDataStream out(&block, QIODevice::WriteOnly);
    out << quint16(0) << QUESTION_HTML;
    out << text;
    out.device()->seek(0);
    out << quint16(block.size() - sizeof(quint16));
    qDebug() << "Block size: " << block.size();
    socket.write(block);
    return;
}

for(int i = 0; i < text.length(); i+=1024)
{
    QByteArray block;
    QDataStream out(&block, QIODevice::WriteOnly);
    out << quint16(0) << QUESTION_HTML;
    if((text.length() - i) > 1024)
        out << text.mid(i, i+1024);
    else
        out << text.right(1024 - i);
    out.device()->seek(0);
    out << quint16(block.size() - sizeof(quint16));
    qDebug() << "Block size: " << block.size();
    socket.write(block);
}

接收代码:

qDebug() << "Writing File";
QDataStream in(this);
QString temp = "Teste.html", text;
QFile myFile(".//Questions//" + temp);
myFile.open(QIODevice::WriteOnly);
QDataStream out(&myFile);
while(!in.atEnd())
{
    in >> text;
    out << text;
}

我之前打过一个帖子,在这里:Sending data through socket spaces, receiving with spaces

人们不再帮我了。顺便说一下,我觉得我的问题没有完全回答。所以我又开了一个帖子。 我还查看了FAQ部分,看看在这种情况下我该怎么做。但没有成功。

无论如何,我现在的问题是:我应该删除quint16吗?那么我应该用什么来确定传入数据包的大小?

谢谢,我很抱歉我可能犯过的错误。

2 个答案:

答案 0 :(得分:3)

您在文件中返回的内容不是您的原始文本,而是QString序列化表单,这是不可忽视的UTF-16。如果您想要恢复文本,请将输入QDataStream读回QString并将其保存到文件中。

虽然为数据添加长度前缀通常是一个好主意,但对于QString&gt;&gt;它绝对是多余的。 QDataStream。阅读herehere内容。此外,你已经形成了一种令人困惑的模糊方式,我怀疑它什么都不做。 QByteArray没有实现QIODevice(实际上,为什么它应该这样)所以你的out.device() - &gt; seek()是一个基础虚拟实现,empty and just returning true。如果在序列化转储文件的末尾找到长度“标题”,我不会感到惊讶。

编辑:我认为您的html传输可能只是完全省略混乱的quint操作并使用out QTextStream而不是QByteStream来开始正常工作。

答案 1 :(得分:0)

我在另一篇文章中发布了我案例的解决方案。

谢谢大家的关注