免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1277 | 回复: 0
打印 上一主题 下一主题

用UNIX域协议传递发送者凭证的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-03-31 20:07 |只看该作者 |倒序浏览
本帖最后由 dengjin_cu 于 2010-03-31 20:12 编辑

错误是sendmsg: Operation not permitted
我已经用了root权限了,该怎么解决呢,附上代码
sender.c

#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<sys/socket.h>
#include<sys/types.h>
#include<sys/un.h>

#define CMS_LEN (sizeof(struct cmsghdr)+sizeof(struct ucred))
union{
        struct cmsghdr cm;
        char col[CMSG_SPACE(sizeof(struct ucred))];
}un_control;
int main(){

        struct sockaddr_un sun;
        struct msghdr msg;
        int sock;
        struct cmsghdr* pcmsg;
        struct ucred *cred;

    sock = socket(AF_LOCAL,SOCK_STREAM,0);
        if(sock < 0){
                perror("socket";exit(-1);
        }       
        sun.sun_family = AF_LOCAL;
        strncpy(sun.sun_path,"/home/eric/unix_test",sizeof(sun.sun_path)-1);

        if(connect(sock,(struct sockaddr*)&sun,sizeof(sun)) < 0){
                perror("connect";exit(-1);
        }
       
        msg.msg_name = NULL;
        msg.msg_namelen = 0;
        msg.msg_controllen = sizeof(un_control.col);
        msg.msg_control = (void *)un_control.col;
        pcmsg = CMSG_FIRSTHDR(&msg);
        pcmsg->cmsg_len = CMSG_LEN(sizeof(struct ucred));
        pcmsg->cmsg_level = SOL_SOCKET;
        pcmsg->cmsg_type = SCM_CREDENTIALS;
        if(sendmsg(sock,&msg,0) < 0){
                perror("sendmsg";exit(-1);
        }
}
receiver.c
#include<stdio.h>
#include<stdlib.h>
#include<sys/un.h>
#include<unistd.h>
#include<sys/socket.h>
#include<sys/types.h>

#define CMS_LEN (sizeof(struct cmsghdr)+sizeof(struct ucred))

int main(){
        struct msghdr msg;
        struct sockaddr_un sun;
        int listenfd,connfd,n = 1;

        listenfd = socket(AF_LOCAL,SOCK_STREAM,0);
        if(listenfd < 0){
                perror("socket";exit(-1);
        }
       
        unlink("/home/eric/unix_test";       
        bzero(&sun,sizeof(sun));
        sun.sun_family = AF_LOCAL;
        strncpy(sun.sun_path,"/home/eric/unix_test",sizeof(sun.sun_path)-1);

        setsockopt(listenfd,SOL_SOCKET,SO_REUSEADDR,&n,sizeof(n));
        if(bind(listenfd,(struct sockaddr*)&sun,sizeof(sun)) < 0){
                perror("bind";exit(-1);
        }
        listen(listenfd,5);
        for(;{
                connfd = accept(listenfd,NULL,NULL);
printf("get a connected\n";
                struct cmsghdr* pcmsg;
                struct ucred* pcred;
                recvmsg(connfd,&msg,0);
                pcmsg = CMSG_FIRSTHDR(&msg);
                if(pcmsg && pcmsg->cmsg_len == CMS_LEN){
                        if(pcmsg->cmsg_level == SOL_SOCKET && \
                                                                        pcmsg->cmsg_type == SCM_CREDENTIALS){
                                pcred = (struct ucred*)CMSG_DATA(pcmsg);
                                printf("real uid=%d\n"
                                           "real gid=%d\npid=%d\n",pcred->uid,\
                                                                                           pcred->gid,\
                                                                                           pcred->pid);
                        }
                }
        }
        return 0;
}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP