socket 통신 코드 연습--매일 조금씩 진보
/* */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
void die(char *msg)
{
perror(msg);
exit(1);
}
void copy_data(int from,int to)
{
char buf[1024];
int amount;
while((amount=read(from,buf,sizeof(buf)))>0) {
if(write(to,buf,amount) !=amount)
{
die("write");
return;
}
}
if(amount <0) die("read");
}
int main()
{
int sock,conn,i;
struct sockaddr_in addr;
size_t addr_len =sizeof(addr);
if((sock = socket(PF_INET,SOCK_STREAM,0))<0)
die("socket");
i=1;
setsocketopt(sock,SOL_SOCKET,SO_REUAEADDR,&i,sizeof(i));
memset(&addr,0,sizeof(addr));
addr.sin_family = AF_INET;
addr.sin_addr.s_addr=htonl(INADDR_ANY);
addr.sin_port =htons(8888);
if(bind(sock,(struct sockaddr *)&addr,sizeof(addr)))
die("blind");
if (lisetn(socket,5))
die("listen");
while((conn=accept(sock,(struct sockaddr *)&addr,&addr_len)) >=0){
printf("Accept %s:%d
",inet_ntoa(addr.sin_addr),addr.sin_port);
copy_data(conn,STDOUT_FILENO);
printf("Done!
");
close(conn);
}
return 0;
}
/* */
#include <stdil.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
#include <netinet/in.h>
int main(int argc,const char *argv[])
{
struct sockaddr_in addr;
int sock;
if (argc !=2){
fprintf (stderr,"need an IP address
");
return -1;
}
memset(&addr,0,sizeof(addr));
addr.sin_family =AF_INET;
inet_aton(argv[1],&addr.sin_addr);
addr.sin_port =htons(8888);
if ((sock =socket(PF_INET,SOCK_STREAN,0)) <0{
die("socket");
}
if (connect(sock,(struct sockaddr *)&addr,sizeof(addr))){
die("connect");
}
printf("Connected!
);
copy_data(STDIN_FILENO,sock);
close(sock);
return 0;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
React 구성 요소에서 소켓 이벤트 리스너가 여러 번 실행됩니다.기본적이지만 종종 간과되는 사이드 프로젝트를 하면서 배운 것이 있습니다. 이 프로젝트에는 단순히 두 가지 주요 부분이 포함되어 있습니다. 프런트 엔드: 반응 및 재료 UI 백엔드: Express, Typescript...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.