<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/">
  <channel>
    <title>PHP on CyberVeille</title>
    <link>https://cyberveille.ch/tags/php/</link>
    <description>Recent content in PHP on CyberVeille</description>
    <generator>Hugo -- 0.146.0</generator>
    <language>fr-fr</language>
    <copyright>Cyberveille CC BY-NC-SA 4.0</copyright>
    <lastBuildDate>Sun, 03 May 2026 00:00:00 +0000</lastBuildDate>
    <atom:link href="https://cyberveille.ch/tags/php/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>PHP 8.5.5 : UAF 21 ans dans unserialize() exploité en RCE local et distant</title>
      <link>https://cyberveille.ch/posts/2026-05-03-php-8-5-5-uaf-21-ans-dans-unserialize-exploite-en-rce-local-et-distant/</link>
      <pubDate>Sun, 03 May 2026 00:00:00 +0000</pubDate>
      <guid>https://cyberveille.ch/posts/2026-05-03-php-8-5-5-uaf-21-ans-dans-unserialize-exploite-en-rce-local-et-distant/</guid>
      <description>&lt;h2 id=&#34;-contexte&#34;&gt;🔍 Contexte&lt;/h2&gt;
&lt;p&gt;Publié le 2 mai 2026 sur le blog de Calif (blog.calif.io), cet article technique détaille la découverte et l&amp;rsquo;exploitation d&amp;rsquo;une vulnérabilité &lt;strong&gt;use-after-free (UAF)&lt;/strong&gt; dans la fonction &lt;strong&gt;&lt;code&gt;unserialize()&lt;/code&gt; de PHP&lt;/strong&gt;, présente depuis &lt;strong&gt;PHP 5.1 (2005)&lt;/strong&gt; et toujours exploitable dans &lt;strong&gt;PHP 8.5.5&lt;/strong&gt;. La découverte s&amp;rsquo;inscrit dans le cadre du projet &lt;strong&gt;MAD Bugs (Month of AI-Discovered Bugs)&lt;/strong&gt;, combinant modèles d&amp;rsquo;IA (Claude) et expertise humaine.&lt;/p&gt;
&lt;h2 id=&#34;-la-vulnérabilité&#34;&gt;🐛 La vulnérabilité&lt;/h2&gt;
&lt;p&gt;Le bug réside dans &lt;strong&gt;&lt;code&gt;zend_user_unserialize()&lt;/code&gt;&lt;/strong&gt; (fichier &lt;code&gt;Zend/zend_interfaces.c&lt;/code&gt;), le point de dispatch pour &lt;code&gt;Serializable::unserialize()&lt;/code&gt;. Contrairement à tous les autres points de dispatch utilisateur (&lt;code&gt;__wakeup&lt;/code&gt;, &lt;code&gt;__unserialize&lt;/code&gt;, &lt;code&gt;__destruct&lt;/code&gt;), cette fonction &lt;strong&gt;omet d&amp;rsquo;incrémenter &lt;code&gt;BG(serialize_lock)&lt;/code&gt;&lt;/strong&gt;, ce qui permet à un appel récursif à &lt;code&gt;unserialize()&lt;/code&gt; de &lt;strong&gt;partager le &lt;code&gt;var_hash&lt;/code&gt; externe&lt;/strong&gt;.&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
