21997, 3/1100 회원가입  로그인  
   lMaxl04
   http://1111
   libc 관련

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


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

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

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

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

  Hit : 1041     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  
21957   cd80님 감사 인사 드립니다.[2]     lMaxl04
12/15 686
21956   모 그룹에 흙수저 코스프레 하는 또라이 해커가 있습니다[3]     gggg
12/05 1310
21955   해킹 보안 관련 과외를 진행합니다.[1]     bluewindsoul
09/11 1477
21954   우리은행 해킹대회 안내[1]     wooricon
09/05 1470
  libc 관련[5]     lMaxl04
07/29 1040
21952   해킹 과외 선생님 찾습니다.     ploplo33
07/10 1351
21951   해킹팀 및 보안스터디 모집     hideroot
06/21 2017
21950   몇년만인지 모르겠네요 다시 시작하며 lob 질문 하나 드립니다[10]     lMaxl04
05/01 1476
21949   차세대 보안리더 양성 프로그램 11기 모집 예정     한승재
04/26 1559
21948   우분투 22.04 LTS가 출시되었습니다     한승재
04/23 1252
21947   해킹 기초 과외합니다~[2]     jsi606897
04/10 2200
21946   2022 디지털 포렌식 챌린지 일정이 공개 되었습니다[2]     한승재
04/05 1608
21945   보안 스터디 하실 분[1]     mailwoou
03/29 1567
21944   사이트 리뉴얼은 언제되나요?[3]     john1913
03/03 1667
21943   해킹 보안 관련 과외를 진행합니다.[1]     bluewindsoul
02/14 2229
21942   해킹 과외 진행합니다[2]     jsi606897
02/01 1966
21941   해킹 배우고싶습니다.[1]     Whddn302
01/26 1715
21940   안녕하세요 해킹 처음 시작할때[1]     marbong97
01/07 1868
21939   사회 생활에 찌든 아재 한 명이 유적 탐험 하고 갑니다.[1]     U_SoRang
12/19 2563
21938   과외선생님을 찾습니다[4]     김태마리
11/29 1821
[1][2] 3 [4][5][6][7][8][9][10]..[1100]

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