역 컴파일이 가능한가요?

익명 사용자의 이미지

c 만든 소스 컴파일된 것을

역컴파일하는 게 가능한가요?

가능하면 방법 좀 알려주십시오-

익명 사용자의 이미지

전에 어떤 프로젝트에 참가해서 리버스 엔지니어링을 한적이
있는데, 전문가 두분이 계셨는데 그분들 덕분에 노하우를 조금
알게 되었는데, 그렇지만 대단한 것은 아니고요.
역컴파일하면 어셈블리 코드를 얻을 수는 있습니다.
그것도 완벽한 것은 아니고요. 코드 영역이랑 데이터 영역을
잘 분간 못해서 엉뚱한 코드를 보여주는 경우도 있습니다.

그리고 치명적으로 원래 함수명을 알수없기 때문에 이 함수가
무슨 어떤 함수인지는 직접 코드 전체를 읽어야만 합니다.
함수가 수천 수만개 있을때는 거의 죽음이죠.

C로 코딩했다고 해서 C언어로는 살리는 것은 불가능한걸로
알고 있습니다. 어셈으로 바뀔때 소스코드의 정보가 사라져
버리거든요. 직접 소스코드를 어셈으로 바꿔보시면 왜 안되는지
쉽게 아실수 있을겁니다.

결론
(1) 어셈으로는 역변환 된다
(2) C로는 역변환 안된다.

익명 사용자의 이미지

역공학을 공부하다 보면 필연적인것이,
역어셈블러가 아닐지 싶군요..

어셈블리가 언어적으로는 그리 복잡하지 않아도
컴파일러가 생성해낸 바이너리 코드를 다시 역어셈블
하다보면,,, 변수나 함수 이름들이 모두
16진수의 값으로 나타나서 코드 따라가기가 아주
힘이듭니다..

이런 불편함을 해소할만한 소프트웨어가 있어서..
소개 하려고 합니다..

http//www.ezdoum.com/stories.php?story=02/04/30/2340070

익명 사용자의 이미지


디버그 정보가 스트립 되지 않은채로 나오는 녀석들이 있습니다.

이런 경우는 gdb로 로드해 보면 상당히 유용한 정보가 많죠. ^_^

2의 이미지

<script>console.log("hi")</script>

세벌의 이미지

댓글 달기

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
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.