FP_SMTP_TRANSFER_CONTROL_LOG

데이터 로깅 파일의 SMTP 전송 제어

이 FP 명령은 nLogID에서 지정한 데이터 로깅 파일의 SMTP 전송을 제어합니다. 유효한 제어 워드는 'ENABLE', 'DISABLE''CANCEL'입니다.

파라미터

입력

nLogID (WORD, INT, UINT)

LOG 번호( 0–15). 컴파일러는 내부적으로 로그 파일 번호의 문자열(예: 'LOG=0')을 생성합니다.

sControl (STRING)

제어 문자열:

  • 'ENABLE': 파일 전송을 활성화합니다.

  • 'DISABLE': 파일 전송을 비활성화합니다.

  • 'CANCEL': 파일 전송을 취소합니다.

출력

bError (BOOL)

다음 조건에서 TRUE로 전환:

  • 연결 타임아웃 시간을 초과한 경우

  • IP 어드레스가 유효하지 않을 경우

에러가 발생하면 시스템 변수 sys_iEthernetConnectionErrorCode에서 에러 코드 번호를 확인하십시오.

주석

  • 문자 데이터의 문자수는 256을 초과하지 않아야 합니다.

  • 명령을 실행하기 전에 FP_SMTP_SET_MODE_TRANSFER_LOG 또는 SMTP 클라이언트의 설정 다이얼로그를 사용하여 데이터 로깅 파일의 이메일 전송 설정을 지정해야 합니다.

  • 명령을 실행하기 전에 sys_bIsEthernetInitializingFALSE인지 확인하십시오. 명령이 실행되면 sys_bIsEthernetInitializingTRUE로 전환됩니다. sys_bIsEthernetInitializingTRUE일 때 명령을 실행하면 에러가 발생합니다.

  • 문자 정수를 지정할 수 있는 오퍼랜드에 대문자와 소문자를 사용할 수 있습니다. "Abcd", "ABCD", "abcd"는 모두 동의어이지만 파일 이름에서는 대/소문자를 구분합니다.

  • 이 명령이 성공적으로 실행되면 시스템 변수 sys_bIsCarrysys_iEthernetConnectionErrorCode가 초기화됩니다.

  • 전송 취소 요청을 처리하는 데 시간이 소요됩니다. FP_SMTP_GET_STATUS로 전송 상태를 확인하고 명령을 실행한 후에 전송이 중단되는지 확인합니다.

  • 에러가 발생하면 시스템 변수 sys_iEthernetConnectionErrorCode에서 에러 코드 번호를 확인하십시오.

에러 플래그

sys_bIsOperationErrorHold(TRUE로 전환되어 TRUE로 유지됨)
  • 'ENABLE' 'DISABLE' 또는 'CANCEL' 이외의 제어 문자열이 sControl에 지정된 경우.

  • 문자열 데이터의 문자 수가 256자 이상인 경우.

  • FP_SMTP_SET_MODE_TRANSFER_LOG 명령 또는 SMTP 클라이언트의 설정 다이얼로그로 정의되지 않은 데이터 로그 파일의 이메일 전송 설정이 지정된 경우.

sys_bIsOperationErrorNonHold(스캔 1회에 대해 TRUE로 전환)
  • 'ENABLE' 'DISABLE' 또는 'CANCEL' 이외의 제어 문자열이 sControl에 지정된 경우.

  • 문자열 데이터의 문자 수가 256자 이상인 경우.

  • FP_SMTP_SET_MODE 명령 또는 STMP 클라이언트의 설정 다이얼로그로 정의되지 않은 이메일 전송 설정이 지정된 경우.

  • FP_SMTP_SET_MODE_TRANSFER_LOG 명령 또는 SMTP 클라이언트의 설정 다이얼로그로 정의되지 않은 데이터 로그 파일의 이메일 전송 설정이 지정된 경우.

sys_bIsCarry(스캔 1회에 대해 TRUE로 전환)
  • 이더넷 초기화 중에 명령이 실행되면 sys_iEthernetConnectionErrorCode가 "11: 이더넷이 초기화 중입니다"

POU 헤더

이 펑션 프로그램 시 사용한 모든 입력과 출력 변수는 POU 헤더에서 선언되었습니다. 모든 프로그래밍 언어에 같은 POU 헤더를 사용합니다.

	VAR
		bIsError: BOOL:=FALSE;
		bSetLogTransferSMTP: BOOL:=FALSE;
		bDisableLogTransferSMTP: BOOL:=FALSE;
	END_VAR

POU 본문

bSetLogTransferSMTPbDisableLogTransferSMTPTRUE로 설정되면 명령이 실행됩니다.

LD 본문

BODY
    WORKSPACE
        NETWORK_LIST_TYPE := NWTYPELD ;
        ACTIVE_NETWORK := 0 ;
    END_WORKSPACE
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 7 ;
        NETWORK_BODY
B(B_VARIN,,0,19,2,21,4,);
B(B_VARIN,,'GRPNO=0~SUBJECTAUTO',19,3,21,5,);
B(B_VARIN,,'Sent Log Files',19,4,21,6,);
B(B_VARIN,,'INFO=NON~ATT=NONE',19,5,21,7,);
B(B_VAROUT,,bIsError,39,2,41,4,);
B(B_CONTACT,,bSetLogTransferSMTP,5,1,7,3,);
B(B_F,FP_SMTP_SET_MODE_TRANSFER_LOG!,,21,0,39,7,,?DEN?DnLogID?DsGroupNumber_Subject?DsBodyText?DsAttachment?AENO?AbError);
L(1,2,5,2);
L(7,2,21,2);
L(1,0,1,7);
        END_NETWORK_BODY
    END_NET_WORK
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 5 ;
        NETWORK_BODY
B(B_CONTACT,,bDisableLogTransferSMTP,5,1,7,3,);
B(B_F,FP_SMTP_TRANSFER_CONTROL_LOG!,,21,0,39,5,,?DEN?DnLogID?DsControl?AENO?AbError);
B(B_VARIN,,0,19,2,21,4,);
B(B_VARIN,,'DISABLE',19,3,21,5,);
B(B_VAROUT,,bIsError,39,2,41,4,);
L(1,2,5,2);
L(7,2,21,2);
L(1,0,1,5);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

ST 본문

If (bSetLogTransferSMTP) Then
    FP_SMTP_SET_MODE_TRANSFER_LOG(nLogID := 0,
                                  sGroupNumber_Subject := 'GRPNO=0,SUBJECTAUTO',
                                  sBodyText := 'Sent Log Files', 
								  sAttachment := 'INFO=NON,ATT=NONE', bError => bIsError);
End_if;
If (bDisableLogTransferSMTP) Then
    FP_SMTP_TRANSFER_CONTROL_LOG(nLogID := 0,
                                 sControl := 'DISABLE', bError => bIsError);
End_if;

최종 수정일: 2024-03-07이 페이지에 대한 피드백Panasonic 직통 전화