Ladda ner: Plugin för att glömma spamkommentarer
Det här är ett gratis insticksprogram mot skräppost som enbart är avsett för WordPress standardkommentarsystem.
Hur fungerar det?
Alternativt, för avancerade användare, är den manuella metoden nedan.
Standardkommentarsystemet i WordPress har två stora problem.
- Lockar till sig skräppostkommentarer.
- Skicka inget uppföljningsmeddelande till författaren av kommentaren (kommer att diskuteras om ett tag).
Låt oss tala om dess lösningar.
Förhindra skräppostkommentarer
I stället för att direkt tillåta vem som helst att göra en POST-förfrågan på /wp-comments-post.php
kan vi lägga till lite logik för att förhindra skräppostkommentarer till 100 %.
Steg 1. Begränsning av sökvägen för POST-kommentarer via frågeparametrar
Jag kommer att dela med mig av tre sätt, använd en metod.
Apache
- Yoast > Gå till Verktyg > Filredigerare
- RankMath > Gå till Allmänna inställningar > Redigera .htaccess
- FTP/SSH > Kolla
/var/www/html
# If Query string doesn't matches return 404
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteCond %{REQUEST_URI} .wp-comments-post\.php
# You may change 45jpfAY9RcNeFP to something else
RewriteCond %{QUERY_STRING} !^45jpfAY9RcNeFP
RewriteRule (.*) - [R=404,L]
</IfModule>
Om du använder LiteSpeed har den också stöd för .htaccess-filer. Du måste starta om efter genomförandet.
NGINX
location = /wp-comments-post.php {
if ($query_string !~ "45jpfAY9RcNeFP") {
return 404;
}
}
Cloudflare
data:image/s3,"s3://crabby-images/d19d7/d19d768ef62836893a7fbb1ef7f56585984d26b6" alt="prevent spam comments"
- Logga in för att Cloudflare Dashboard
- Gå till Firewall > Firewall Rules
- Skapa en ny brandväggsregel med följande uttryck
Fält | Operatör | Värde | |
URI | contains | wp-comments-post.php | And |
URL Query String | does not equal | 45jpfAY9RcNeFP |
- Välj åtgärd: Blocka
I slutet kommer du att se ett uttryck
(http.request.uri contains "wp-comments-post.php" and http.request.uri.query ne "45jpfAY9RcNeFP")
Steg 2. Korrigera URL:en för Comment POST vid Scroll-evenemanget
- Lägg till nedanstående funktion med hjälp av insticksprogrammet Code Snippets eller temat functions.php
- Se till att du använder rätt domän och formulär-ID.
function correct_comment_url_on_scroll() {
// Check if Comment is enabled
if(comments_open()) echo '<script>
let commentForm = document.querySelector("#commentform, #ast-commentform, #ht-commentform");
// Load new comment path on the scroll event
document.onscroll = function () {
commentForm.action = "https://www.example.com/wp-comments-post.php?45jpfAY9RcNeFP";
};
</script>';
}
add_action('wp_footer', 'correct_comment_url_on_scroll', 99);
Om du använder GeneratePress Premium-tema kan du också lägga till ovanstående JS-del direkt med hjälp av Elements-modulen.
<script>
let commentForm = document.querySelector("#commentform");
commentForm.action = "https://www.example.com/wp-comments-post.php";
// Load new comment path on the scroll event
document.onscroll = function () {
commentForm.action = "https://www.example.com/wp-comments-post.php?45jpfAY9RcNeFP";
};
</script>
- Lägg till en ny hook
- Ny Hook Titel: Ändra URL för kommentarer i farten
- Hook: WP Footer
- Prioritet: 99
- Plats: Inlägg – Alla inlägg
- Publicera
Hur kan jag kontrollera om den fungerar?
- Generellt sett returnerar WordPress 405 svar för GET-förfrågan på
/wp-comments-post.php
- Men efter ovanstående inställning bör du se Access Denied (Åtkomst nekad).
- Och URL:en ska bara laddas om det finns en särskild Query String
45jpfAY9RcNeFP
som vi lagt till för att förhindra skräppost. Du kan ändra den här frågeteckensträngen till något annat i alla ovanstående konfigurationer. - Källkoden visar vanligtvis sökvägen
wp-comments-post.php
, men om du inspekterar elementet efter rullning kommer du att märka att en frågeteckensträng har lagts till.
Resultat nr 1: Ingen skräppost
data:image/s3,"s3://crabby-images/ecb2a/ecb2a2c536879462df423fcffd1a3a4d5f1e9660" alt="no spam"
Resultat nr 2: Spammare blockeras
data:image/s3,"s3://crabby-images/da5ec/da5ec112981ea6887a386a71c68eb7e7f6151eec" alt="log"
Bonustips för att göra standardkommentarsystemet ännu bättre
- Som standard skickar WordPress kommentarsystem inget uppföljningsmeddelande till kommentarsförfattaren. För att åtgärda det här problemet kan du använda plugin Comment Reply Email Notification av Arno Welzel.
Om du gillar den här informationen kan du skicka den vidare till dina vänner. 🙏
Thank you so much Sir Gulshan Kumar! I really appreciate your guide, and this has saved me tons of headache. Implemented via Cloudflare WAF plus Generatepress Elements Module.
Glad to hear. Thank you!
By the way, how do you know if legit users won’t get blocked? Before this, I’ve been using a CF firewall rules that will blocks or challenge anyone who visit wp-comments-post.php but actually by doing so, legit users also got blocked. How this one different? Is it because of the string ”45jpfAY9RcNeFP” that will differentiate which request is from bot and which request is from legit users? If legit users, they should’ve the string, if it’s spam, they don’t have that string. Am I understand it correctly?
You need to implement exactly as per instructions to prevent users from blocking.
Does this plugin / method will stop website from having spam comments once and for all or do we still receive it but it’s automatically filtered from the real comments (like Akismet)?
There is no filter. It just stops spam.
That is so cool! Will try it. Thank youuuuuuuuuuuuuu
You’re welcome!
The best plugin to filter the spam.
Hi Gulshan.
I just wanted to let you know that I’ve been using your plugin for a few weeks now and it is brilliant. Genuine comments still get through but all of the spam, and I mean ALL of it, is filtered out. Excellent job!
Well done and thank you so much for sharing it for free so that hobby bloggers like me can make use of it.
thank you very useful
Hy! I just installed your plugin but Google Console show me tons of errors:
https://prnt.sc/wnhkbd
How can I solve this? Thanks!!
Hi,
I am also using plugin at this blog. It works perfectly fine here.
If you want to me look into this issue, please provide your actual site URL where I can see live.
Thanks!
Brilliant! Thank you so much!
I have question
Where can I get value code like 45jpfAY9RcNeFP
You can use MD5 generator or write any random text. I’d recommend using plugin for set and forget experience.
Good plugins for stopping spam.
I have use this plugin earlier. It is working perfectly.
Wow! This is great. Thanks a lot. Gonna give a try to this trick.
Glad, this is not a spam comment. Just kidding!
Thanks Huzaifa!😊