해커스랩 프리해킹 존 8단계 질문입니다.
글쓴이: sephiron / 작성시간: 일, 2005/09/04 - 1:23오후
아시겠지만 레이싱 컨디션에 관한 문제입니다.
/bin/ps2 가 /var/tmp2/ps2.tmp 라는 임시 파일을 생성할 때,
위 임시 파일을 삭제 후 다른 파일을 위 임시 파일 이름으로 링크 하는
것이죠?
제 문제는 /var/tmp2/ 디렉토리가 스티키 설정이 되어 있어서인지
/var/tmp2/ps2.tmp를 삭제할 때 퍼미션 에러가 나온다는 것입니다.
ps2.tmp 를 삭제하지 않고 내용을 추가, chmod로 실행속성을 부여하는 방법도 chmod에서 퍼미션에러가 나오는 군요,
모범답안을 봐도 모르겠으니, 도와주시겠습니까?
[/code]
Forums:
스티키 비트의 의미는 해당 디렉토리의 퍼미션이 열려 있다고 해도디렉토
스티키 비트의 의미는 해당 디렉토리의 퍼미션이 열려 있다고 해도
디렉토리의 파일은 생성한 사람만 제거 할 수 있는것입니다.
그러니 자신이 실행한 프로그램이 파일을 생성한다면
자신의 uid 를 effective uid 로 하여 파일을 생성하므로
자신의 uid 로 파일이 생성되게 됩니다.
그러므로 자신이 실행한 프로그램이 만든 파일은 자신이 지울 수 있습니다.
sephiron 님이 어떤 환경인지는 자세히 모릅니다.
스티키 비드가 아닌 다른 원인이 있을것 같습니다
[list]drwxrwx--T 2 root level8
drwxrwx--T 2 root level8 12288 Sep 4 19:53 .
drwxr-xr-x 16 root root 4096 Aug 27 2002 ..
-rw-rw-r-- 1 level9 level8 0 Sep 4 19:53 ps2.tmp
우선 답변에 감사드립니다.
위의 ls 결과가 'ps2 &;ls -al /var/tmp2/' 를 실행 결과 입니다.
[level8@drill tmp]$ ls -l /usr/bin/ps2
-rws--x--- 1 level9 level8 15739 Jul 5 2001 /usr/bin/ps2
위의 것이 ps2입니다.
ps2는 위 임시파일을 만들자마자 다시 지웁니다.
파일을 만들기 전 ps2.tmp가 이미 존재하는 지 검사, 심볼릭 링크인지 검사 후 chown을 하던지 하는 것 같습니다. 저는 심볼릭 링크 검사와 chown등 함수 실행 사이에 ps2.tmp를 지우고 같은 이름의 링크를 생성하려고 합니다. 아마도 친절한 ps2가 그 파일을 알아서 실행시킬 듯 합니다.
한데 ps2, 이 파일을 제가 지우려고 할 때 에러가 납니다. 제 id는
uid=2008(level8) gid=2008(level8) groups=2008(level8),9999(hackerszone)
입니다.
레이싱 컨디션 스크립트는
while true
do
ps2&
rm -rf /var/tmp2/ps2.tmp
ln -sf /bin/sh /var/tmp2/ps2.tmp
/var/tmp2/ps2.tmp
done
으로 짰습니다..
조금만 더 자세히 알려주시겠습니까?
[/]되는군요.. 한데 질문있습니다.
[level8@drill tmp]$ cat race
while true
do
ps2&
#rm -rf /var/tmp2/ps2.tmp
ln -sf pass /var/tmp2/ps2.tmp
rm -rf /var/tmp2/ps2.tmp
done
위 스크립트처럼 첫번째 rm 명령을 실행하지 않으면
성공하는데, 위의 주석처리 해시를 없애고 실행하면 실패하는 군요.
물론 ln에 f 옵션이 있어서 rm이 필요없기는 하지만 있다고 실패하는 이유는 잘 모르겠네요.
마저 가르쳐 주시면 감사하겟습니다.
댓글 달기