HTTP 연결용 서버 설정
이 FP 명령은 지정된 파라미터에 따라 CPU에서 지정된 HTTP 클라이언트에 대한 연결에 필요한 서버 설정을 정의합니다.
입력
서버 어드레스(필수 파라미터)
키워드: 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 어드레스가 지정되면 작동 에러는 없지만 출력 bError가 TRUE로 설정됩니다.
호스트 명
키워드: HOST
구문: 예: 'HOST=HTTP.pidsx.com'
포트 번호 (옵션 파라미터)
키워드: 'PORT'
구문: 'PORT=xxxxx'
값: 1–65535(기본값: 80)
SSL3/TSL1 인증(옵션 파라미터)
SSL3/TSL1 인증 사용 여부를 지정합니다.
키워드:
SSL
: SSL3/TLS1 사용
NON
: SSL3/TLS1 사용하지 않음(기본)
다음 SSL3/TLS1 인증을 사용하여 IP 어드레스 192.255.2.10, 포트 번호 80으로 HTTP 서버 번호 0에 연결합니다. 'SV0,IPv4=192.255.2.10,PORT=80,SSL'
다음 SSL3/TLS1 인증을 사용하여 IP 어드레스 1111:1222::1555:0:0:1888, 포트 번호 8080으로 HTTP 서버 번호 1에 연결합니다. 'SV1,IPv6=1111:1222::1555:0:0:1888,PORT=8080,SSL'
호스트 이름 HTTP.pidsx.com, 포트 번호 80, 패시브 오픈 방식으로 HTTP 서버 번호 2에 연결합니다. 다음 인증을 사용하지 않습니다. 'SV2,HOST=HTTP.pidsx.com,PORT=80,NON'
로그인 데이터를 설정합니다
유저명 (최대 32자)
키워드: USER
'USER=xxx'
(기본값: root). 'USER='
를 사용하여 사용자 이름을 삭제합니다.패스워드(대소문자 허용(최대 32자))
키워드: PASS
구문: 'PASS=passwd'
(기본값: root). 'PASS='
를 사용하여 암호를 삭제합니다.
INITIAL
: 사용자 이름과 암호를 기본 설정 "root" 및 "root"로 초기화합니다.
KEEP
: 현재 로그인 설정을 유지합니다.예:
사용자 이름을 "Admin"로, 암호를 "Panasonic"로 설정: 'USER=Admin,PASS=Panasonic'
사용자 이름을 "Supervisor"로 설정하고 암호 삭제: 'USER=Supervisor,PASS='
사용자 이름을 "Support"로 설정합니다. 암호를 변경하지 마십시오. 'user=Support'
'USER=,PASS='
사용자 이름과 암호를 기본값으로 초기화: 'INITIAL'
'KEEP'
필요에 따라 선택적 통신 파라미터를 설정합니다.
연결 타임아웃
키워드: TOUT
구문:'TOUT=xxx'
(기본값: 60초)
값: 30-300초
재시도 횟수
키워드: RTRY
구문: 'RTRY=x'
(기본: 3회)
값: 0-3
재시도 주기
키워드: RTTM
구문: 'RTTM=xxxxx'
(기본값: 600초)
값: 10-86400초
10초 단위로 값을 지정할 수 있습니다. 10 단위로 내림 처리됩니다. 예: 38초를 지정하면 30초가 설정됩니다.
이 파라미터의 경우, 사용할 수 있는 두 개의 추가 키워드가 있습니다.
INITIAL
: 연결 타임아웃, 재시도 횟수 및 재시도 간격을 기본 설정으로 초기화합니다.
KEEP
: 현재 통신 설정을 유지합니다.
예:
연결 타임아웃 설정: 30초, 재시도 횟수: 2, 재시도 간격: 500초: 'TOUT=30,RTRY=2,RTTM=500'
연결 타임아웃 설정: 270초, 재시도 없음, 재시도 간격: 4900초: 'TOUT=270,RTRY=0,RTTM=4900'
연결 타임아웃 설정: 30초, 재시도 횟수: 25, 재시도 간격: 변경 안 함: 'TOUT=30,RTRY=25'
연결 타임아웃 설정: 변경 안 함, 재시도 횟수: 25, 재시도 간격: 3000초: ',RTRY=25,RTTM=3000'
기본 설정으로 초기화(연결 타임아웃: 60초, 재시도 횟수: 3, 재시도 간격: 600초): 'INITIAL'
모든 현재 설정 그대로 유지: 'KEEP'
출력
다음 조건에서 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_bIsEthernetInitializing이 FALSE인지 확인하십시오. 명령이 실행되면 sys_bIsEthernetInitializing이 TRUE로 전환됩니다. sys_bIsEthernetInitializing이 TRUE일 때 명령을 실행하면 에러가 발생합니다.
지정된 전송 설정에 대한 전송 요청 플래그가 "FALSE: 전송 요청 없음"인 경우에만 이 명령이 실행됩니다. 전송 요청 플래그가 "TRUE: 전송 요청됨"이면, 연산 에러가 발생합니다.
이 명령이 성공적으로 실행되면 시스템 변수 sys_bIsCarry 및 sys_iEthernetConnectionErrorCode가 초기화됩니다.
에러가 발생하면 시스템 변수 sys_iEthernetConnectionErrorCode에서 에러 코드 번호를 확인하십시오.
파라미터에 지정된 값이 허용 범위를 벗어난 경우.
동일한 키워드가 두 번 이상 지정된 경우
명령이 실행될 때 지정된 전송 설정에 대한 전송 요청 플래그가 "TRUE: 전송 요청됨"인 경우
서버 번호가 오름차순으로 지정되지 않은 경우
명령을 인터럽트 프로그램에서 실행한 경우.
문자열 데이터의 문자 수가 256자 이상인 경우.
파라미터에 지정된 값이 허용 범위를 벗어난 경우.
동일한 키워드가 두 번 이상 지정된 경우
명령이 실행될 때 지정된 전송 설정에 대한 전송 요청 플래그가 "TRUE: 전송 요청됨"인 경우
서버 번호가 오름차순으로 지정되지 않은 경우
명령을 인터럽트 프로그램에서 실행한 경우.
문자열 데이터의 문자 수가 256자 이상인 경우.
잘못된 IP 어드레스로 명령을 실행하면 sys_iEthernetConnectionErrorCode가 "1: 잘못된 IP 어드레스가 지정됨"으로 설정됩니다.
이더넷 초기화 중에 명령이 실행되면 sys_iEthernetConnectionErrorCode가 "11: 이더넷이 초기화 중입니다"
이 펑션 프로그램 시 사용한 모든 입력과 출력 변수는 POU 헤더에서 선언되었습니다. 모든 프로그래밍 언어에 같은 POU 헤더를 사용합니다.
VAR
bSetConnectionError: BOOL:=FALSE;
bSetConnection: BOOL:=FALSE;
wErrorCode: WORD:=0;
bSetConnectionOK: BOOL:=FALSE;
END_VAR
bSetConnection이 FALSE에서 TRUE로 변경되고 sys_bIsEthernetInitializing이 FALSE면 명령이 실행됩니다.
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
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;