22049, 1/1103 회원가입  로그인  
   lMaxl04
   http://1111
   libc 관련

http://www.hackerschool.org/HS_Boards/zboard.php?id=Free_Board&no=37634 [복사]


포너블 문제를 풀다보면 libc가 제공되는 경우가 다소 있는 것 같습니다

문제 파일 실행 시 해당 파일을 참조해야하는데 어떻게 참조하게 만들 수 있나요?

libc에 맞는 ld 파일을 찾아 함께 patchelf를 해보려했으나 libc에 맞는 ld 파일이 잘 찾아지지 않기도 하고요 ㅠㅠ

물론 노가다로 오프셋을 구할 수는 있다는건 증명하였습니다 ㅎㅎ

  Hit : 625     Date : 2022/07/29 06:02



    
lMaxl04 추가로, strings로 libc 파일에서 /bin/sh의 offset을 찾는데, 함수 주소는 왜 그렇게 찾으면 offset이 다른지 궁금합니다. 2022/07/29  
cd80 보통 libc가 주어지는 경우에 patchelf같은걸로 같이 실행해야되는 경우는 힙문제풀때 아니면 거의 없습니다
힙문제풀때는 주어진 libc로 같이 실행하면 좋은 이유가 libc 버전마다 힙에 걸려있는 check & mitigation이 다르기 떄문입니다
댓글의 내용으로 보아 단순히 system함수와 /bin/sh문자열의 오프셋만 찾으면 되는 경우 같은데
(base) ➜ ~ strings -t x /lib/x86_64-linux-gnu/libc.so.6 | grep /bin/sh
1b45bd /bin/sh
(base) ➜ ~ objdump -d /lib/x86_64-linux-gnu/libc.so.6 | grep system\.\*\>:
0000000000052290 <__libc_system@@GLIBC_PRIVATE>:
0000000000153ae0 <svcerr_systemerr@@GLIBC_2.2.5>:
(base) ➜ ~

이런식으로 찾으시면 됩니다
/bin/sh의 offset = 0x1b45bd
system의 offset = 0x52290

함수주소를 strings로 찾으면 다른 이유는 system함수의 시작은 "system"문자열의 주소가 아니라 system함수 코드의 시작주소기 때문이구요
2022/08/01  
lMaxl04 역시 ㅎㅎ 기다렸습니다
우선 댓글의 질문에 대한 답은 잘 이해했습니다.

말씀하신 것과 같이 단순히 offset을 구하는 경우가 대부분이라 사실 그냥 찾으면 되긴 하는데, 간혹 libc 내의 특정 함수의 중간즈음에서 memory leak이 일어나는 경우 libc 버전에 따라서 해당 함수의 위치가 다른 경우가 있는 것을 확인하여서 그런 궁금증이 들었습니다 ㅎㅎ

예를 들어 libc_1.so 에서 printf + 100의 위치가 leak 되었는데,
libc_2.so에서는 printf + 200의 위치가 leak 되는 경우 입니다.

역시 patchelf 말고는 방법이 없으려나요?
2022/08/01  
cd80 쉽지 않네요 어떤 경우인지 알겠는데 저도 그럴때마다 정확히 시작점이 릭되는 함수들로 바꿔서 릭시켰었거든요 memcpy함수같은경우는 base나 len의 align에 따라 fast path, slow path로 나눠지기도 하는데 그런경우에 다르게 릭되는게 아닐까 싶네요 정확한 이유는 모르겠습니다 2022/08/02  
lMaxl04 답변 감사합니다 ㅎㅎ
우선은 patchelf에 대해서 조금 알아봐야겠습니다.
역시나 이번에도 큰 도움 되었습니다. 감사합니다
2022/08/03  
22049   2023 핵테온 세종(HackTheon Sejong) 국제 대학생 사이버보안 경진대회 (접수 3월 22일 마감)     Geni pco COM
03/06 78
22048   안녕하세요 현직 프리랜서 프로그래머 입니다,     assoccer63
03/04 176
22047   해킹과외 선생님 찾습니다.     sansuback
02/27 123
22046   안녕하세요 해킹배우고싶어 가입후 글올려요     차영철이다
02/22 104
22045   시스템, 웹 해킹 과외[1]     pingping1234
02/16 199
22044   웹 모바일 해킹과외 합니다.     x6161
02/09 190
22043   운영자님 LOB FC3,4, 10,14 다운로드 안됩니다.[3]     ttest
02/06 104
22042   안녕하세요 영상관련[1]     Whddn302
01/24 150
22041   해커 커뮤니티 사이트 좀 알려주세요... [1]     walker
01/22 475
22040   해킹 과외 합니다.[2]     jdo
01/12 513
22039   해킹 잘하시는분[1]     sksh1290
01/03 394
22038   초보자용 기수제 지옥 훈련 서바이벌 스터디그룹 빡공팟 6기 모집     teamh4c
01/01 256
22037   다시 해킹과외 들으실분 모집합니다.[4]     sysadm
12/23 488
22036   cd80님 감사 인사 드립니다.[2]     lMaxl04
12/15 252
22035   모 그룹에 흙수저 코스프레 하는 또라이 해커가 있습니다[2]     gggg
12/05 641
22034   해킹 보안 관련 과외를 진행합니다.[1]     bluewindsoul
09/11 985
22033   우리은행 해킹대회 안내[1]     wooricon
09/05 873
  libc 관련[5]     lMaxl04
07/29 624
22031   해킹 과외 선생님 찾습니다.     ploplo33
07/10 971
22030   해킹팀 및 보안스터디 모집     hideroot
06/21 1288
1 [2][3][4][5][6][7][8][9][10]..[1103]

Copyright 1999-2023 Zeroboard / skin by Hackerschool.org / Secure Patch by Hackerschool.org & Wowhacker.com