【问题标题】:Bind error in local socket本地套接字中的绑定错误
【发布时间】:2017-04-16 15:15:46
【问题描述】:

我必须编写一些代码来执行以下操作: 客户端从键盘读取输入并将字符串发送到服务器。服务器打印客户端的 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;
}

【问题讨论】:

  • write(fd1,buf,strlen(buf)); -->> write(fd2,buf,strlen(buf));
  • 还是不行

标签: c sockets unix bind unix-socket


【解决方案1】:

编译仍然存在问题(test=0 => test==0; int len; => socklen_t len;(签名错误))。您应该使用-Wall 编译并在询问之前对其进行整理。

您的错误很可能是由于路径中缺少目录。 替换诸如/tmp/socket1 之类的肯定存在的路径使其可以在我的PC 上运行。

【讨论】:

  • test=0 只是一个错字
【解决方案2】:

你正在写入你的监听套接字,更改:


write(fd1,buf,strlen(buf));

进入:

write(fd2,buf,strlen(buf));

另外:您应该检查从read() 获得的返回值,而不是 (memset(buf,0,100);) 在每个循环中将缓冲区归零

和:

if(test=0){

总是假的,因为它是一个赋值。 (也许你想要if(test == 0){ ?)

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2016-09-22
    • 2021-05-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-10-31
    相关资源
    最近更新 更多