해커스랩 프리해킹 존 8단계 질문입니다.

sephiron의 이미지

아시겠지만 레이싱 컨디션에 관한 문제입니다.

/bin/ps2 가 /var/tmp2/ps2.tmp 라는 임시 파일을 생성할 때,

위 임시 파일을 삭제 후 다른 파일을 위 임시 파일 이름으로 링크 하는

것이죠?

제 문제는 /var/tmp2/ 디렉토리가 스티키 설정이 되어 있어서인지

/var/tmp2/ps2.tmp를 삭제할 때 퍼미션 에러가 나온다는 것입니다.

ps2.tmp 를 삭제하지 않고 내용을 추가, chmod로 실행속성을 부여하는 방법도 chmod에서 퍼미션에러가 나오는 군요,

모범답안을 봐도 모르겠으니, 도와주시겠습니까?

[/code]

익명 사용자의 이미지

스티키 비트의 의미는 해당 디렉토리의 퍼미션이 열려 있다고 해도
디렉토리의 파일은 생성한 사람만 제거 할 수 있는것입니다.

그러니 자신이 실행한 프로그램이 파일을 생성한다면
자신의 uid 를 effective uid 로 하여 파일을 생성하므로
자신의 uid 로 파일이 생성되게 됩니다.

그러므로 자신이 실행한 프로그램이 만든 파일은 자신이 지울 수 있습니다.

sephiron 님이 어떤 환경인지는 자세히 모릅니다.
스티키 비드가 아닌 다른 원인이 있을것 같습니다

sephiron의 이미지

    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

으로 짰습니다..

조금만 더 자세히 알려주시겠습니까?

[/]
sephiron의 이미지

[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이 필요없기는 하지만 있다고 실패하는 이유는 잘 모르겠네요.

마저 가르쳐 주시면 감사하겟습니다.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.