我必须编写一些执行以下操作的代码: 客户端从键盘读取输入并将字符串发送到服务器。服务器打印客户端的IP和字符串。 编译时间很好,但是当我运行代码时会出现绑定错误"没有这样的文件或目录" 我已经在论坛上查看了beej的指南和其他问题,但无法解决问题。 任何帮助表示赞赏。
编辑:我做了你告诉我要做的改动,除了控制读写的返回值,因为程序没有进入while循环!另外,setsockopt也不起作用。
#include<unistd.h>
#include<string.h>
#include<stdlib.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<stdio.h>
#include<sys/un.h>
int main(void)
{
int fd1,fd2,test,lun,n,enable=1;
socklen_t len;
struct sockaddr_un indirizzo_serv, indirizzo_cl;
char buf[100]={0},temp[100]={0};
fd1=socket(PF_LOCAL,SOCK_STREAM,0); //creo socket locale
if(fd1<0)
perror("Errore nella creazione del socket\n");
else printf("Socket OK\n");
indirizzo_serv.sun_family=AF_LOCAL;
strcpy(indirizzo_serv.sun_path,"/tmp/socket1000");
//lun=strlen(indirizzo_serv.sun_path)+sizeof(indirizzo_serv.sun_family);
if(setsockopt(fd1,SOL_SOCKET,SO_REUSEADDR,&enable,sizeof(int))<0)
perror("Errore in setsockopt REUSEADDR\n");
test=bind(fd1,(struct sockaddr*)&indirizzo_serv,sizeof(indirizzo_serv));
if(test==0){
printf("Bind OK\n");
test=listen(fd1,2);
if(test==0){
printf("listen OK\n");
len=sizeof(struct sockaddr_un);
while(1){
fd2=accept(fd1,(struct sockaddr*)&indirizzo_cl,&len);
if(fd2<0)
perror("\nErrore nella accept\n");
else printf("Accept OK\n");
write(STDOUT_FILENO,"Client - Inserire la stringa da inviare al server: \n",strlen("Client - Inserire la stringa da inviare al server: \n"));
read(STDIN_FILENO,buf,sizeof(buf));
write(fd2,buf,strlen(buf));//write(fd1,buf,strlen(buf));
read(fd2,buf,strlen(buf));
sprintf(temp,"Server - IP del client: %s\n",indirizzo_cl.sun_path);
write(STDOUT_FILENO,temp,strlen(temp));
memset(buf,0,100);
memset(temp,0,100);
}
}
else perror("Errore nella listen\n");
}
else perror("Errore nella bind\n");
unlink(indirizzo_serv.sun_path);//close(fd1);
return 0;
}
答案 0 :(得分:0)
编译仍有问题(test=0
=&gt; test==0
; int len;
=&gt; socklen_t len;
(签名错误))。您应该使用-Wall
进行编译并在询问之前对其进行排序。
您的错误很可能是由于路径中缺少目录。
替换一个确定存在的路径,例如/tmp/socket1
,可以在我的电脑上运行。
答案 1 :(得分:0)
您正在写入您的侦听套接字,更改:
write(fd1,buf,strlen(buf));
成:
write(fd2,buf,strlen(buf));
另外:代替(memset(buf,0,100);
)在每个循环上清零缓冲区,你应该检查从read()
获得的返回值
if(test=0){
始终为false,因为它是一项任务。 (mabe你想要if(test == 0){
?)