|
아래 코드로 봐서는 NumberBytes 의 정의가 애매 합니다.
만약 NumberBytes 가 고정이라면 보내는측에서 strlen으로 바이트숫자를 정하지 마시고 그냥 1000 byte다 보내세요.
물론 받는데서도 1000바이트 다 받고요..
지금보니 보내는데는 1000 메모리 잡고 받는부분은 100 만큼 잡았네요...
보내고 받는것이 100 바이트 이내라면 문제될것은 없지만.... 만약 100바이트 이상되면 받는곳에서 문제가 되겠지요?
its 님이 쓰신 글 :
: NMUDP로 DB.1.3 같은 데이터를 전송해서 받으면 DB에 올려주는 소스를 구현중인데, 볼랜드에서 F9를 누르면 잘 되는데, 그냥 EXE로 실행할 때는 안되네요 ㅠㅠ 도와주세요;;
:
:
: - 보내는 소스입니다.
: if(NMUDP1->RemoteHost == "")
: {
:
: }
: else
: {
: AnsiString data = "DB."+String(floor)+"."+String(sfloor)+".";
: char sd[1000];
: memset(sd, 0x00, sizeof(sd));
: memcpy(sd, data.c_str(),strlen(data.c_str()));
: NMUDP1->SendBuffer(sd, sizeof(sd), strlen(Edit1->Text.c_str()));
: }
:
: * 참고. 통신규약은 DB.출발층.도착층. 입니다.
:
: - 받는 소스입니다.
:
: char bf[100];
: int i = 0;
: memset(bf, 0x00, 100);
: NMUDP1->ReadBuffer(bf, NumberBytes, i);
: AnsiString data = bf;
:
: int pos1 = data.Pos(".");
: AnsiString data1 = data.SubString(1, pos1-1);
: data = data.Delete(1, pos1);
:
: int pos2 = data.Pos(".");
: AnsiString data2 = data.SubString(1, pos2-1);
: data = data.Delete(1, pos2);
:
: int pos3 = data.Pos(".");
: AnsiString data3 = data.SubString(1, pos3-1);
: data = data.Delete(1, pos3);
:
: if(data1 == "DB")
: {
: TDateTime MyDateTime;
:
: ADOQuery1->Close();
: ADOQuery1->SQL->Clear();
: ADOQuery1->SQL->Add("Insert into Table1");
: ADOQuery1->SQL->Add("(출발층,도착층,시각)");
: ADOQuery1->SQL->Add("VALUES");
: ADOQuery1->SQL->Add("('"+data2+"','"+data3+"','"+DateTimeToStr(MyDateTime.CurrentDateTime())+"')");
: ADOQuery1->ExecSQL();
: ADOQuery1->SQL->Clear();
: ADOQuery1->SQL->Add("select * from Table1");
: ADOQuery1->Open();
: }
:
: 좀 도와 주세요;; 욕설/비방/답변X는 삼가합니다. 좋은 고수님들의 답변 제발 부탁합니다.
|