-2

これには、QT4 で C++ を使用しています。また、大きな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;
}

以前、ここで投稿を開きました:ソケットスペースを介してデータを送信し、スペースで受信する

人々は私を助けるのをやめました。ところで、私の質問に完全に答えられた気がしませんでした。というわけで、別の投稿を開きました。また、FAQ セクションを調べて、この場合はどうすればよいかを確認しました。しかし、成功しませんでした。

とにかく、私の質問は次のとおりです。quint16を削除する必要がありますか? 着信パケットのサイズを決定するには何を使用すればよいですか?

ありがとうございます。間違いがあったことをお詫び申し上げます。

4

2 に答える 2

3

ファイルに返されるのは元のテキストではなく、QString シリアル化形式であり、驚くことに UTF-16 です。テキストを戻したい場合は、入力 QDataStream を読み取って QString に戻し、それをファイルに保存します。

データに長さのプレフィックスを付けることは一般的に良い考えですが、QString >> QDataStream では完全に冗長です。ここまたはここで何かを読んでください。さらに、あなたは、私が何もしていないと思われる気が遠くなるほど難読化された方法を開発しました。QByteArray は QIODevice を実装していません (実際、なぜそうすべきなのか) ため、 out.device()->seek() は基本仮想実装であり、空で true を返すだけです。シリアライゼーション ダンプ ファイルの最後に長さの「ヘッダー」が見つかっても驚かないでしょう。

編集:out混乱した quint 操作を完全に除外し、QByteStream の代わりに QTextStreamを使用することによってのみ、html トランスポートが正しく機能し始める可能性があると思います。

于 2012-06-10T21:12:37.120 に答える
0

私は自分のケースの解決策を別の投稿に投稿しました。

ご清聴ありがとうございました

于 2012-07-03T21:11:20.483 に答える