免费注册 查看新帖 |

Chinaunix

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

如何将普通用户设置在chroot环境中? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-10-09 16:53 |只看该作者 |倒序浏览
大家好,,我想将一个普通用户加入的到 chroot环境中,,就是要做的该用户,只能在自己的目录底下活动,不能访问其它任何目录, 就是连“cd /”都不能使用,,谢谢,,

论坛徽章:
0
2 [报告]
发表于 2007-10-09 17:48 |只看该作者
至少得重新装备一套/bin /etc/passwd /dev/null 等东西,根本没有必要。

论坛徽章:
0
3 [报告]
发表于 2007-10-09 19:09 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
4 [报告]
发表于 2007-10-09 19:11 |只看该作者
原帖由 hiwoody 于 2007-10-9 19:09 发表
参见bind中的chroot实现


那可不大一樣,bind 只是 chroot 呼叫而已,但是不用有 shell 操作環境.

若是要使用者登入後有一個 shell 環境,相關所需要的程式與程式庫都要複製一份,其實這做起來費時費力。

一般來說建議若是沒特殊需求,提供 ftp 搭配 chroot 限制即可,不需要開放 shell 登入.

--

论坛徽章:
0
5 [报告]
发表于 2007-10-09 19:19 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
6 [报告]
发表于 2007-10-09 21:54 |只看该作者
谢谢,,楼上的各位,,

能不能考虑下,在shell的配置文件下设置,,我想要是不行的话,能不能根椐Bash 或者其它(csh,tcsh,)的源程序,自己做一个接口,,
不知,那里这方面的资料找,?

论坛徽章:
0
7 [报告]
发表于 2007-10-10 09:14 |只看该作者
首先创建一个chroot环境jailroot;
编译下面程序,并且将其chmod u+s
将用户的登陆shell设置为这个程序,这样一来用户登陆后就被chroot到/home/hank/jailroot了
#include <stdlib.h>
#include <unistd.h>
#include <string.h>

int main(int argc, char **argv)
{
        int i;
        chdir("/home/hank/jailroot");
        i=chroot("/home/hank/jailroot");
        if(i!=0)
        {
                perror("chroot");
        }
        if(argc>1&&strcmp(argv[1],"root")==0)
        {
                system("/bin/sh");
        }
        else
        {
                seteuid(getuid());
                system("/bin/sh");
        }
}

论坛徽章:
0
8 [报告]
发表于 2007-10-10 17:41 |只看该作者
谢谢,,大家。感谢 Au_Hank  的C代码,,,谢谢,,,已经OK,,,,万分感激,,,,
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP