On my IT consulting business site, I’m using a php script I’ve written to generate on-the-fly random email addresses specific to the browsing session looking at the site. So, I can include email addresses in plain text on the site, but if a spammer harvests one, I can block it, and other people legitimately browsing the site will still get individualized working addresses they can contact me with.It generates a log as email are generated, so you know who got what email. You’ll want to watch the log size yourself so you don’t fill your disk space.Obviously it’s more complicated than just this, there’s whitelisting involved as well as some other behind-the-scenes trickery, such as double-checking emails against the log as they arrive, that I can’t reveal publicly for opsec reasons.But, I can reveal the basic php script that coughs up a random email address specific to the session info. A WordPress shortcode that allows calling custom PHP scripts is set to run this script, and placed on the site where I want a working contact email address to be displayed.Right now it works for me with PHP8.4. YMMV.A word of warning: I wrote this a long time ago, and hate PHP, and really don’t remember how it works. Please don’t write with questions or support requests, this is an “as is” freebee. I’m sure you can find someone who’s better at PHP than I am to help you with anything.Basically, I just stuck this here because I’m first setting this site up and need some content to test the layouts. Don’t expect more than that.Also, I know it’s badly flowed and hard to read. If you think I’m going to battle WordPress’s broken editor trying to get it to display a code block correctly, you’ve got another think coming.<?php// –USER SETTINGS:$myDomain=”YourEmailDomainHere.com”;$file=”NameForYourLogFileHere.log”; //generated emails and user session info will be logged in the logfile you specify$wordArray=array(“apple”,”pear”,”banana”,”cherry”); //in wordArray, enter some words to use in the generated email addresses, since email addresses can’t start with a number. Then, to prevent spamming to catchall addresses, you can filter for these valid words and reject incoming emails that don’t start with them.$salt=”ENTERsomeRANDOMcharactersHEREasAcryptographicSALT”;// –END OF USER SETTINGSif(!isset($_SESSION)) { session_start(); } ini_set(‘display_errors’, 1); ini_set(‘display_startup_errors’, 1); error_reporting(E_ALL);if (!isset($_SESSION[‘theEmail’])) {function getUserIpAddr(){ if(!empty($_SERVER[‘HTTP_CLIENT_IP’])){ //ip from share internet $ip = $_SERVER[‘HTTP_CLIENT_IP’]; }elseif(!empty($_SERVER[‘HTTP_X_FORWARDED_FOR’])){ //ip pass from proxy $ip = $_SERVER[‘HTTP_X_FORWARDED_FOR’]; }else{ $ip = $_SERVER[‘REMOTE_ADDR’]; } return $ip; }function getUA() { if(!isset($_SERVER[‘HTTP_USER_AGENT’])) {return “none”;} else { return $_SERVER[‘HTTP_USER_AGENT’];} }$theOutput =””;// Write the contents back to the file$n=10; $m=2;function getName($n) { $theBrowserDetails=””; foreach (getallheaders() as $name => $value) { $theBrowserDetails .= “$name: $value\n”; } // Append a new person to the file $current = ‘Date – ‘.date(“c”).”\n”; $current .= ‘Detected IP – ‘.$_SERVER[‘REMOTE_ADDR’].”\n”; $current .= ‘User Real IP – ‘.getUserIpAddr().”\n”; $theUA = getUA(); $current .= $theBrowserDetails.”\n”; $current .= ‘getUA() – ‘.$theUA.”\n”;$theIP=$_SERVER[‘REMOTE_ADDR’].getUserIpAddr();$theIPhash=md5($theIP.$salt.$theUA); $IPhashInt = (int) filter_var($theIPhash, FILTER_SANITIZE_NUMBER_INT); $connectors=”——….._____0123456789″; $wordArrayLength=sizeof($wordArray); $wordIndex=$IPhashInt%$wordArrayLength; $word=$wordArray[$wordIndex]; $wordHash=md5($word.$salt); $theIPhashReversed=md5($theUA.$theIP.$salt); $IPhashReversedInt = (int) filter_var($theIPhashReversed, FILTER_SANITIZE_NUMBER_INT); $randomDigitOne = 1+$IPhashInt%8; $randomDigitTwo = 1+$IPhashReversedInt%8; $randomComboOne = $randomDigitOne * $randomDigitTwo + $randomDigitOne; $randomComboTwo = $randomDigitOne * 10 + $randomDigitTwo; $randomComboThree = $randomDigitOne + $randomDigitTwo*10; $wordHashInt = filter_var($wordHash, FILTER_SANITIZE_NUMBER_INT); $connectorChar=$connectors[($wordHashInt+$randomDigitOne-$randomDigitTwo)%24]; $wordHashFinal = md5(10+(($randomComboThree*($wordHashInt%$randomComboTwo+abs($randomComboOne-$randomComboTwo))) % (2+($randomComboOne*10) % ($randomComboTwo+1)))); $wordHashHashed = $wordHashFinal[-2]; $theResult = $word.$connectorChar.$wordHashHashed.$randomDigitOne.$randomDigitTwo; $current .= “Script generated an email address: “.$theResult.”\n”; $current .= “~ ~ ~ ~\n”;file_put_contents($file, $current,FILE_APPEND);if (filesize($file) > 500*1024) { $filename2 = “$file”.date(“c”); rename($file, $filename2); touch($file); chmod($file,0666); } return $theResult; } $theOutput=getName($n);$_SESSION[‘theEmail’] = $theOutput; } else { $theOutput = $_SESSION[‘theEmail’]; } echo $theOutput.”@”.$myDomain; ?> Mike Kupietz , a reluctant scion of the postmodern age, is larger on the inside than the outside: perhaps not a composer, but a producer and arranger of sounds; nor a writer, but an avid writer-down; an occasional author of doggerel; an erstwhile urban hermit; and privately a man of very great ardor. He is, if now resigned to never succeeding at those personal and artistic pursuits he holds most dear, unwavering in his determination to fail at them as entertainingly as possible. He is currently in what he calls the "red bathrobe period" of his life. If you're wondering what all this has to do with FileMaker development or IT consulting: you done taken the wrong turn, this river don't go to Aintry—Mike's professional services are on his San Francisco FileMaker Pro consulting website. View All PostsPost navigationPrevious Post all imagesNext PostA Helluva Band — Generative Art gallery