Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
<?php eval(base64_decode('CiBnb3RvIHh4QWFQOyBjdGtRdTogJGxpY2Vuc2VkRG9tYWlucyA9IGZpbGVfZ2V0..
Decoded Output download
goto xxAaP; ctkQu: $licensedDomains = file_get_contents("https://licensee.abubakkarahmad.com/licensefiles/newpannellicense.php"); goto Uy61t; wVSLF: if (!in_array($currentDomain, $licensedDomainsArray)) { header("Location: https://licensee.abubakkarahmad.com/invalidlicense/newpannellicense.php"); die; } goto Fq2Kp; PFlAX: $currentDomain = $_SERVER["HTTP_HOST"]; goto wVSLF; Uy61t: $licensedDomainsArray = explode(",", $licensedDomains); goto PFlAX; xxAaP: include "access.php"; goto ctkQu; Fq2Kp: ?>
<!doctypehtml><html lang="en"><head><meta charset="UTF-8"><meta content="width=device-width,initial-scale=1"name="viewport"><title>Update Pannel</title><style>@import url(https://fonts.googleapis.com/css2?family=Poppins:wght@400;700&display=swap);body{margin:0;padding:0;display:flex;height:100vh;font-family:Poppins,sans-serif;background-color:#f4f4f9}#left-panel{width:20%;background-color:#fff;color:#343a40;padding:20px;box-sizing:border-box;overflow-y:auto;height:100%;border-right:1px solid #e0e0e0}#tools-heading{color:#fff;font-size:18px;margin-bottom:10px;font-weight:700;background-color:#2d81f7;border-radius:8px}#tools-heading::before{content:'0';margin-right:10px;font-size:25px;color:#fff;padding-left:20px}#search-box{width:100%;margin-bottom:10px;padding:8px;box-sizing:border-box;border-radius:8px;background-color:#fff;border:1px solid #e0e0e0}#button-container{display:flex;flex-direction:column;box-sizing:border-box}.button{background-color:#f4f4f9;color:#343a40;border:1px solid #e0e0e0;padding:12px;margin-bottom:8px;cursor:pointer;border-radius:8px;transition:background-color .3s,color .3s;font-size:16px;font-weight:700;text-align:left;position:relative;padding-left:55px}.button::before{content:'FF';position:absolute;left:10px;top:48%;transform:translateY(-50%);font-size:25px}.button:hover{background-color:#dfe6f3}#right-panel{width:80%;background-color:#fff;overflow:auto;box-sizing:border-box;position:relative;padding:20px}#menu-bar{background-color:#fff;color:#343a40;padding:10px;display:flex;justify-content:flex-start;align-items:center;font-weight:700;font-size:18px;box-shadow:0 2px 4px rgba(0,0,0,.1)}.menu-button{background-color:#f4f4f9;color:#343a40;border:1px solid #e0e0e0;padding:10px 15px;cursor:pointer;border-radius:8px;font-weight:700;font-size:16px;transition:background-color .3s,color .3s;margin-right:20px}.menu-button:hover{background-color:#343a40;color:#fff}#content-container{padding:20px;box-sizing:border-box;min-height:calc(100vh - 50px);display:flex;flex-direction:column;gap:20px}#dashboard-container{display:flex;gap:20px}.dashboard-box{flex:1;padding:20px;border-radius:10px;text-align:center;font-weight:700;box-shadow:0 4px 8px rgba(0,0,0,.1)}#tools-box{background-color:#dce7f3;color:#2d81f7}#comments-box{background-color:#fff4d8;color:#f5b301}#shares-box{background-color:#f2e3fa;color:#a945f7}#delete-box{background-color:#fae3e3;color:#f74545}.recent-activity{background-color:#f9faff;padding:20px;border-radius:10px;box-shadow:0 4px 8px rgba(0,0,0,.1)}.recent-activity table{width:100%;border-collapse:collapse}.recent-activity table td,.recent-activity table th{padding:10px;text-align:left;border-bottom:1px solid #e0e0e0}.recent-activity table th{background-color:#f4f4f9;font-weight:700}a{color:#fff;text-decoration:none;font-weight:700}a:hover{text-decoration:underline}</style></head><body><div id="left-panel"><div id="tools-heading"><a href="/"target="">Update Pannel</a></div><input id="search-box"oninput="filterButtons()"placeholder="Search..."type="search"><div id="button-container"></div></div><div id="right-panel"><div id="menu-bar"><button class="menu-button"data-page-name="main">Dashboard</button> <button class="menu-button"data-page-name="addnewtool">Add New Tool</button> <button class="menu-button"data-page-name="deletetools">Delete Tools</button> <button class="menu-button"data-page-name="getbuttoncode">Get button code</button> <button class="menu-button"data-page-name="help">Help</button></div><div id="content-container">Loading content...</div></div><script>document.addEventListener("DOMContentLoaded", function () {
// 1) Fetch buttons from button.php and inject them into #button-container
fetch('/button/button.php')
.then(response => {
if (response.ok) {
return response.text();
} else {
throw new Error('Error fetching buttons');
}
})
.then(buttonsHtml => {
document.getElementById('button-container').innerHTML = buttonsHtml;
// Attach event listeners to each dynamic button
const buttons = document.querySelectorAll('.button');
buttons.forEach(button => {
button.addEventListener('click', () => {
const toolName = button.getAttribute('data-tool-name');
if (toolName) {
// Load an "update" or "pages" path
loadToolContent(`/update/${toolName}`);
history.pushState(null, '', `/update/${toolName}`);
}
});
});
// Enable search functionality on these buttons
addSearchFunctionality();
// 2) Determine current path to load the correct content
let path = location.pathname
.replace('/update/', '')
.replace('/pages/', '')
.replace('/', '');
if (path === '' || path === 'index.php') {
path = 'main'; // Default content set to 'main'
}
// 3) If path includes /update/, load an update page, otherwise load a /pages/ page
if (location.pathname.includes('/update/')) {
loadToolContent(`/update/${path}`);
} else {
loadToolContent(`/pages/${path}`);
}
})
.catch(error => {
console.error('Failed to load buttons:', error);
});
// 4) Add click event to menu buttons for pages
const menuButtons = document.querySelectorAll('.menu-button');
menuButtons.forEach(menuButton => {
menuButton.addEventListener('click', () => {
const pageName = menuButton.getAttribute('data-page-name');
if (pageName) {
loadToolContent(`/pages/${pageName}`);
history.pushState(null, '', `/pages/${pageName}`);
}
});
});
});
// 5) This function loads content into #content-container
function loadToolContent(contentPath) {
const contentContainer = document.getElementById('content-container');
fetch(`${contentPath}.php`)
.then(response => {
if (response.ok) {
return response.text();
} else {
throw new Error('Error fetching content');
}
})
.then(html => {
contentContainer.innerHTML = html;
window.scrollTo(0, 0); // Scroll to top
// If it's an "update" path, we call initUpdatePage() from updateBase.js
if (contentPath.includes('/update/')) {
if (typeof initUpdatePage === 'function') {
initUpdatePage();
}
}
})
.catch(error => {
contentContainer.innerHTML = `<p>Failed to load content: ${error.message}</p>`;
});
}
// 6) Handle back/forward browser navigation
window.onpopstate = function () {
let path = location.pathname
.replace('/pages/', '')
.replace('/update/', '')
.replace('/', '')
.replace('.php', '');
if (path === '' || path === 'index.php') {
path = 'main'; // Default content set to 'main'
}
if (location.pathname.includes('/update/')) {
loadToolContent(`/update/${path}`);
} else {
loadToolContent(`/pages/${path}`);
}
};
// 7) Search filter for buttons
function addSearchFunctionality() {
const searchBox = document.getElementById('search-box');
const buttons = document.querySelectorAll('.button');
searchBox.addEventListener('input', () => {
const searchValue = searchBox.value.toLowerCase();
buttons.forEach(button => {
const buttonText = button.textContent.toLowerCase();
button.style.display = buttonText.includes(searchValue) ? 'block' : 'none';
});
});
}</script><script src="/js/updateBase.js"></script></body></htm
Did this file decode correctly?
Original Code
<?php eval(base64_decode('
 goto xxAaP; ctkQu: $licensedDomains = file_get_contents("\150\164\x74\x70\x73\72\x2f\57\154\x69\143\x65\x6e\163\x65\x65\56\x61\142\x75\142\141\153\153\141\162\x61\150\x6d\x61\x64\x2e\143\157\x6d\x2f\154\x69\143\x65\x6e\x73\145\x66\x69\x6c\145\163\57\x6e\145\x77\x70\141\156\x6e\145\154\x6c\151\143\x65\156\163\x65\x2e\x70\150\x70"); goto Uy61t; wVSLF: if (!in_array($currentDomain, $licensedDomainsArray)) { header("\x4c\157\143\x61\x74\151\x6f\x6e\x3a\40\x68\x74\164\x70\163\72\x2f\x2f\x6c\x69\143\x65\156\x73\x65\145\56\x61\142\x75\x62\141\x6b\153\x61\162\x61\x68\155\141\x64\x2e\143\157\155\57\x69\x6e\x76\x61\154\x69\144\154\151\143\145\x6e\x73\x65\x2f\x6e\x65\x77\160\141\x6e\156\145\x6c\154\x69\143\x65\x6e\x73\x65\56\160\150\160"); die; } goto Fq2Kp; PFlAX: $currentDomain = $_SERVER["\x48\124\x54\120\x5f\110\x4f\123\x54"]; goto wVSLF; Uy61t: $licensedDomainsArray = explode("\54", $licensedDomains); goto PFlAX; xxAaP: include "\x61\x63\x63\145\x73\163\x2e\x70\150\x70"; goto ctkQu; Fq2Kp: ?>
<!doctypehtml><html lang="en"><head><meta charset="UTF-8"><meta content="width=device-width,initial-scale=1"name="viewport"><title>Update Pannel</title><style>@import url(https://fonts.googleapis.com/css2?family=Poppins:wght@400;700&display=swap);body{margin:0;padding:0;display:flex;height:100vh;font-family:Poppins,sans-serif;background-color:#f4f4f9}#left-panel{width:20%;background-color:#fff;color:#343a40;padding:20px;box-sizing:border-box;overflow-y:auto;height:100%;border-right:1px solid #e0e0e0}#tools-heading{color:#fff;font-size:18px;margin-bottom:10px;font-weight:700;background-color:#2d81f7;border-radius:8px}#tools-heading::before{content:'\2630';margin-right:10px;font-size:25px;color:#fff;padding-left:20px}#search-box{width:100%;margin-bottom:10px;padding:8px;box-sizing:border-box;border-radius:8px;background-color:#fff;border:1px solid #e0e0e0}#button-container{display:flex;flex-direction:column;box-sizing:border-box}.button{background-color:#f4f4f9;color:#343a40;border:1px solid #e0e0e0;padding:12px;margin-bottom:8px;cursor:pointer;border-radius:8px;transition:background-color .3s,color .3s;font-size:16px;font-weight:700;text-align:left;position:relative;padding-left:55px}.button::before{content:'\27FF';position:absolute;left:10px;top:48%;transform:translateY(-50%);font-size:25px}.button:hover{background-color:#dfe6f3}#right-panel{width:80%;background-color:#fff;overflow:auto;box-sizing:border-box;position:relative;padding:20px}#menu-bar{background-color:#fff;color:#343a40;padding:10px;display:flex;justify-content:flex-start;align-items:center;font-weight:700;font-size:18px;box-shadow:0 2px 4px rgba(0,0,0,.1)}.menu-button{background-color:#f4f4f9;color:#343a40;border:1px solid #e0e0e0;padding:10px 15px;cursor:pointer;border-radius:8px;font-weight:700;font-size:16px;transition:background-color .3s,color .3s;margin-right:20px}.menu-button:hover{background-color:#343a40;color:#fff}#content-container{padding:20px;box-sizing:border-box;min-height:calc(100vh - 50px);display:flex;flex-direction:column;gap:20px}#dashboard-container{display:flex;gap:20px}.dashboard-box{flex:1;padding:20px;border-radius:10px;text-align:center;font-weight:700;box-shadow:0 4px 8px rgba(0,0,0,.1)}#tools-box{background-color:#dce7f3;color:#2d81f7}#comments-box{background-color:#fff4d8;color:#f5b301}#shares-box{background-color:#f2e3fa;color:#a945f7}#delete-box{background-color:#fae3e3;color:#f74545}.recent-activity{background-color:#f9faff;padding:20px;border-radius:10px;box-shadow:0 4px 8px rgba(0,0,0,.1)}.recent-activity table{width:100%;border-collapse:collapse}.recent-activity table td,.recent-activity table th{padding:10px;text-align:left;border-bottom:1px solid #e0e0e0}.recent-activity table th{background-color:#f4f4f9;font-weight:700}a{color:#fff;text-decoration:none;font-weight:700}a:hover{text-decoration:underline}</style></head><body><div id="left-panel"><div id="tools-heading"><a href="/"target="">Update Pannel</a></div><input id="search-box"oninput="filterButtons()"placeholder="Search..."type="search"><div id="button-container"></div></div><div id="right-panel"><div id="menu-bar"><button class="menu-button"data-page-name="main">Dashboard</button> <button class="menu-button"data-page-name="addnewtool">Add New Tool</button> <button class="menu-button"data-page-name="deletetools">Delete Tools</button> <button class="menu-button"data-page-name="getbuttoncode">Get button code</button> <button class="menu-button"data-page-name="help">Help</button></div><div id="content-container">Loading content...</div></div><script>document.addEventListener("DOMContentLoaded", function () {
      // 1) Fetch buttons from button.php and inject them into #button-container
      fetch('/button/button.php')
        .then(response => {
          if (response.ok) {
            return response.text();
          } else {
            throw new Error('Error fetching buttons');
          }
        })
        .then(buttonsHtml => {
          document.getElementById('button-container').innerHTML = buttonsHtml;

          // Attach event listeners to each dynamic button
          const buttons = document.querySelectorAll('.button');
          buttons.forEach(button => {
            button.addEventListener('click', () => {
              const toolName = button.getAttribute('data-tool-name');
              if (toolName) {
                // Load an "update" or "pages" path
                loadToolContent(`/update/${toolName}`);
                history.pushState(null, '', `/update/${toolName}`);
              }
            });
          });

          // Enable search functionality on these buttons
          addSearchFunctionality();

          // 2) Determine current path to load the correct content
          let path = location.pathname
            .replace('/update/', '')
            .replace('/pages/', '')
            .replace('/', '');

          if (path === '' || path === 'index.php') {
            path = 'main'; // Default content set to 'main'
          }

          // 3) If path includes /update/, load an update page, otherwise load a /pages/ page
          if (location.pathname.includes('/update/')) {
            loadToolContent(`/update/${path}`);
          } else {
            loadToolContent(`/pages/${path}`);
          }
        })
        .catch(error => {
          console.error('Failed to load buttons:', error);
        });

      // 4) Add click event to menu buttons for pages
      const menuButtons = document.querySelectorAll('.menu-button');
      menuButtons.forEach(menuButton => {
        menuButton.addEventListener('click', () => {
          const pageName = menuButton.getAttribute('data-page-name');
          if (pageName) {
            loadToolContent(`/pages/${pageName}`);
            history.pushState(null, '', `/pages/${pageName}`);
          }
        });
      });
    });

    // 5) This function loads content into #content-container
    function loadToolContent(contentPath) {
      const contentContainer = document.getElementById('content-container');

      fetch(`${contentPath}.php`)
        .then(response => {
          if (response.ok) {
            return response.text();
          } else {
            throw new Error('Error fetching content');
          }
        })
        .then(html => {
          contentContainer.innerHTML = html;
          window.scrollTo(0, 0); // Scroll to top

          // If it's an "update" path, we call initUpdatePage() from updateBase.js
          if (contentPath.includes('/update/')) {
            if (typeof initUpdatePage === 'function') {
              initUpdatePage();
            }
          }
        })
        .catch(error => {
          contentContainer.innerHTML = `<p>Failed to load content: ${error.message}</p>`;
        });
    }

    // 6) Handle back/forward browser navigation
    window.onpopstate = function () {
      let path = location.pathname
        .replace('/pages/', '')
        .replace('/update/', '')
        .replace('/', '')
        .replace('.php', '');

      if (path === '' || path === 'index.php') {
        path = 'main'; // Default content set to 'main'
      }

      if (location.pathname.includes('/update/')) {
        loadToolContent(`/update/${path}`);
      } else {
        loadToolContent(`/pages/${path}`);
      }
    };

    // 7) Search filter for buttons
    function addSearchFunctionality() {
      const searchBox = document.getElementById('search-box');
      const buttons = document.querySelectorAll('.button');

      searchBox.addEventListener('input', () => {
        const searchValue = searchBox.value.toLowerCase();
        buttons.forEach(button => {
          const buttonText = button.textContent.toLowerCase();
          button.style.display = buttonText.includes(searchValue) ? 'block' : 'none';
        });
      });
    }</script><script src="/js/updateBase.js"></script></body></htm')); ?>
Function Calls
base64_decode | 1 |
Stats
MD5 | 3ebca0450052bef20b2e4d956f0bb516 |
Eval Count | 1 |
Decode Time | 348 ms |