FP_FTP_SET_CONNECTION

FTP 연결용 서버 설정

이 FP 명령은 지정된 파라미터에 따라 CPU에서 지정된 FTP 클라이언트에 대한 연결에 필요한 서버 설정을 정의합니다.

파라미터

입력

sServer (STRING)
  • 서버 어드레스(필수 파라미터)

    키워드: SV

    값: SV0–SV3 (Server 0–Server 3)

  • IP 어드레스 혹은 호스트명(필수 파라미터).

    • IP 어드레스

      IP 어드레스의 경우, 처음에 IPv4 또는 IPv6 키워드를 지정합니다.

      IPv4 구문: 예, 'IPv4=111.122.133.144'

      IPv6 구문: 예, 'IPv6=1111:122:2:1555:0:0:1888'

      IPv4 어드레스의 범위 제한을 기록해 주십시오. 명령과 함께 잘못된 IP 어드레스가 지정되면 작동 에러는 없지만 출력 bErrorTRUE로 설정됩니다.

    • 호스트 명

      키워드: HOST

      구문: 예: 'HOST=FTP.pidsx.com'

  • 포트 번호 (옵션 파라미터)

    키워드: 'PORT'

    구문: 'PORT=xxxxx'

    값: 1–65535(기본값: 21)

  • 오픈 방식(옵션 파라미터)

    키워드: OPEN

    구문: 'OPEN=xxxx'

    값: act(액티브), pasv(패시브)(기본값: act)

  • SSL3/TSL1 인증(옵션 파라미터)

    SSL3/TSL1 인증 사용 여부를 지정합니다.

    키워드:

    • SSL: SSL3/TLS1 사용

    • NON: SSL3/TLS1 사용하지 않음(기본)

예:
  1. 다음 SSL3/TLS1 인증을 사용하여 IP 어드레스 192.255.2.10, 포트 번호 21, 액티브 오픈 방식으로 FTP 서버 번호 0에 연결합니다. 'SV0,IPv4=192.255.2.10,PORT=21,OPEN=act,SSL'

  2. 다음 SSL3/TLS1 인증을 사용하여 IP 어드레스 1111:1222::1555:0:0:1888, 포트 번호 생략(기본 포트 21 사용), 오픈 방식 생략(기본값 사용=액티브)으로 FTP 서버 번호 1에 연결합니다. 'SV1,IPv6=1111:1222::1555:0:0:1888,SSL'

  3. 호스트 이름 FTP.pidsx.com, 포트 번호 28, 패시브 오픈 방식으로 FTP 서버 번호 2에 연결합니다. 다음 인증을 사용하지 않습니다. 'SV2,HOST=FTP.pidsx.com,PORT=28,OPEN=pasv,NON'

sLogin (STRING)

로그인 데이터를 설정합니다

  • 유저명(최대 32자)

    키워드: USER

    구문: 'USER=xxx'(기본값: root). 'USER='를 사용하여 사용자 이름을 삭제합니다.

  • 패스워드(대소문자 허용(최대 32자))

    키워드: PASS

    구문: 'PASS=passwd'(기본값: root). 'PASS='를 사용하여 암호를 삭제합니다.

이 파라미터의 경우, 사용할 수 있는 두 개의 추가 키워드가 있습니다.
  • INITIAL: 사용자 이름과 암호를 기본 설정 "root" 및 "root"로 초기화합니다.

  • KEEP: 현재 로그인 설정을 유지합니다.

예:

  1. 사용자 이름을 "Admin"로, 암호를 "Panasonic"로 설정: 'USER=Admin,PASS=Panasonic'

  2. 사용자 이름을 "Supervisor"로 설정하고 암호 삭제: 'USER=Supervisor,PASS='

  3. 사용자 이름 및 암호 삭제: 'USER=,PASS='

  4. 사용자 이름과 암호를 기본값으로 초기화: 'INITIAL'

  5. 현재 사용자 이름 및 암호 유지: 'KEEP'

sCommunication (STRING)

필요에 따라 선택적 통신 파라미터를 설정합니다.

  • 연결 타임아웃

    키워드: TOUT

    구문: 'TOUT=xxx'(기본값: 60초)

    값: 30-300초

  • 재시도 횟수

    키워드: RTRY

    구문: 'RTRY=x' (기본: 3회)

    값: 0-3

  • 재시도 주기

    키워드: RTTM

    구문: 'RTTM=xxxxx'(기본값: 600초)

    값: 10-86400초

    10초 단위로 값을 지정할 수 있습니다. 10 단위로 내림 처리됩니다.

    예: 38초를 지정하면 30초가 설정됩니다.

이 파라미터의 경우, 사용할 수 있는 두 개의 추가 키워드가 있습니다.

  • INITIAL: 연결 타임아웃, 재시도 횟수 및 재시도 간격을 기본 설정으로 초기화합니다.

  • KEEP: 현재 통신 설정을 유지합니다.

예:

  1. 연결 타임아웃 설정: 30초, 재시도 횟수: 2, 재시도 간격: 500초: 'TOUT=30,RTRY=2,RTTM=500'

  2. 연결 타임아웃 설정: 270초, 재시도 없음, 재시도 간격: 4900초: 'TOUT=270,RTRY=0,RTTM=4900'

  3. 연결 타임아웃 설정: 30초, 재시도 횟수: 25, 재시도 간격: 변경 안 함: 'TOUT=30,RTRY=25'

  4. 연결 타임아웃 설정: 변경 안 함, 재시도 횟수: 25, 재시도 간격: 3000초: ',RTRY=25,RTTM=3000'

  5. 기본 설정으로 초기화(연결 타임아웃: 60초, 재시도 횟수: 3, 재시도 간격: 600초): 'INITIAL'

  6. 모든 현재 설정 그대로 유지: 'KEEP'

출력

bError (BOOL)

다음 조건에서 TRUE로 전환:

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

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

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

주석

  • 모든 키워드 엔트리는 콤마로 구분됩니다(예: 'NAME=abcd,FROM=sender@server.com').

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

  • 인터럽트 프로그램에서는 이 명령을 사용할 수 없습니다.

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

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

  • 지정된 전송 설정 또는 지정된 nLogID 번호에 대한 전송 요청 플래그가 FALSE인 경우에만 명령을 실행할 수 있습니다. 전송 요청 플래그가 TRUE인 경우 연산 에러가 발생합니다.

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

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

에러 플래그

sys_bIsOperationErrorHold(TRUE로 전환되어 TRUE로 유지됨)
  • 파라미터에 지정된 값이 허용 범위를 벗어난 경우.

  • 동일한 키워드가 두 번 이상 지정된 경우

  • 명령이 실행될 때 지정된 전송 설정에 대한 전송 요청 플래그가 "TRUE: 전송 요청됨"인 경우

  • 지정된 nLogID 번호에 대한 전송 요청 플래그가 TRUE인 경우(예: sys_blsLog0DataRecordingActiveTRUE인 경우)

  • 서버 번호가 오름차순으로 지정되지 않은 경우

  • 명령을 인터럽트 프로그램에서 실행한 경우.

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

sys_bIsOperationErrorNonHold(스캔 1회에 대해 TRUE로 전환)
  • 파라미터에 지정된 값이 허용 범위를 벗어난 경우.

  • 동일한 키워드가 두 번 이상 지정된 경우

  • 명령이 실행될 때 지정된 전송 설정에 대한 전송 요청 플래그가 "TRUE: 전송 요청됨"인 경우

  • 지정된 nLogID 번호에 대한 전송 요청 플래그가 TRUE인 경우(예: sys_blsLog0DataRecordingActiveTRUE인 경우)

  • 서버 번호가 오름차순으로 지정되지 않은 경우

  • 명령을 인터럽트 프로그램에서 실행한 경우.

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

sys_bIsCarry(스캔 1회에 대해 TRUE로 전환)
  • 잘못된 IP 어드레스로 명령을 실행하면 sys_iEthernetConnectionErrorCode가 "1: 잘못된 IP 어드레스가 지정됨"으로 설정됩니다.

  • 이더넷 초기화 중에 명령이 실행되면 sys_iEthernetConnectionErrorCode가 "11: 이더넷이 초기화 중입니다"

POU 헤더

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

	VAR
		bError: BOOL:=FALSE;
		wErrorCode: WORD:=0;
		bSetConnectionOK: BOOL:=FALSE;
		bSetConnectionError: BOOL:=FALSE;
		bSetConnection: BOOL:=FALSE;
	END_VAR

POU 본문

bSetConnectionFALSE에서 TRUE로 변경되고 sys_bIsEthernetInitializingFALSE면 명령이 실행됩니다.

LD 본문

BODY
    WORKSPACE
        NETWORK_LIST_TYPE := NWTYPELD ;
        ACTIVE_NETWORK := 0 ;
    END_WORKSPACE
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 9 ;
        NETWORK_BODY
B(B_CONTACT,,bSetConnection,5,1,7,3,R);
B(B_CONTACT,,sys_bIsEthernetInitializing,16,1,18,3,N);
B(B_VARIN,,'SV0~IPv4=192.168.178.64~PORT=21~OPEN=pasv~NON',21,5,23,7,);
B(B_VARIN,,'USER=user~PASS=user',21,6,23,8,);
B(B_VARIN,,'TOUT=30~RTRY=0~RTTM=120',21,7,23,9,);
B(B_VAROUT,,bSetConnectionError,36,5,38,7,);
B(B_F,FP_FTP_SET_CONNECTION!,,23,3,36,9,,?DEN?DsServer?DsLogin?DsCommunication?AENO?CbError);
L(7,2,16,2);
L(1,2,5,2);
L(18,2,18,5);
L(18,5,23,5);
L(1,0,1,9);
        END_NETWORK_BODY
    END_NET_WORK
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 4 ;
        NETWORK_BODY
B(B_CONTACT,,bSetConnectionError,6,1,8,3,);
B(B_F,E_MOVE!,,25,0,31,4,,?DEN?D?AENO?C);
B(B_VARIN,,sys_iEthernetConnectionErrorCode,23,2,25,4,);
B(B_VAROUT,,wErrorCode,31,2,33,4,);
L(8,2,25,2);
L(1,2,6,2);
L(1,0,1,4);
        END_NETWORK_BODY
    END_NET_WORK
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 3 ;
        NETWORK_BODY
B(B_CONTACT,,bError,6,1,8,3,N);
B(B_COIL,,bSetConnectionOK,28,1,30,3,);
L(8,2,28,2);
L(1,2,6,2);
L(1,0,1,3);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

ST 본문

If DF(bSetConnection) AND NOT sys_bIsEthernetInitializing then
    FP_FTP_SET_CONNECTION(sServer := 'SV0,IPv4=192.168.178.64,PORT=21,OPEN=pasv,NON',
                          sLogin := 'USER=user,PASS=user',
                          sCommunication := 'TOUT=30,RTRY=0,RTTM=120', 
                    bError => bSetConnectionError);
End_if;
If (bSetConnectionError) then
    wErrorCode := sys_iEthernetConnectionErrorCode;
End_if;
If NOT bError then
    bSetConnectionOK := TRUE;
End_if;

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