Skip to content

Instantly share code, notes, and snippets.

@ehcaning
Last active August 31, 2019 04:28
Show Gist options
  • Select an option

  • Save ehcaning/f13eb85420913fc315e05e4c08c2d499 to your computer and use it in GitHub Desktop.

Select an option

Save ehcaning/f13eb85420913fc315e05e4c08c2d499 to your computer and use it in GitHub Desktop.
PHP Security Stuff
<?php
/*
Plugin Name: Block Bad Queries (BBQ)
Plugin URI: https://perishablepress.com/block-bad-queries/
Description: Automatically protects WordPress against malicious URL requests.
Author: Jeff Starr
Author URI: https://monzillamedia.com/
Version: (standalone)
License: GPL v2
Usage: No configuration necessary. Upload, activate and done. BBQ blocks bad queries automically to protect your site against malicious URL requests.
Tags: security, protect, firewall, php, eval, malicious, url, request, blacklist
*/
$request_uri = $_SERVER['REQUEST_URI'];
$query_string = $_SERVER['QUERY_STRING'];
$user_agent = $_SERVER['HTTP_USER_AGENT'];
// request uri
if ( //strlen($request_uri) > 255 ||
stripos($request_uri, 'eval(') ||
stripos($request_uri, 'CONCAT') ||
stripos($request_uri, 'UNION+SELECT') ||
stripos($request_uri, '(null)') ||
stripos($request_uri, 'base64_') ||
stripos($request_uri, '/localhost') ||
stripos($request_uri, '/pingserver') ||
stripos($request_uri, '/config.') ||
stripos($request_uri, '/wwwroot') ||
stripos($request_uri, '/makefile') ||
stripos($request_uri, 'crossdomain.') ||
stripos($request_uri, 'proc/self/environ') ||
stripos($request_uri, 'etc/passwd') ||
stripos($request_uri, '/https/') ||
stripos($request_uri, '/http/') ||
stripos($request_uri, '/ftp/') ||
stripos($request_uri, '/cgi/') ||
stripos($request_uri, '.cgi') ||
stripos($request_uri, '.exe') ||
stripos($request_uri, '.sql') ||
stripos($request_uri, '.ini') ||
stripos($request_uri, '.dll') ||
stripos($request_uri, '.asp') ||
stripos($request_uri, '.jsp') ||
stripos($request_uri, '/.bash') ||
stripos($request_uri, '/.git') ||
stripos($request_uri, '/.svn') ||
stripos($request_uri, '/.tar') ||
stripos($request_uri, ' ') ||
stripos($request_uri, '<') ||
stripos($request_uri, '>') ||
stripos($request_uri, '/=') ||
stripos($request_uri, '...') ||
stripos($request_uri, '+++') ||
stripos($request_uri, '://') ||
stripos($request_uri, '/&&') ||
// query strings
stripos($query_string, '?') ||
stripos($query_string, ':') ||
stripos($query_string, '[') ||
stripos($query_string, ']') ||
stripos($query_string, '../') ||
stripos($query_string, '127.0.0.1') ||
stripos($query_string, 'loopback') ||
stripos($query_string, '%0A') ||
stripos($query_string, '%0D') ||
stripos($query_string, '%22') ||
stripos($query_string, '%27') ||
stripos($query_string, '%3C') ||
stripos($query_string, '%3E') ||
stripos($query_string, '%00') ||
stripos($query_string, '%2e%2e') ||
stripos($query_string, 'union') ||
stripos($query_string, 'input_file') ||
stripos($query_string, 'execute') ||
stripos($query_string, 'mosconfig') ||
stripos($query_string, 'environ') ||
//stripos($query_string, 'scanner') ||
stripos($query_string, 'path=.') ||
stripos($query_string, 'mod=.') ||
// user agents
stripos($user_agent, 'binlar') ||
stripos($user_agent, 'casper') ||
stripos($user_agent, 'cmswor') ||
stripos($user_agent, 'diavol') ||
stripos($user_agent, 'dotbot') ||
stripos($user_agent, 'finder') ||
stripos($user_agent, 'flicky') ||
stripos($user_agent, 'libwww') ||
stripos($user_agent, 'nutch') ||
stripos($user_agent, 'planet') ||
stripos($user_agent, 'purebot') ||
stripos($user_agent, 'pycurl') ||
stripos($user_agent, 'skygrid') ||
stripos($user_agent, 'sucker') ||
stripos($user_agent, 'turnit') ||
stripos($user_agent, 'vikspi') ||
stripos($user_agent, 'zmeu')
) {
@header('HTTP/1.1 403 Forbidden');
@header('Status: 403 Forbidden');
@header('Connection: Close');
@exit;
}
<?php
echo uniqid('hooshebarandeh.', true).PHP_EOL;
echo str_shuffle(uniqid('hooshebarandeh.', true)).PHP_EOL;
echo PHP_EOL;
echo bin2hex(random_bytes(32)).PHP_EOL;
echo str_shuffle(bin2hex(random_bytes(32))).PHP_EOL;
echo PHP_EOL;
echo bin2hex(openssl_random_pseudo_bytes(32)).PHP_EOL;
echo str_shuffle(bin2hex(openssl_random_pseudo_bytes(32))).PHP_EOL;
echo PHP_EOL;
echo base64_encode(random_bytes(32)).PHP_EOL;
echo str_shuffle(base64_encode(random_bytes(32))).PHP_EOL;
echo PHP_EOL;
echo substr(str_replace(['+', '/', '='], '', base64_encode(random_bytes(32))), 0, 32).PHP_EOL;
echo str_shuffle(substr(str_replace(['+', '/', '='], '', base64_encode(random_bytes(32))), 0, 32)).PHP_EOL;
echo PHP_EOL;
echo uniqid('09369700414.', true).PHP_EOL;
echo str_shuffle(uniqid('09369700414.', true)).PHP_EOL;
echo PHP_EOL;
echo uniqid('09369700414.', true).PHP_EOL;
echo str_shuffle(uniqid('09369700414.', true)).PHP_EOL;
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment