FP_SMTP_TRANSFER_REQUEST

SMTP-Übertragungsauftrag

Dieser FP-Befehl beauftragt den SMTP-Client, eine E-Mail zu senden und die durch nTransferID angegebenen Daten zu übertragen.

Parameter

Eingang

nTransferID (WORD, INT, UINT)

Einstellen der SMTP-Client-ID

Werte: 0–15

Ausgang

bError (BOOL)

Wird unter den folgenden Bedingungen auf TRUE gesetzt:

  • wenn eine Zeitüberschreitung der Verbindung überschritten wird,

  • wenn eine IP-Adresse ungültig ist

Wenn ein Fehler auftritt, prüfen Sie die Systemvariable sys_iEthernetConnectionErrorCode auf die Fehlercodenummer.

Anmerkungen

  • Dieser Befehl ist in Interrupt-Programmen nicht verfügbar.

  • Bevor Sie den Befehl ausführen, müssen Sie die E-Mail-Übertragungseinstellungen mit FP_SMTP_SET_MODE oder dem Einstellungsdialog des SMTP-Clients angeben.

  • Bevor Sie den Befehl ausführen, prüfen Sie, ob die Systemvariable sys_bIsEthernetSMTPClientReady TRUE ist. Wenn sie FALSE ist, wenn der Befehl ausgeführt wird, tritt ein Fehler auf.

  • Bevor Sie den Befehl ausführen, stellen Sie sicher, dass sys_bIsEthernetInitializing FALSE ist. sys_bIsEthernetInitializing wird auf TRUE gesetzt, wenn der Befehl ausgeführt wird. Wenn Sie den Befehl ausführen, während sys_bIsEthernetInitializing TRUE ist, tritt ein Fehler auf.

  • Der Befehl kann nur ausgeführt werden, wenn sys_bIsEthernetCableNotConnected FALSE ist.

  • Der Befehl kann nur ausgeführt werden, wenn der Datenübertragungsmerker für die angegebene Datenübertragungseinstellung "FALSE: Kein Datenübertragungsauftrag“ ist. Wenn der Datenübertragungsmerker "TRUE: Datenübertragung beauftragt“ ist, tritt ein Operationsfehler auf.

  • Wenn dieser Befehl erfolgreich ausgeführt wurde, werden die Systemvariablen sys_bIsCarry und sys_iEthernetConnectionErrorCode zurückgesetzt.

  • Wenn ein Fehler auftritt, prüfen Sie die Systemvariable sys_iEthernetConnectionErrorCode auf die Fehlercodenummer.

Fehleralarmmerker

sys_bIsOperationErrorHold (wird auf TRUE gesetzt und bleibt TRUE)
  • wenn der mit dem Index-Modifizierer definierte Bereich größer ist als der zulässige Bereich

  • wenn ein für einen Parameter angegebener Wert außerhalb des zulässigen Bereichs liegt.

  • wenn der Befehl in einem Interrupt-Programm ausgeführt wird.

  • wenn die Systemvariable sys_bIsEthernetSMTPClientReady FALSE ist, wenn der Befehl ausgeführt wird.

  • wenn der Anforderungsmerker für die E-Mail-Übertragung für die angegebene E-Mail-Übertragungseinstellung auf "TRUE: Übertragung angefordert" gesetzt ist.

  • wenn eine E-Mail-Datenübertragungseinstellung angegeben ist, die nicht mit dem Befehl FP_SMTP_SET_MODE oder dem Einstellungsdialog des SMTP-Clients konfiguriert wurde.

  • wenn das Senden von E-Mails deaktiviert ist, d. h. wenn der Bezeichner bIsTransmissionBlocked of FP_CLIENT_STATUS_DUT TRUE ist.

sys_bIsOperationErrorNonHold (wird für einen Zyklus auf TRUE gesetzt)
  • wenn der mit dem Index-Modifizierer definierte Bereich größer ist als der zulässige Bereich

  • wenn ein für einen Parameter angegebener Wert außerhalb des zulässigen Bereichs liegt.

  • wenn der Befehl in einem Interrupt-Programm ausgeführt wird.

  • wenn die Systemvariable sys_bIsEthernetSMTPClientReady FALSE ist, wenn der Befehl ausgeführt wird.

  • wenn der Anforderungsmerker für die E-Mail-Übertragung für die angegebene E-Mail-Übertragungseinstellung auf "TRUE: Übertragung angefordert" gesetzt ist.

  • wenn eine E-Mail-Datenübertragungseinstellung angegeben ist, die nicht mit dem Befehl FP_SMTP_SET_MODE oder dem Einstellungsdialog des SMTP-Clients konfiguriert wurde.

  • wenn das Senden von E-Mails deaktiviert ist, d. h. wenn der Bezeichner bIsTransmissionBlocked of FP_CLIENT_STATUS_DUT TRUE ist.

sys_bIsCarry (wird für einen Zyklus auf TRUE gesetzt)
  • wenn der Befehl ausgeführt wird, während das Ethernet-Kabel nicht angeschlossen ist. sys_iEthernetConnectionErrorCode wird eingestellt auf "10: Ethernet-Kabel getrennt".

  • wenn der Befehl während der Initialisierung des Ethernets ausgeführt wird, wird sys_iEthernetConnectionErrorCode auf "11: Ethernet wird initialisiert“ gesetzt.

Beispiel

POE-Kopf

Im POE-Kopf werden alle Ein- und Ausgangsvariablen deklariert, die für die Programmierung dieser Funktion verwendet werden. Für alle Programmiersprachen wird der gleiche POE-Kopf verwendet.

	VAR
		iID10: INT:=10;
		bTransferRequestError: BOOL:=FALSE;
		bTransferRequest: BOOL:=FALSE;
	END_VAR

POE-Rumpf

Wenn bTransferRequest von FALSE auf TRUE gesetzt wird und die Systemvariable sys_bIsEthernetSMTPClientReady auf TRUE gesetzt ist, wird der Befehl ausgeführt. Die SMTP-Datenübertragung wird für das Ethernet-Modul 10 beauftragt.

KOP-Rumpf

BODY
    WORKSPACE
        NETWORK_LIST_TYPE := NWTYPELD ;
        ACTIVE_NETWORK := 0 ;
    END_WORKSPACE
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 4 ;
        NETWORK_BODY
B(B_CONTACT,,bTransferRequest,4,1,6,3,R);
B(B_VARIN,,iID10,23,2,25,4,);
B(B_VAROUT,,bTransferRequestError,40,2,42,4,);
B(B_F,FP_SMTP_TRANSFER_REQUEST!,,25,0,40,4,,?DEN?DnID?AENO?CbError);
B(B_CONTACT,,sys_bIsEthernetSMTPClientReady,15,1,17,3,);
L(1,2,4,2);
L(6,2,15,2);
L(17,2,25,2);
L(1,0,1,4);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

ST-Rumpf

if DF(bTransferRequest) AND sys_bIsEthernetSMTPClientReady then
    FP_SMTP_TRANSFER_REQUEST(nTransferID := iID10,
                            bError => bTransferRequestError);
End_if;

Letzte Änderung: 2024-07-16Feedback zu dieser SeitePanasonic Hotline