Ubuntu上的套接字(不允许操作)

前端之家收集整理的这篇文章主要介绍了Ubuntu上的套接字(不允许操作)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我是新手,只是在Linux下我的第一步.
所以我有一些关于套接字的任务.我正在关注指南,尤其是 @L_301_0@指南.代码示例不起作用.我从这开始:
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/un.h>

#define SOCK_PATH "echo_socket"

int main(void)
{
    int s,s2,t,len;
    struct sockaddr_un local,remote;
    char str[100];

    if ((s = socket(AF_UNIX,SOCK_STREAM,0)) == -1) {
        perror("socket");
        exit(1);
    }

    local.sun_family = AF_UNIX;
    strcpy(local.sun_path,SOCK_PATH);
    unlink(local.sun_path);
    len = strlen(local.sun_path) + sizeof(local.sun_family);
    if (bind(s,(struct sockaddr *)&local,len) == -1) {
        perror("bind");
        exit(1);
    }
return 0;
}

我已经想出要编译它(Code :: Blocks)必须还有一个包含:

#include <unistd.h>

但成功运行后,我收到消息“Bind:Operation not permitted”.哪里不对?我试图在root下运行它仍然无法正常工作.

有些Unix系统不允许你到处创建套接字.确保您拥有正确的权限和正确的文件系统. (Fat32因为在手机上的sdcards上使用它不会允许额外的文件标记,可能会让你陷入麻烦)
最后在较新的系统上运行像selinux这样的安全事件可能会阻止套接字的创建.

在我的例子中,我不得不改变

#define SOCK_PATH "echo_socket"

#define SOCK_PATH "/dev/socket/echo_socket"

之后它立即起作用. (可执行文件在root shell中启动)

猜你在找的Ubuntu相关文章