자료 참고 안내 1. 본 자료실의 모든 자료 저작권은 ㈜에이치앤에스에 있습니다.

본 자료는 개발하시는데 참고자료 용도로 사용하실 수 있으며 저작권 표시 없이 복사,게재, 출판 하실 수 없습니다. 외부 게재 사용 시 반드시 출처 항목에 회사명과 사이트 주소를 반드시 명시해 주시기 바랍니다.
[표기 예] 출처 : ㈜에이치앤에스(www.hnsts.co.kr) 또는 ㈜HNS(www.hnsts.co.kr)

2. 제품 개발 시 내용과 예제 코드는 수정 및 검증작업을 직접 하셔야 하며 문제 발생에 대한 책임은 ㈜HNS사와 무관합니다.

본사는 자료를 최신내용으로 유지하기 위해 노력하고 있으며 제공되는 정보의 오류 및 내용이 정확하지 않을 경우 사전 공지 없이 업데이트 될 수 있습니다. 자료의 문제점 발견 시 본사로 문의주시면 검토하여 자료를 수정하도록 하겠습니다.

[C#, VB.NET] TCP/IP통신에서 송/수신 시 수신측 이벤트에서 데이터 단편화(Fragmentation)발생 원인과 해결방법
작성일 2019-03-21 수정일 2019-03-21 조회수 373
분류 SmartX Framework
적용
플랫폼
키워드 TCP/IP통신, 데이터 단편화(Fragmentation)
첨부파일 Tech73_TcpIp통신단편화예제.zip

TCP/IP통신에서 대량의 데이터를 연속으로 송/수신하는 경우 수신 측 이벤트(OnReceive Handler)에서 데이터의 단편화 (Fragmentation)현상이 발생합니다. 즉, 송신 측에서 보낸 데이터와 수신 측에서 받은 데이터의 총 사이즈를 비교하면 동일하지만 수신 이벤트에서 단편화(Fragmentation)가 발생하여 매회 수신되는 데이터의 사이즈는 다르게 됩니다. 이를 해결하기 위해서는 수신된 데이터의 패킷을 Frame화 할 수 있는 별도의 처리가 필요합니다. HNS에서는 송/수신 시 STX(시작구분코드)와 ETX(마감구분코드) 사용하여 패킷을 프레임화하고 데이터 길이와 CRC32를 사용하여 에러 체크를 수행합니다.

본 문서는
1. 단편화 의미와 발생 이유
2. TCP/IP통신에서 대량의 데이터를 연속으로 송/수신 시 수신측 이벤트에서 발생될 수 있는 문제점

2-1. 서버와 클라이언트 통신 환경설정
2-2. 대량의 데이터를 연속으로 송/수신 시 수신측 이벤트에서 발생하는 문제점(단편화 발생)

3. 단편화 해결 방안
4. 프로그램 핵심소스(서버측 코드 vs 클라이언트측 코드)
5. 예제 프로그램 사용방법 순서로 설명합니다.
순서로 진행합니다.

1. 단편화 의미와 발생 이유

단편화 란 데이터가 전송될 때 전송 데이터가 수신측 이벤트에 한번에 전송되지 않고 조각(Fragment)으로 나누어져 전송되는 것을 의미합니다. 단편화 발생이유는 특정장비의 MTU(특정장비에서 한번에 보낼 수 있는 IP데이터 그램의 최대 크기)보다 큰 패킷이 들어왔을 때 발생하게 되며 수신되는 데이터는 조각으로 나누어져 수신 받게 됩니다.

2. TCP/IP통신에서 대량의 데이터를 연속으로 송/수신 시 수신측 이벤트에서 발생될 수 있는 문제점
2-1. 서버와 클라이언트 통신 환경설정

예시) [서버 – 인트라넷 – 클라이언트], [서버 – 인터넷 – 클라이언트]

2-2. 대량의 데이터를 연속으로 송/수신 시 수신측 이벤트에서 발생하는 문제점(단편화 발생)

예시) [서버 → 클라이언트] 또는 [클라이언트 → 서버]로 대량의 데이터(1500Byte이상)을 연속(인터벌1ms)로 송신 시 수신 측에서 발생하는 문제점


3. 단편화 해결 방안

HNS에서 사용한 해결 방법은 송신 측에서는 보낼 데이터를 STX(시작구분코드) + DATA길이 + CRC32 + DATA + ETX(마감 구분코드)로 프레임 화하여 전송하고 수신 측에서는 데이터 길이와 CRC등을 사용하여 검증할 수 있습니다.

[송/수신 데이터의 프레임 구조 예시]
패킷 STX DATA
길이
CRC32 DATA ETX
설명 시작구분 코드 송/수신
데이터 길이
(DATA의
길이)
에러체크 전송할
데이터
마감구분
코드
예제예시 “@” “00010” “A80D6516”
(16진수)
“ABCDEFGHIJ”
(데이터에
STX(@),
ETX(;)
문자없어야 함
“;”

※ 모든 데이터는 Unicode 문자열로 처리됨

수신 측 OnReceiveHandler 이벤트에서 데이터를 수신하고 GetFrameData()에서 데이터의 구조가 Frame구조로 되어 있는지 확인하여 정상 프레임 구조일때만 그 다음 처리를 진행합니다. 정상 프레임 구조라면 Verification 메서드에서 수신 데이터의 길이와 CRC에러검증을 수행하여 에러가 발생하는 경우 관련 에러 메시지를 반환합니다.

참고 보다 자세한 처리방법은 4. 프로그램 핵심소스(서버측 코드 vs 클라이언트측 코드)를 참고바랍니다.
4. 프로그램 핵심소스(서버측 코드 vs 클라이언트측 코드)

※ 본 예시는 참고 용이며 적용하고자 하시는 프로젝트에서 응용하여 적용하시기 바랍니다.

서버측 코드
(서버시작)
클라이언트측 코드
(클라이언트 서버접속)
private void butStart_Click(object sender, EventArgs e)
{
// 비동기 통신
smartTCPMultiServer1.SetBlocking(false);
smartTCPMultiServer1.Port = 3377;
smartTCPMultiServer1.MaxClient = 30;
smartTCPMultiServer1.MaxReceiveBufferSize =
500000;
smartTCPMultiServer1.ReceiveTimeout = 3000;
if (smartTCPMultiServer1.IsStart == false)
{
smartTCPMultiServer1.Start();
}
}
private void butConnect_Click(object sender, EventArgs e)
{
smartTCPClient1.SetBlocking(false);
smartTCPClient1.ServerIPAddress = "192.168.0.20";
smartTCPClient1.Port = 3377;
smartTCPClient1.MaxReceiveBufferSize = 500000;
smartTCPClient1.ReceiveTimeout = 3000;

if (smartTCPClient1.IsConnect == false)
{
// 서버와 연결
smartTCPClient1.Connect();
}
}
서버측 코드
(데이터 송신)
클라이언트측 코드
(수신이벤트)
private void smartTimer1_Tick(object sender, EventArgs e)
{
// Frame Format : STXCODE(1) + LENGTH(5) + CRC(8) + DATA(N) + ETXCODE(1)
smartTCPMultiServer1. SendStringUnicodeIP("192.168.0.20", STXCODE + m_sSendData.Length.ToString("00000") + m_CRC32Data + m_sSendData + ETXCODE);
}
if (strRecData != "")
{
// m_strReceive의 데이터가 공백이 될때까지 strFrameData(STXCODE(1) + LENGTH(5) + CRC(8) + DATA(N) + ETXCODE(1))구조로 완성하여 출력
do
{
strFrameData = GetFrameData(ref m_strReceive);
if (strFrameData != "")
{
switch (Verification(strFrameData))
{
// 정상수신
case VERIFYCODE.SUCESS:
lblrecvTotal.Text =
(++recvTotalCnt).ToString();
smartListBox1.AddItem("[" + recvTotalCnt.ToString() + "] " + strFrameData);
smartFile1.WriteString_Begin(strFrameData + "\r\n\r\n");

byte[] StrByte = Encoding.Unicode.GetBytes(m_sSendData);
m_CRC32Data = SmartX.SmartTCPMultiServer.GetCRC32Gen(StrByte).ToString("X");

// Frame Format : STXCODE(1) + LENGTH(5) + CRC(8) + DATA(N) + ETXCODE(1)
// 모든 문자열은 Unicode 문자열로 처리됨
smartTCPClient1.SendStringUnicode(STXCODE + m_sSendData.Length.ToString("00000") + m_CRC32Data + m_sSendData + ETXCODE);
lblSentCnt.Text = (++m_iSendCnt).ToString();
break;
// CRC 오류발생
ase VERIFYCODE.CRC_ERROR:
lblErrorCnt.Text = (++recvErrorCnt).ToString();
lblErrorMesg.Text = "CRC_ERROR";
break;
// 수신 데이터 길이오류발생
case VERIFYCODE.LENGTH_ERROR:
lblErrorCnt.Text = (++recvErrorCnt).ToString();
lblErrorMesg.Text = "LENGTH_ERROR";
break;
// 그외 오류발생
case VERIFYCODE.ERROR:
lblErrorCnt.Text = (++recvErrorCnt).ToString();
lblErrorMesg.Text = "ERROR";
break;
}
}
}
while (strFrameData != "");
}
수신 측에서 데이터를 프레임 구조로 처리하는 함수
(GetFrameData)
private const string STXCODE = "@";
private const string ETXCODE = ";";
// 프레임(STX+LENGTH+CRC32+데이터+ETX)구조로 만들어질때까지 ""을 리턴하고
// 프레임구조로 만들어진경우 해당 프레임 부분을 리턴하고 프레임을 제외한 나머지 부분은 strInData에 저장
private string GetFrameData(ref string strInData)
{
int iPosSTX;
int iPosETX;
string strTemp;
string strRet;

strTemp = strInData;

// strTemp에서 맨 처음 발견되는 지정된 유니코드 문자('@')의 0부터 시작하는 인덱스를 iPosSTX에저장
iPosSTX = strTemp.IndexOf(STXCODE);

// strTemp에서'@'를 발견하지 못한경우
if (iPosSTX == -1)
{
return "";
}

// strTemp에서 맨 처음 발견되는 지정된 유니코드 문자(';')의 0부터 시작하는 인덱스를 iPosETX에 저장
iPosETX = strTemp.IndexOf(ETXCODE);

// strTemp에서';'를 발견하지 못한경우
if (iPosETX == -1)
{
return "";
}
// @와;가 모두 있어야만 이부분 실행
// iPosSTX 부터 (iPosETX - iPosSTX) + 1까지의 문자를 strRet에 저장
strRet = strTemp.Substring(iPosSTX, (iPosETX - iPosSTX) + 1);

// iPosSTX 부터 (iPosETX - iPosSTX) + 1까지의 문자를 삭제
// strTemp - strRet나머지를 strInData에저장. GetFrameData(ref string strInData)호출시 인자로 전달
strInData = strTemp.Remove(iPosSTX, (iPosETX - iPosSTX) + 1);

// @와;가 들어있는 완전한 프레임을 반환
return strRet;
}
수신 측에서 데이터를 검증(LENGTH, CRC)하는 메서드
public enum VERIFYCODE
{
SUCESS = 0, // 성공
LENGTH_ERROR = 1, // 길이에러
CRC_ERROR = 2, // CRC에러
ERROR = 3, // 그이외 에러
}

// Frame Format : STX(1) + LENGTH(5) + CRC(8) + DATA(N) + ETX(1)
public VERIFYCODE Verification(string strFrameData)
{
int iLength_Read; // 데이터길이
int iLength_Cal; // 데이터길이 검증
string strCRC_Read; // 수신프레임에서 추출된 CRC저장
int iCRC_Read; //strCRC_Read(16진수) --> int형으로 변환
int iCRC_Cal; // CRC값을 계산하고 int형으로 변환
string strData;
byte[] chData;

try
{
// 수신데이터에서 데이터의 길이 추출
iLength_Read = Convert.ToInt32(strFrameData.Substring(1, 5));
// 수신데이터의 데이터의 길이 계산
iLength_Cal = strFrameData.Length - 15;

if (iLength_Read != iLength_Cal)
{
// 길이오류
return VERIFYCODE.LENGTH_ERROR;
}

// 수신된 데이터에서 실제데이터만 추출
strData = strFrameData.Substring(14, strFrameData.Length - 15);

// CRC추출
strCRC_Read = strFrameData.Substring(6, 8);

// 16진수를 int형으로 변환하여 iCRC_Read에 저장
iCRC_Read = Convert.ToInt32(strCRC_Read, 16);

// String형을 Unicode타입의 Byte[]로 변환
chData = Encoding.Unicode.GetBytes(strData);

// CRC값을 계산 Int형으로 변환하여 iCRC_Cal에 저장
iCRC_Cal = (int)SmartX.SmartTCPMultiServer.GetCRC32Gen(chData);
}
catch (Exception)
{
return VERIFYCODE.ERROR;
}

// 수신데이터의 CRC32값과 계산하여 만든 CRC32값이 일치 안한다면
if (iCRC_Read != iCRC_Cal)
{
return VERIFYCODE.CRC_ERROR;
}
return VERIFYCODE.SUCESS;
}
서버측 코드
(서버종료)
클라이언트측 코드
(클라이언트종료)
private void butExit_Click(object sender, EventArgs e)
{
if (smartTCPMultiServer1.IsStart == true)
{
smartTCPMultiServer1.Stop();
}
Close();
}
private void butExit_Click(object sender, EventArgs e)
{
if (smartTCPClient1.IsConnect == true)
{
// 서버와 연결종료
smartTCPClient1.Close();
}
Close();
}
5.예제프로그램 사용방법
   
  • Step-1. 서버 프로그램의 Server – Start 버튼을 클릭하여 서버를 시작합니다.
  • Step-2. 클라이언트 프로그램의 Server Connect를 클릭하여 클라이언트를 서버에 접속합니다.
  • Step3. 서버 프로그램의 SendCount(전송할 데이터 개수)를 설정하고 TimerInterval(전송할 데이터간 인터벌) 값을 설정합니다.
  • Step-4. 서버 프로그램의 SendToClient를 클릭하여 클라이언트로 데이터전송을 시작합니다.
  • Step-5. 클라이언트측 수신데이터 확인

    데이터 전송이 모두 완료된 이후 클라이언트 프로그램의 FileWrite를 클릭하여 서버로부터수신받은 데이터를 파일(Test1.txt)로 저장하고 해당 파일을 열어서 STXCODE(‘@’)의 개수와 ETXCODE(‘;’)의 개수가 서버측에서 보낸 Send Count개수와 일치하는지 확인하시면 됩니다.
    데이터 송신이 정상인 경우) 서버측 SentCount(1000개) = 클라이언트 STXCODE(‘@’)의 개수 = 클라이언트ETXCODE(‘;’)의 개수 가 일치하면 됩니다.

  • Step-6. 서버측 수신데이터 확인

    서버 프로그램의 FileWrite를 클릭하여 클라이언트로부터 수신받은 데이터를 파일(Test1.txt)로 저장하고 해당 파일을 열어서 STXCODE(‘@’)의 개수와 ETXCODE(‘;’)의 개수가 클라이언트에서 보낸 Sent Count개수와 일치하는지 확인하시면 됩니다.

맨 위로
팝업닫기

(주)에이치앤에스('http://hnsts.co.kr/'이하 '(주)에이치앤에스 웹사이트')는 개인정보보호법에 따라 이용자의 개인정보 보호 및 권익을 보호하고 개인정보와 관련한 이용자의 고충을 원활하게 처리할 수 있도록 다음과 같은 처리방침을 두고 있습니다.

(주)에이치앤에스 웹사이트는 개인정보처리방침을 개정하는 경우 웹사이트 공지사항(또는 개별공지)을 통하여 공지할 것입니다.

○ 본 방침은 2011년 4월 1일부터 시행됩니다.

1. 개인정보의 처리 목적 (주)에이치앤에스 웹사이트는 개인정보를 다음의 목적을 위해 처리합니다. 처리한 개인정보는 다음의 목적 이외의 용도로는
사용되지 않으며 이용 목적이 변경될 시에는 사전동의를 구할 예정 입니다.
가. 민원사무 처리
민원인의 신원 확인, 민원사항 확인, 사실조사를 위한 연락 · 통지, 처리결과 통보 등을 목적으로 개인정보를 처리합니다.
2. 개인정보 파일 현황
1. 개인정보 파일명 : 고객의 소리
  • - 개인정보 항목 : 이메일, 휴대전화번호, 자택전화번호, 이름, 서비스 이용 기록, 접속 로그, 쿠키, 접속 IP 정보
  • - 수집방법 : 웹사이트
  • - 보유근거 : 이용자 동의
  • - 보유기간 : 3년
3. 개인정보의 제3자 제공에 관한 사항
① (주)에이치앤에스 웹사이트는 원칙적으로 이용자의 개인정보를 제1조에서 명시한 목적 범위 내에서 처리하며, 본래의 범위를 초과하여 처리하거나 제3자에게 제공하지 않습니다.
다만, 다음의 경우에는 개인정보를 제3자에게 제공할 수 있습니다.
  • – 이용자가 사전에 제3자 제공 및 공개에 동의한 경우
  • – 법령 등에 의해 제공이 요구되는 경우
  • – 서비스의 제공에 관한 계약의 이행을 위하여 필요한 개인정보로서 경제적/기술적인 사유로 통상의 동의를 받는 것이 현저히 곤란한 경우
  • – 개인을 식별하기에 특정할 수 없는 상태로 가공하여 이용하는 경우
4. 정보주체의 권리,의무 및 그 행사방법 이용자는 개인정보주체로서 다음과 같은 권리를 행사할 수 있습니다.
① 정보주체는 (주)에이치앤에스 웹사이트에 대해 언제든지 다음 각 호의 개인정보 보호 관련 권리를 행사할 수 있습니다.
  • 1. 개인정보 열람요구
  • 2. 오류 등이 있을 경우 정정 요구
  • 3. 삭제요구
  • 4. 처리정지 요구
② 제1항에 따른 권리 행사는 (주)에이치앤에스 웹사이트에 대해 개인정보 보호법 시행규칙 별지 제8호 서식에 따라 서면, 전자우편, 모사전송(FAX) 등을 통하여 하실 수 있으며 (주)에이치앤에스 웹사이트는
이에 대해 지체 없이 조치하겠습니다.
③ 정보주체가 개인정보의 오류 등에 대한 정정 또는 삭제를 요구한 경우에는 (주)에이치앤에스 웹사이트는 정정 또는 삭제를 완료할 때까지 당해 개인정보를 이용하거나 제공하지 않습니다.
④ 제1항에 따른 권리 행사는 정보주체의 법정대리인이나 위임을 받은 자 등 대리인을 통하여 하실 수 있습니다. 이 경우 개인정보 보호법 시행규칙 별지 제11호 서식에 따른 위임장을
제출하셔야 합니다.
5. 제3자에게의 개인정보 제공
① (주)에이치앤에스 웹사이트는 다음의 개인정보 항목을 처리하고 있습니다.
<민원사무 처리>
– 필수항목 : 이름, 휴대전화번호, 자택전화번호, 이메일, 서비스 이용 기록, 접속로그, 쿠키, 접속IP 정보
6. 개인정보의 파기
(주)에이치앤에스 웹사이트는 원칙적으로 개인정보 처리목적이 달성된 경우에는 지체없이 해당 개인정보를 파기합니다. 파기의 절차, 기한 및 방법은 다음과 같습니다.
  • –파기절차 이용자가 입력한 정보는 목적 달성 후 별도의 DB에 옮겨져(종이의 경우 별도의 서류) 내부 방침 및 기타 관련 법령에 따라 일정기간 저장된 후 혹은 즉시 파기됩니다. 이 때, DB로 옮겨진 개인정보는 법률에 의한 경우가 아니고서는 다른 목적으로 이용되지 않습니다.-파기기한이용자의 개인정보는 개인정보의 보유기간이 경과된 경우에는 보유기간의 종료일로부터 5일 이내에, 개인정보의 처리 목적 달성, 해당 서비스의 폐지, 사업의 종료 등 그 개인정보가 불필요하게 되었을 때에는 개인정보의 처리가 불필요한 것으로 인정되는 날로부터 5일 이내에 그 개인정보를 파기합니다.
  • –파기방법 전자적 파일 형태의 정보는 기록을 재생할 수 없는 기술적 방법을 사용합니다. 종이에 출력된 개인정보는 분쇄기로 분쇄하거나 소각을 통하여 파기합니다.
7. 개인정보의 안전성 확보 조치
(주)에이치앤에스 웹사이트는 개인정보보호법 제29조에 따라 다음과 같이 안전성 확보에 필요한 기술적/관리적 및 물리적 조치를 하고 있습니다.
1. 정기적인 자체 감사 실시
개인정보 취급 관련 안정성 확보를 위해 정기적(분기 1회)으로 자체 감사를 실시하고 있습니다.
2. 개인정보 취급 직원의 최소화 및 교육
개인정보를 취급하는 직원을 지정하고 담당자에 한정시켜 최소화 하여 개인정보를 관리하는 대책을 시행하고 있습니다.
3. 내부관리계획의 수립 및 시행
개인정보의 안전한 처리를 위하여 내부관리계획을 수립하고 시행하고 있습니다.
4. 해킹 등에 대비한 기술적 대책
(주)에이치앤에스 웹사이트는 해킹이나 컴퓨터 바이러스 등에 의한 개인정보 유출 및 훼손을 막기 위하여 보안프로그램을 설치하고 주기적인 갱신·점검을 하며 외부로부터 접근이 통제된 구역에
시스템을 설치하고 기술적/물리적으로 감시 및 차단하고 있습니다.
5. 개인정보의 암호화
이용자의 개인정보는 비밀번호는 암호화 되어 저장 및 관리되고 있어, 본인만이 알 수 있으며 중요한 데이터는 파일 및 전송 데이터를 암호화 하거나 파일 잠금 기능을 사용하는 등의
별도 보안기능을 사용하고 있습니다.
6. 접속기록의 보관 및 위변조 방지
개인정보처리시스템에 접속한 기록을 최소 6개월 이상 보관, 관리하고 있으며, 접속 기록이 위변조 및 도난, 분실되지 않도록 보안기능 사용하고 있습니다.
7. 개인정보에 대한 접근 제한
개인정보를 처리하는 데이터베이스시스템에 대한 접근권한의 부여,변경,말소를 통하여 개인정보에 대한 접근통제를 위하여 필요한 조치를 하고 있으며 침입차단시스템을 이용하여
외부로부터의 무단 접근을 통제하고 있습니다.
8. 문서보안을 위한 잠금장치 사용
개인정보가 포함된 서류, 보조저장매체 등을 잠금장치가 있는 안전한 장소에 보관하고 있습니다.
9. 비인가자에 대한 출입 통제
개인정보를 보관하고 있는 물리적 보관 장소를 별도로 두고 이에 대해 출입통제 절차를 수립, 운영하고 있습니다.
8. 개인정보 보호책임자 작성
① (주)에이치앤에스 웹사이트는 개인정보 처리에 관한 업무를 총괄해서 책임지고, 개인정보 처리와 관련한 정보주체의 불만처리 및 피해구제 등을 위하여 아래와 같이 개인정보 보호책임자를
지정하고 있습니다.
▶ 개인정보 보호책임자
성명 : 김진효
소속 : (주)에이치앤에스
전화번호 : 02-6402-8001
이메일 : hns@hnsts.co.kr
② 정보주체께서는 (주)에이치앤에스 웹사이트의 서비스(또는 사업)을 이용하시면서 발생한 모든 개인정보 보호 관련 문의, 불만처리, 피해구제 등에 관한 사항을 개인정보 보호책임자 및
담당부서로 문의하실 수 있습니다. (주)에이치앤에스 웹사이트는 정보주체의 문의에 대해 지체 없이 답변 및 처리해드릴 것입니다.
9. 개인정보침해 구제방법
정보주체는 개인정보침해로부터 구제받고자 하는 경우 다음과 같은 기관에 도움을 요청할 수 있습니다.
▶ 개인정보 침해신고센터 (한국인터넷진흥원 운영)
– 소관업무 : 개인정보 침해사실 신고, 상담 신청
– 홈페이지 : privacy.kisa.or.kr
– 전화 : (국번없이) 118
– 주소 : (138-950) 서울시 송파구 중대로 135 한국인터넷진흥원 개인정보침해신고센터
▶ 개인정보 분쟁조정위원회 (한국인터넷진흥원 운영)
– 홈페이지 : privacy.kisa.or.kr
– 전화 : (국번없이) 118
– 주소 : (138-950) 서울시 송파구 중대로 135 한국인터넷진흥원 개인정보침해신고센터
10. 개인정보 처리방침 변경
① 이 개인정보처리방침은 시행일로부터 적용되며, 법령 및 방침에 따른 변경내용의 추가, 삭제 및 정정이 있는 경우에는 변경사항의 시행 7일 전부터 공지사항을 통하여 고지할
것입니다.
팝업닫기

본 웹사이트에 게시된 이메일 주소가 전자우편 수집 프로그램이나 그 밖의 기술적 장치를 이용하여 무단으로 수집되는 것을 거부하며, 이를 위반시 정보통신망법에 의해 형사처벌됨을 유념하시기 바랍니다.

게시일 : 2011.4.1