Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. General and Desktop
  4. Multiple Slot to same QNetworkAccessManager
Forum Updated to NodeBB v4.3 + New Features

Multiple Slot to same QNetworkAccessManager

Scheduled Pinned Locked Moved Unsolved General and Desktop
13 Posts 4 Posters 3.8k Views 2 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • H Offline
    H Offline
    Helson
    wrote on last edited by Helson
    #3

    Hi SGaist, thank you!

    I'm using the same QNetworkAccessManager for both classes.
    And now, I removed connect(mpNetworkMgr, SIGNAL(finished(QNetworkReply*)), this, SLOT(onFinish(QNetworkReply*)));

    But nothing has changed.

    The slot onFinishValid() is called two times.

    The first time when
    networkMgr->post(request, datatoSend); //Check user
    is executed.

    And the second time when
    networkMgr->post(request, datatoSend); //Send file

    Then I have to create a new QNetworkAccessManager for the second class?

    My best regards!


    EDIT

    When I use different QNetworkAccessManager, it's works so fine.
    But I wonder if is not a grood pratice.

    Thanks.

    1 Reply Last reply
    0
    • dheerendraD Offline
      dheerendraD Offline
      dheerendra
      Qt Champions 2022
      wrote on last edited by
      #4

      @Helson said:

      connect(networkMgr, SIGNAL(finished(QNetworkReply*)), this, SLOT(onFinishValid(QNetworkReply*)));

      By any chance whether above connect statement is called twice ? Can you try passing the Qt::UniqueConnection as 5th parameter to connect statement ?

      Dheerendra
      @Community Service
      Certified Qt Specialist
      http://www.pthinks.com

      H 1 Reply Last reply
      3
      • B Offline
        B Offline
        bsomervi
        wrote on last edited by
        #5

        You need to connect the finished signal of the QNetworkReply object instance returned by the QNetworkAccessManager::post() method, not the finished signal of the QNetworkAccessManager instance. That way the slots called are specific to the requests.

        Alternatively you can check the address of the QNetworkReply instance passed by the finished signal to see which request it belongs to.

        H 1 Reply Last reply
        0
        • dheerendraD dheerendra

          @Helson said:

          connect(networkMgr, SIGNAL(finished(QNetworkReply*)), this, SLOT(onFinishValid(QNetworkReply*)));

          By any chance whether above connect statement is called twice ? Can you try passing the Qt::UniqueConnection as 5th parameter to connect statement ?

          H Offline
          H Offline
          Helson
          wrote on last edited by
          #6

          @dheerendra I try to this, but not work :(
          Thank you.

          1 Reply Last reply
          0
          • B bsomervi

            You need to connect the finished signal of the QNetworkReply object instance returned by the QNetworkAccessManager::post() method, not the finished signal of the QNetworkAccessManager instance. That way the slots called are specific to the requests.

            Alternatively you can check the address of the QNetworkReply instance passed by the finished signal to see which request it belongs to.

            H Offline
            H Offline
            Helson
            wrote on last edited by
            #7

            @bsomervi Thanks for your explanation, but in terms of code, I don't know how I can achieve that...

            If you can explain me a little bit i'll be grateful.

            1 Reply Last reply
            0
            • dheerendraD Offline
              dheerendraD Offline
              dheerendra
              Qt Champions 2022
              wrote on last edited by
              #8

              Slot is called twice means that there are TWO connects executed. By looking your tries, you are making the multiple connects with two different objects.

              Either you are connecting the twice or creating two objects of ClassOne some how.

              Inside the slot use the sender() API to get which object is sending the signal. May be you can print the address of the object returned by the sender or try to use the object name. This will give the source of the problem.

              Dheerendra
              @Community Service
              Certified Qt Specialist
              http://www.pthinks.com

              1 Reply Last reply
              3
              • B Offline
                B Offline
                bsomervi
                wrote on last edited by
                #9
                class ClassOne {
                    // ...
                private:
                    // ...
                    QNetworkReply * reply_ptr;
                    // ...
                };
                
                void ClassOne::checkUser{
                // connect(networkMgr, SIGNAL(finished(QNetworkReply*)), this, SLOT(onFinishValid(QNetworkReply*)));
                reply_ptr = networkMgr->post(request, datatoSend);
                connect(reply_ptr, &QNetworkReply::finished, this, &ClassOne::onFinshValid);
                
                void ClassOne::haveData() {
                    QString data {reply_ptr->readAll()};
                    ...
                        if(true){
                             ...some code
                         showMessage("Login OK! Sending file!")
                         sendFile();
                       } else{
                           showMessage("Login fail")
                        } 
                         reply_ptr->deleteLater();
                }
                
                //Class 2
                class ClassTwo {
                    // ...
                private:
                    // ...
                    QNetworkReply * reply_ptr;
                    // ...
                };
                
                ClassTwo::sendFile(){
                    // connect(mpNetworkMgr, SIGNAL(finished(QNetworkReply*)), this, SLOT(onFinish(QNetworkReply*)));  //Other slot
                    reply_ptr = networkMgr->post(request, datatoSend);
                    connect(reply_ptr, &QNetworkReply::finished, this, &ClassTwo::onFinish);
                }
                
                ClassTwo::onFinish(){
                
                     reply_ptr->deleteLater();
                }
                
                H 1 Reply Last reply
                0
                • B bsomervi
                  class ClassOne {
                      // ...
                  private:
                      // ...
                      QNetworkReply * reply_ptr;
                      // ...
                  };
                  
                  void ClassOne::checkUser{
                  // connect(networkMgr, SIGNAL(finished(QNetworkReply*)), this, SLOT(onFinishValid(QNetworkReply*)));
                  reply_ptr = networkMgr->post(request, datatoSend);
                  connect(reply_ptr, &QNetworkReply::finished, this, &ClassOne::onFinshValid);
                  
                  void ClassOne::haveData() {
                      QString data {reply_ptr->readAll()};
                      ...
                          if(true){
                               ...some code
                           showMessage("Login OK! Sending file!")
                           sendFile();
                         } else{
                             showMessage("Login fail")
                          } 
                           reply_ptr->deleteLater();
                  }
                  
                  //Class 2
                  class ClassTwo {
                      // ...
                  private:
                      // ...
                      QNetworkReply * reply_ptr;
                      // ...
                  };
                  
                  ClassTwo::sendFile(){
                      // connect(mpNetworkMgr, SIGNAL(finished(QNetworkReply*)), this, SLOT(onFinish(QNetworkReply*)));  //Other slot
                      reply_ptr = networkMgr->post(request, datatoSend);
                      connect(reply_ptr, &QNetworkReply::finished, this, &ClassTwo::onFinish);
                  }
                  
                  ClassTwo::onFinish(){
                  
                       reply_ptr->deleteLater();
                  }
                  
                  H Offline
                  H Offline
                  Helson
                  wrote on last edited by
                  #10

                  @bsomervi
                  Hello again!

                  When I try in this way the slot is never called:

                  reply_ptr = networkMgr->post(request, datatoSend);
                  connect(reply_ptr, &QNetworkReply::finished, this, &ClassTwo::onFinish)
                  

                  I try too

                  connect(reply_ptr, &QNetworkReply::finished(), this, &ClassTwo::onFinish())
                  

                  and

                  connect(reply_ptr, finished(QNetworkReply*), this, (onFinish(QNetworkReply*)))
                  

                  But nothing happen.

                  What I'm doing wrong?

                  1 Reply Last reply
                  0
                  • SGaistS Offline
                    SGaistS Offline
                    SGaist
                    Lifetime Qt Champion
                    wrote on last edited by
                    #11

                    Silly question: are you sure the request is sent ? You should also connect the error signal

                    Interested in AI ? www.idiap.ch
                    Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

                    1 Reply Last reply
                    2
                    • dheerendraD Offline
                      dheerendraD Offline
                      dheerendra
                      Qt Champions 2022
                      wrote on last edited by
                      #12

                      Can you share the complete code for us to check ? It helps us to quickly help you.

                      Dheerendra
                      @Community Service
                      Certified Qt Specialist
                      http://www.pthinks.com

                      1 Reply Last reply
                      3
                      • H Offline
                        H Offline
                        Helson
                        wrote on last edited by Helson
                        #13
                        void ClassOne::init(){
                             mpNetworkMgr = new QNetworkAccessManager(this);
                        }
                        
                        void ClassOne::sendFile(){
                        
                        	        QString data;
                                    QByteArray datatoSend;
                        			
                        			data = ...
                        
                        			datatoSend = data.toAscii();
                        
                        			webServHost = settings->addressWebServiceHost();
                        			addressWebServUpload = settings->addressWebServiceUpload();	
                                    QNetworkRequest request(QUrl(QString(addressWebServUpload).toAscii().constData()));
                        			
                                    request.setHeader(QNetworkRequest::ContentLengthHeader, datatoSend.size());
                        			request.setRawHeader("SOAPAction","");
                        			request.setRawHeader("...");
                        
                                    // Send the file
                                    mpNetworkMgr->post(request, datatoSend);
                                }
                        	}
                        }
                        
                        void ClassOne::validateUser(QString username, QString password){
                        			
                                    QString data;
                                    QByteArray datatoSend;
                        
                        			data = "...";		
                        				
                                    request.setHeader(QNetworkRequest::ContentLengthHeader, datatoSend.size());
                        			request.setRawHeader("SOAPAction","");
                        			request.setRawHeader("Content-Type", "text/xml; charset=UTF-8");					
                        			request.setRawHeader("Host", webServHost.toAscii());
                                    request.setRawHeader("Accept", "*/*");
                                    request.setRawHeader("Accept-Language", "pt-BR,pt;q=0.8,en-US;q=0.6,en;q=0.4");
                        
                        			connect(mpNetworkMgr, SIGNAL(finished(QNetworkReply*)), this, SLOT(onFinishedValidation(QNetworkReply*)));
                                    mpNetworkMgr->post(request, datatoSend);
                        }
                        
                        void ClassOne::onFinishedValidation(QNetworkReply *reply){
                         	QString data = (QString) reply->readAll();
                        	QString result;
                        	QXmlStreamReader xml(data);
                        
                        	reply->deleteLater();
                        
                        	while(!xml.atEnd()){
                        	xml.readNextStartElement();
                        		if(xml.name() == "test" && !xml.isEndElement()){
                        			result = xml.readElementText();		
                        		}
                        	}
                        
                        	if(result == "true"){
                        		UBApplication::showMessage(tr("Login OK"));
                        		UBApplication::showMessage(tr("Sending FILE...!"));		
                        		sendFile();
                        	} else {
                        		UBApplication::showMessage(tr("Failed to login"));
                        	}    
                        	reply->deleteLater();
                        }
                        
                        void ClassOne::onFinished(QNetworkReply *reply2)
                        { 	
                        	reply2->deleteLater();
                        }
                        
                        void ClassOne::publish()
                        {
                            UBPublicationLoginSigeuDlg dlg;
                            if(QDialog::Accepted == dlg.exec())
                            {
                                mUsername = dlg.login();
                                mPassword = dlg.password();
                                validateUser(mUsername, mPassword);			
                            }
                        }
                        
                        
                        
                        ###############
                        
                        class ClassOne : public QObject
                        {
                            Q_OBJECT;
                        
                        public:
                            explicit ClassOne();
                            virtual ~ClassOne();
                        
                            void publish();
                        	
                        private slots:
                        	void onFinished(QNetworkReply* reply2);
                            void onFinishedValidation(QNetworkReply* reply);
                        
                        private:
                            void init();
                            void sendFile();
                        	void validateUser(QString username, QString password);
                           
                            QNetworkAccessManager* mpNetworkMgr;
                            QString mUsername;
                            QString mPassword;
                        	QString webServHost;
                        
                        
                        };
                        

                        Then I call the publish() method.
                        Remember, If I use a different "QNetworkAccessManager", the slot onFinishedValidation() executes only one time.

                        My best regards.

                        1 Reply Last reply
                        0

                        • Login

                        • Login or register to search.
                        • First post
                          Last post
                        0
                        • Categories
                        • Recent
                        • Tags
                        • Popular
                        • Users
                        • Groups
                        • Search
                        • Get Qt Extensions
                        • Unsolved