SMTP 연결용 서버 설정
이 FP 명령은 지정된 파라미터에 따라 CPU에서 지정된 SMTP 클라이언트에 대한 연결에 필요한 서버 설정을 정의합니다.
입력
이름 및 어드레스와 포트 번호 및 인증 방법을 사용하여 계정 데이터를 설정합니다.
소스 이름 (옵션 파라미터)
키워드: NAME
소스 이메일 어드레스 (필수 파라미터)
키워드: FROM
구문: 'FROM='
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=SMTP.pidsx.com'
포트 번호 (옵션 파라미터)
키워드: 'PORT'
구문: 'PORT=xxxxx'
(기본값: 25)
범위: 1-65535
SSL3/TSL1 인증(옵션 파라미터). SSL3/TSL1 인증 사용 여부를 지정합니다.
키워드:
SSL
: SSL3/TLS1 사용
NON
: SSL3/TLS1 사용하지 않음(기본)
예:
FP7_001을 소스 이름으로, pana@pana.com을 소스 이메일 어드레스로 102.244.2.110을 IP 어드레스로 각각 설정하고 포트 25와 다음 SSL3/TLS1 인증을 사용합니다. 'NAME=FP7_001,FROM=pana@pana.com,IPv4=192.255.2.10,PORT=25,SSL'
소스 이름을 그대로 유지하고sunx@sunx.com""을 소스 이메일 어드레스로, 1222::a8dd:0:0:6666을 IP 어드레스로 각각 설정하고 포트 100을 사용한 다음 SSL3/TLS1 인증을 사용합니다. ',FROM=sunx@sunx.com,IPv6=1111:1222::a8dd:0:0:6666,PORT=100,SSL'
FP7_002를 소스 이름으로, pewsunx@pewsunx.com""을 소스 이메일 어드레스로, "SMTPmailserver.com"을 호스트 이름으로 설정하고 인증 없이 포트 1000을 사용합니다. 'NAME=FP7_002,FROM=pewsunx@pewsunx.com,HOST=SMTPmailserver.com,PORT=1000,NON'
FP7_002를 소스 이름으로, pewsunx@pewsunx.com을 소스 이메일 어드레스로, "SMTPmailserver.com"을 호스트 이름으로 설정합니다. 포트 번호 및 인증에 대한 설정을 변경하지 마십시오. 'NAME=FP7_002,FROM=pewsunx@pewsunx.com,HOST=SMTPmailserver.com'
로그인 데이터를 설정합니다
SMTP 인증 수단(키워드 필요)
키워드:
CRAM: CRAM-MD5가 사용됩니다.
PLAIN1 PLAIN1 (ID/PASS)이 사용됩니다
PLAIN2 PLAIN2 (ID/PASS)이 사용됩니다
LOGIN: LOGIN가 사용됩니다.
계정(최대 32자)
키워드: ACCOUNT
구문: 'ACCOUNT=xxx'
(기본: root). 'ACCOUNT='
을 사용하여 계정을 삭제합니다.
패스워드(대소문자 허용(최대 32자))
키워드: PASS
구문: 'PASS=xxx'
(기본: root). 'PASS='
를 사용하여 암호를 삭제합니다.
NOUSE
: SMTP 인증 방법에 대한 설정은 무시됩니다.
KEEP
: 현재 로그인 설정을 유지합니다.예:
CRAM-MD5를 암호가 "control"인."sunx" 계정의 SMTP 인증 방법으로 사용합니다. 'CRAM,ACCOUNT=sunx,PASS=control'
CRAM-MD5를 "root" 계정에 대한 SMTP 인증 방법으로 설정하고 암호를 삭제합니다. 'CRAM,ACCOUNT=root,PASS='
PLAIN1을 SMTP 인증 방법으로 설정하고, 계정 이름을 삭제하고, 암호 "SUNX"를 사용합니다. 'PLAIN1,ACCOUNT=,PASS=SUNX'
PLAIN2를 SMTP 인증 방법으로 설정하고 계정 이름과 암호를 삭제합니다. 'PLAIN2,ACCOUNT=,PASS='
LOGIN을 "panasonic" 계정에 대한 SMTP 인증 방법으로 설정하고 이미 설정된 암호를 유지합니다. 'PLAIN2,ACCOUNT=panasonic'
CRAM-MD5를 이미 지정된 계정 이름에 대한 SMTP 인증 방법으로 설정하고 암호 "SUNX"를 설정합니다. 'CRAM,,PASS=SUNX'
SMTP 인증 방법을 사용하지 마십시오. 계정을 사용하지 마십시오. 암호를 변경하지 마십시오. 'NOUSE'
SMTP 인증 방법, 계정 및 암호를 유지합니다. 'KEEP'
필요에 따라 선택적 통신 파라미터를 설정합니다. 기본 이메일 언어는 일본어로 설정되어 있습니다.
최대 이메일 크기
키워드: MAILSIZE
구문: 'MAILSIZE=xxx'
(기본값: 100)
범위: 1–10240KB
연결 타임아웃
키워드: TOUT
구문: 'TOUT=xxx'
(기본값: 60초)
범위: 30-300초
재시도 횟수
키워드: RTRY
구문: 'RTRY=x'
(기본: 3회)
범위: 0-3
재시도 주기
키워드: RTTM
구문: 'RTTM=xxxxx'
(기본값: 600초)
범위: 10-86400초
10초 단위로 값을 지정할 수 있습니다. 10 단위로 내림 처리됩니다.
예: 38초를 지정하면 30초가 설정됩니다.
이메일 제목 및 텍스트에 사용할 언어.
키워드:
JPN: 일본어(기본)
ENG: 영어
INITIAL
: 연결 타임아웃, 재시도 횟수 및 재시도 간격을 기본 설정으로 초기화합니다.
KEEP
: 현재 통신 설정을 유지합니다.
예:
최대 이메일 크기 설정: 1000KB, 연결 타임아웃: 30초, 재시도 횟수: 2, 재시도 간격: 500초, 이메일 언어: 일본어: 'MAILSIZE=1000,TOUT=30,RTRY=2,RTTM=500,JPN'
최대 이메일 크기 설정: 10000KB, 연결 타임아웃: 270초, 재시도 없음, 재시도 간격: 4900초, 이메일 언어: 영어: 'MAILSIZE=10000,TOUT=270,RTRY=0,RTTM=4900,ENG'
최대 이메일 크기 설정: 500KB, 연결 타임아웃: 30초, 재시도 횟수: 3, 재시도 간격: 200초, 이메일 언어:변경 안 함: 'MAILSIZE=500,TOUT=30,RTRY=3,RTTM=200'
최대 이메일 크기 설정: 5000KB, 연결 타임아웃: 변경하지 않음, 재시도 횟수: 5, 재시도 간격: 3000초, 이메일 언어: 영어: 'MAILSIZE=5000,,RTRY=5,RTTM=3000,ENG'
기본 설정으로 초기화(최대 이메일 크기: 100KB, 연결 타임아웃: 60초, 재시도 횟수: 3, 재시도 간격: 600초, 기본 이메일 언어: 일본어): 'INITIAL'
모든 현재 설정 그대로 유지: 'KEEP'
출력
다음 조건에서 TRUE로 전환:
연결 타임아웃 시간을 초과한 경우
IP 어드레스가 유효하지 않을 경우
에러가 발생하면 시스템 변수 sys_iEthernetConnectionErrorCode에서 에러 코드 번호를 확인하십시오.
모든 키워드 엔트리는 콤마로 구분됩니다(예: 'NAME=abcd,FROM=sender@server.com').
문자 데이터의 문자수는 256을 초과하지 않아야 합니다.
인터럽트 프로그램에서는 이 명령을 사용할 수 없습니다.
대소문자를 사용하여 키워드를 지정할 수 있습니다. 그러나 제목, 이메일 텍스트 및 첨부 파일 이름은 대소문자를 구분합니다.
명령을 실행하기 전에 sys_bIsEthernetInitializing이 FALSE인지 확인하십시오. 명령이 실행되면 sys_bIsEthernetInitializing이 TRUE로 전환됩니다. sys_bIsEthernetInitializing이 TRUE일 때 명령을 실행하면 에러가 발생합니다.
지정된 전송 설정 또는 지정된 nLogID 번호에 대한 전송 요청 플래그가 FALSE인 경우에만 명령을 실행할 수 있습니다. 전송 요청 플래그가 TRUE인 경우 연산 에러가 발생합니다.
이 명령이 성공적으로 실행되면 시스템 변수 sys_bIsCarry 및 sys_iEthernetConnectionErrorCode가 초기화됩니다.
에러가 발생하면 시스템 변수 sys_iEthernetConnectionErrorCode에서 에러 코드 번호를 확인하십시오.
파라미터에 지정된 값이 허용 범위를 벗어난 경우.
동일한 키워드가 두 번 이상 지정된 경우
지정된 전송 설정에 대한 이메일 전송 요청 플래그가 "TRUE: 전송 요청됨"인 경우.
지정된 nLogID 번호에 대한 전송 요청 플래그가 TRUE인 경우(예: sys_blsLog0DataRecordingActive가 TRUE인 경우)
명령을 인터럽트 프로그램에서 실행한 경우.
문자열 데이터의 문자 수가 256자 이상인 경우.
파라미터에 지정된 값이 허용 범위를 벗어난 경우.
동일한 키워드가 두 번 이상 지정된 경우
지정된 전송 설정에 대한 이메일 전송 요청 플래그가 "TRUE: 전송 요청됨"인 경우.
지정된 nLogID 번호에 대한 전송 요청 플래그가 TRUE인 경우(예: sys_blsLog0DataRecordingActive가 TRUE인 경우)
명령을 인터럽트 프로그램에서 실행한 경우.
문자열 데이터의 문자 수가 256자 이상인 경우.
잘못된 IP 어드레스로 명령을 실행하면 sys_iEthernetConnectionErrorCode가 "1: 잘못된 IP 어드레스가 지정됨"으로 설정됩니다.
이더넷 초기화 중에 명령이 실행되면 sys_iEthernetConnectionErrorCode가 "11: 이더넷이 초기화 중입니다"
이 펑션 프로그램 시 사용한 모든 입력과 출력 변수는 POU 헤더에서 선언되었습니다. 모든 프로그래밍 언어에 같은 POU 헤더를 사용합니다.
VAR
bError: BOOL:=FALSE;
bSetConnection: 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 := 12 ;
NETWORK_BODY
B(B_VARIN,,'NAME=FP7_001~FROM=pewsunx@pewsunx.com~HOST=smtpmailserver.com~PORT=1000~NON',37,6,39,8,);
B(B_VARIN,,'CRAM~ ACCOUNT=sunx~PASS=control',37,7,39,9,);
B(B_VARIN,,'MAILSIZE=1000~TOUT=30~RTRY=2~RTTM=500~ENG',37,8,39,10,);
B(B_CONTACT,,bSetConnection,4,1,6,3,R);
B(B_VAROUT,,bError,53,6,55,8,);
B(B_CONTACT,,sys_bIsEthernetInitializing,13,1,15,3,N);
B(B_F,FP_SMTP_SET_CONNECTION!,,39,4,53,10,,?DEN?DsAccount?DsLogin?DsCommunication?AENO?CbError);
L(6,2,13,2);
L(1,2,4,2);
L(15,2,15,6);
L(15,6,39,6);
L(1,0,1,12);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF DF(bSetConnection) And not sys_bIsEthernetInitializing then
FP_SMTP_SET_CONNECTION(sAccount := 'NAME=FP7_001,FROM=pewsunx@pewsunx.com,HOST=smtpmailserver.com,PORT=1000,NON',
sLogin := 'CRAM, ACCOUNT=sunx,PASS=control',
sCommunication := 'MAILSIZE=1000,TOUT=30,RTRY=2,RTTM=500,ENG',
bError => bError);
END_IF;