22041, 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 : 248     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  
22041   해킹 보안 관련 과외를 진행합니다.[1]     bluewindsoul
09/11 198
22040   우리은행 해킹대회 안내[1]     wooricon
09/05 186
  libc 관련[5]     lMaxl04
07/29 247
22038   해킹 과외 선생님 찾습니다.     ploplo33
07/10 491
22037   해킹팀 및 보안스터디 모집     hideroot
06/21 675
22036   몇년만인지 모르겠네요 다시 시작하며 lob 질문 하나 드립니다[10]     lMaxl04
05/01 568
22035   차세대 보안리더 양성 프로그램 11기 모집 예정     한승재
04/26 659
22034   우분투 22.04 LTS가 출시되었습니다     한승재
04/23 398
22033   해킹 기초 과외합니다~[2]     jsi606897
04/10 1093
22032   2022 디지털 포렌식 챌린지 일정이 공개 되었습니다     한승재
04/05 584
22031   보안 스터디 하실 분[1]     mailwoou
03/29 710
22030   사이트 리뉴얼은 언제되나요?[3]     john1913
03/03 817
22029   해킹 보안 관련 과외를 진행합니다.[1]     bluewindsoul
02/14 1018
22028   해킹 과외 진행합니다[2]     jsi606897
02/01 1113
22027   해킹 배우고싶습니다.[2]     Whddn302
01/26 931
22026   안녕하세요 해킹 처음 시작할때[1]     marbong97
01/07 1082
22025   사회 생활에 찌든 아재 한 명이 유적 탐험 하고 갑니다.[1]     U_SoRang
12/19 1467
22024   과외선생님을 찾습니다[4]     김태마리
11/29 1116
22023   해킹막는 장비나 프로그램추천점여 ㅜㅜㅜㅜㅜㅜㅜㅜ[4]     dfgfg
11/22 1157
22022   해킹 과외를 진행해볼까 합니다.[4]     jsi606897
11/21 1483
1 [2][3][4][5][6][7][8][9][10]..[1103]

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