无法在2个插座之间进行通信

时间:2012-09-25 13:49:47

标签: c++ qt sockets

我有一台Linux机器和一台Windows机器我有一个C ++程序,它充当Linux机器上的服务器,而Qt应用程序则充当Windows机器上的客户端。我使用套接字作为加密密钥(基本xor加密)

问题是,当我多次连接时,我会得到伪造的字符串。我认为问题出在qt应用程序中这里是我的代码。我试图让一个全局标志忙,以防止用户点击连接按钮manny次,但这个标志永远不会被触发。

为什么呢?我应该使用互斥锁吗?如果是的话怎么样?

void MainWindow::performRead()
{
    QTcpSocket * sock = static_cast<QTcpSocket*>(this->sender());
    if (key == 0)
    {
    busy = true;
    QString recv(sock->readLine());
    key = recv.toInt();
    qDebug() << "Cheia este " << key;

    char * response = enc_dec("#AUTH|admin|admin",strlen("#AUTH|admin|admin"),key);
    sock->write(response);
    }
    else
    {
        busy = true;
        while (sock->bytesAvailable() > 0)
        {  
        unsigned short word;
        sock->read((char*)(&word),2);
        qDebug()<<word;
        QByteArray bts = sock->read(word);
        char * decodat = enc_dec((char*)bts.data(),bts.length() - 2,key);
        char testx[2];
        sock->peek(&testx[0],2);
        qDebug() << decodat;
        }
    }

    busy = false;
}

void MainWindow::on_pushButton_clicked()
{
    if (!busy)
    {
    key = 0;
    QTcpSocket * sock = new QTcpSocket();
    connect(sock,SIGNAL(readyRead()),this,SLOT(performRead()));
    sock->connectToHost("194.110.212.46",6550);
    }
    else qDebug()<<"Can't you see I am busy??" << endl;
}

char * enc_dec(char * str,int len, int key)
{
    unsigned char keys[2];
    keys[0] = (unsigned char)key;
    keys[1] = keys[0] ^ 255;
    char * nou = new char[len + 1];
    nou[len] = '\0';
    for (int i = 0; i < len; i++)
    {
        char tmpy = str[i] ^ keys[i % 2];
        nou[i] = tmpy;
    }
    return nou;
}

1 个答案:

答案 0 :(得分:2)

你的代码很混乱,这是我的建议:

  • 每个按钮上都没有connect套接字 - 你覆盖了以前的内容,做了不必要的工作 - 建立TCP连接很昂贵,
  • 也许有一个&#34; Connect&#34;和&#34;断开&#34;按钮,只允许在建立连接时从套接字读取,
  • 尝试确保一切正常,没有您的加密&#34;第一,
  • 之后使用真正的加密。