백엔드 개발 PHP 튜토리얼 PHP 암호화 파일을 복원하는 단계별 실용적인 방법

PHP 암호화 파일을 복원하는 단계별 실용적인 방법

Mar 05, 2021 pm 01:49 PM
php

ps: 작성자는 기술적인 커뮤니케이션만을 위한 것이며 악의적인 의도는 없습니다.

PHP 암호화 파일의 실제 복원

먼저 환경에 대해 이야기해 보겠습니다.

    Ubuntu 14.04.4 LTS (GNU/Linux 3.13.0-52-generic x86_64)
    PHP 5.5.9-1ubuntu4.19 (cli)
로그인 후 복사

실용 프로세스

암호화된 프로젝트와 PHP 확장 동적 링크 라이브러리(jinhou.so)가 있습니다. 손에 .

PHP 코드는 다음과 같습니다.

<?php /* xxxx技术有限公司版权所有: 2016-09-08 08:18:00 */
jhgo(&#39;uGpqefbDEBkqp4preQ2UaAp3RAUeJAZ5s4aERAQMkxbJTgEovHnQw6WxsA99sAhSacJCLGxZL4Q4u6zFyGveuDUoemktHGkMaB5D&#39;);
?>
로그인 후 복사

위에서 분석한 알려진 조건에 따르면:

1 암호화 방법은 평가 암호화 방법과 유사합니다.

2.jhgo에는 실행 코드와 복호화 코드가 포함되어 있습니다.

3.jinhou.so에는 jhgo 기능이 포함되어 있습니다.

먼저 VIM을 사용하여 jinhou.so를 대략적으로 열어 핵심 정보가 있는지 확인하세요.

PHP 암호화 파일을 복원하는 단계별 실용적인 방법

안타깝게도 해결방법의 출처가 명확히 적혀있습니다. https://github.com/eixom/zoeeyguard

코드를 살펴보면 이론적으로 이 확장 프로그램은 파일을 암호화하는 방법과 파일을 해독하는 방법의 두 가지 방법을 노출합니다. 그러나 실제로는 단 하나의 방법만 노출되었고 교활한 공급자에 의해 하나가 제거되었습니다.

물론 우리는 이미 소스 코드를 가지고 있으므로 그다지 신경쓰지 않습니다.

공식 소스코드로 컴파일 후 디코딩을 해보았으나 여전히 동작하지 않는 것을 발견했습니다.

주의 깊게 연구한 결과

PHP 암호화 파일을 복원하는 단계별 실용적인 방법

에 매우 마법 같은 문자열이 포함되어 있음을 발견했습니다. 82dsa7dsas32112389uy7aydh8h2h2i412 이것이 그의 암호화 키인지 궁금했습니다. 코드를 다시 읽어보니 사실인 것으로 드러났습니다. https://github.com/eixom/zoeeyguard/blob/master/src/guard.h 파일에서. 82dsa7dsas32112389uy7aydh8h2h2i412 心想是不是他的加密Key。再翻代码果真是。在 https://github.com/eixom/zoeeyguard/blob/master/src/guard.h 文件里面。
原来的是 28dsa7dsas12312389uy7aydh8h1h2i312원본은 28dsa7dsas12312389uy7aydh8h1h2i312입니다. 변경한 후에도 여전히 작동하지 않는 것을 발견했습니다.

역시 나는 아직 너무 어리고 단순하다.

프로그래머의 심리적 관점에서 분석: 일반적으로 누구도 코드를 변경하지 않으며 기본적으로 매개변수만 변경합니다. 변경된 다른 매개변수가 있나요? 그러나 다른 매개변수는 배열 형식이므로 골치 아픈 일입니다.

/*  private key */
#define PRIVATE_KEY "28dsa7dsas12312389uy7aydh8h1h2i312"
#define PRIVATE_KEY_LEN sizeof(PRIVATE_KEY)

/* order */
static const unsigned char OBFUSCATED_ORDER[] = {
      13,  6,  5,  7,  1, 15, 14, 20
    ,  9, 16, 19,  4, 18, 10,  2,  8
    , 12,  3, 11,  0, 17
};
#define ORDER_SIZE sizeof(OBFUSCATED_ORDER) / sizeof(* OBFUSCATED_ORDER)

/* alphabet for base64 */
static const unsigned char OBFUSCATED_ALPHABET[] = {
      's', '4', 'N', 'E', 'k', 'X', 'c', 'u'
    , 'J', '2', 'U', 'o', 'O', 'w', 'K', 'v'
    , 'h', 'H', 'C', '/', 'D', 'q', 'l', 'R'
    , 'B', 'r', '5', 'Z', 'S', 'Q', '6', 'W'
    , '3', 'L', 'j', '8', '1', 'z', '0', 'G'
    , 'n', 'e', 'y', 'b', 'I', 'd', 'i', 'P'
    , 'A', '9', '7', '+', 'm', 'V', 'M', 'Y'
    , 'F', 'g', 'f', 'p', 'a', 'T', 't', 'x'
};
#define ALPHABET_SIZE 64
로그인 후 복사

이제 킬러 도구인 디컴파일 아티팩트인 IDA Pro v6.8을 출시할 시간입니다. 왼쪽이 일반버전, 오른쪽이 jinhou.so 입니다.

PHP 암호화 파일을 복원하는 단계별 실용적인 방법

데이터를 기반으로 Guard.h의 파일을 변경합니다. 재컴파일 후 성공적으로 복호화되었습니다.

<?php require_cache(APP_PATH.&#39;/Lib/Action/User/AddonAction.class.php&#39;);
?>
로그인 후 복사

이후 요약

1. 이 크래킹에는 암호화 방식과 암호화 코드가 명확하게 알려졌기 때문에 시간이 많이 걸리지 않았습니다.
2. 암호화 매개변수를 테스트하는 데 주요 시간이 소요됩니다. 다행히 .so 파일은 압축되어 있지 않습니다.
3. 크래킹 과정에서 PHP 암호화의 결함에 대해서도 알게 되었습니다.

【추천 학습: PHP 비디오 튜토리얼

위 내용은 PHP 암호화 파일을 복원하는 단계별 실용적인 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

CakePHP 프로젝트 구성 CakePHP 프로젝트 구성 Sep 10, 2024 pm 05:25 PM

이번 장에서는 CakePHP의 환경 변수, 일반 구성, 데이터베이스 구성, 이메일 구성에 대해 알아봅니다.

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Dec 24, 2024 pm 04:42 PM

PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP 데이터베이스 작업 CakePHP 데이터베이스 작업 Sep 10, 2024 pm 05:25 PM

CakePHP에서 데이터베이스 작업은 매우 쉽습니다. 이번 장에서는 CRUD(생성, 읽기, 업데이트, 삭제) 작업을 이해하겠습니다.

CakePHP 날짜 및 시간 CakePHP 날짜 및 시간 Sep 10, 2024 pm 05:27 PM

cakephp4에서 날짜와 시간을 다루기 위해 사용 가능한 FrozenTime 클래스를 활용하겠습니다.

CakePHP 파일 업로드 CakePHP 파일 업로드 Sep 10, 2024 pm 05:27 PM

파일 업로드 작업을 위해 양식 도우미를 사용할 것입니다. 다음은 파일 업로드의 예입니다.

CakePHP 라우팅 CakePHP 라우팅 Sep 10, 2024 pm 05:25 PM

이번 장에서는 라우팅과 관련된 다음과 같은 주제를 학습하겠습니다.

CakePHP 토론 CakePHP 토론 Sep 10, 2024 pm 05:28 PM

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

CakePHP 유효성 검사기 만들기 CakePHP 유효성 검사기 만들기 Sep 10, 2024 pm 05:26 PM

컨트롤러에 다음 두 줄을 추가하면 유효성 검사기를 만들 수 있습니다.

See all articles