FP_HTTP_SET_CONNECTION

HTTP 연결용 서버 설정

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

파라미터

입력

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=HTTP.pidsx.com'

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

    키워드: 'PORT'

    구문: 'PORT=xxxxx'

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

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

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

    키워드:

    • SSL: SSL3/TLS1 사용

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

예:
  1. 다음 SSL3/TLS1 인증을 사용하여 IP 어드레스 192.255.2.10, 포트 번호 80으로 HTTP 서버 번호 0에 연결합니다. 'SV0,IPv4=192.255.2.10,PORT=80,SSL'

  2. 다음 SSL3/TLS1 인증을 사용하여 IP 어드레스 1111:1222::1555:0:0:1888, 포트 번호 8080으로 HTTP 서버 번호 1에 연결합니다. 'SV1,IPv6=1111:1222::1555:0:0:1888,PORT=8080,SSL'

  3. 호스트 이름 HTTP.pidsx.com, 포트 번호 80, 패시브 오픈 방식으로 HTTP 서버 번호 2에 연결합니다. 다음 인증을 사용하지 않습니다. 'SV2,HOST=HTTP.pidsx.com,PORT=80,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. 사용자 이름을 "Support"로 설정합니다. 암호를 변경하지 마십시오. 'user=Support'

  4. 사용자 이름 및 암호 삭제: 'USER=,PASS='
  5. 사용자 이름과 암호를 기본값으로 초기화: 'INITIAL'

  6. 현재 사용자 이름 및 암호 유지: '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을 초과하지 않아야 합니다.

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

  • 키워드의 순서를 변경하지 않음. 키워드와 설정 파라미터를 여기에 나열된 순서대로 지정하십시오.

  • 파라미터 구문의 일부를 생략할 수 있습니다. 파라미터가 부분적으로 생략되어도 설정은 변경되지 않습니다.

  • 지정된 키워드 부분을 생략할 경우 키워드만 생략하고 쉼표는 생략합니다. ',RTRY=25,RTTM=3000'.

  • 지정된 키워드 에 있는 부분을 생략할 경우 쉼표 ","와 키워드는 생략합니다. 'TOUT=30,RTRY=25'.

  • 같은 키워드를 2회 이상 지정하지 않음. 같은 키워드를 2회 이상 지정하면 에러가 발생합니다.

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

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

  • 지정된 전송 설정에 대한 전송 요청 플래그가 "FALSE: 전송 요청 없음"인 경우에만 이 명령이 실행됩니다. 전송 요청 플래그가 "TRUE: 전송 요청됨"이면, 연산 에러가 발생합니다.

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

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

에러 플래그

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

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

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

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

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

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

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

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

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

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

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

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

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

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

POU 헤더

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

	VAR
		bSetConnectionError: BOOL:=FALSE;
		bSetConnection: BOOL:=FALSE;
		wErrorCode: WORD:=0;
		bSetConnectionOK: 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 := 10 ;
        NETWORK_BODY
B(B_VARIN,,'SV1~IPv4=192.255.2.10~PORT=21~OPEN=act~SSL',20,6,22,8,);
B(B_VARIN,,'USER=root~PASS=passwd',20,7,22,9,);
B(B_VARIN,,'TOUT=30~RTRY=2~RTTM=500',20,8,22,10,);
B(B_CONTACT,,bSetConnection,4,1,6,3,R);
B(B_VAROUT,,bSetConnectionError,36,6,38,8,);
B(B_CONTACT,,sys_bIsEthernetInitializing,17,1,19,3,N);
B(B_F,FP_HTTP_SET_CONNECTION!,,22,4,36,10,,?DEN?DsServer?DsLogin?DsCommunication?AENO?CbError);
L(1,2,4,2);
L(6,2,17,2);
L(19,2,19,6);
L(19,6,22,6);
L(1,0,1,10);
        END_NETWORK_BODY
    END_NET_WORK
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 4 ;
        NETWORK_BODY
B(B_CONTACT,,bSetConnectionError,4,1,6,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(6,2,25,2);
L(1,2,4,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,,bSetConnectionError,4,1,6,3,N);
B(B_COIL,,bSetConnectionOK,28,1,30,3,);
L(6,2,28,2);
L(1,2,4,2);
L(1,0,1,3);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

ST 본문

If DF(bSetConnection) AND NOT sys_bIsEthernetInitializing then
    FP_HTTP_SET_CONNECTION(sServer := 'SV1,IPv4=192.255.2.10,PORT=21,OPEN=act,SSL',
                           sLogin := 'USER=root,PASS=passwd',
                           sCommunication := 'TOUT=30,RTRY=2,RTTM=500', 
                           bError => bSetConnectionError);
End_if;
If (bSetConnectionError) then
    wErrorCode := sys_iEthernetConnectionErrorCode;
Else
    bSetConnectionOK := True;   
End_if;

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