Tutorial: Update reCaptcha
Options
Hello all,
There have been some concerns that the Google reCaptcha has not been updated to the latest version within the NetCommunity platform. Here is a temporary fix until they (hopefully) improve the system with the next NC release. Please provide any suggestions to improve this implementation.

1.) Disable the built-in captcha.
2.) Create an unformatted part to add the following html / script to the bottom of your form page. Remember to replace PUBLICKEY with your... public key.
3.) Now upon a postback of your form, it will check for a response from the captcha. If there is no response, the postback will not occur. I will work on adding a validation message, right now the result is logged to console.
Let me know if this works out for you!
Chris
There have been some concerns that the Google reCaptcha has not been updated to the latest version within the NetCommunity platform. Here is a temporary fix until they (hopefully) improve the system with the next NC release. Please provide any suggestions to improve this implementation.

1.) Disable the built-in captcha.
2.) Create an unformatted part to add the following html / script to the bottom of your form page. Remember to replace PUBLICKEY with your... public key.
<div class="g-recaptcha" id="rcaptcha" data-sitekey="PUBLICKEY"></div>
<script src='https://www.google.com/recaptcha/api.js'></script>
<script>
(function ($) {
if (typeof __doPostBack === 'function') {
var old__doPostBack = __doPostBack;
__doPostBack = function (eventTarget, eventArgument) {
$('form').trigger('beforePostBack');
old__doPostBack(eventTarget, eventArgument);
};
}
$.beforePostBack = function (func) {
$('form').on('beforePostBack', function () {
func();
});
};
})(jQuery);
$(document).ready(function(){
$.beforePostBack(function () {
var v = grecaptcha.getResponse();
if(v.length === 0){
console.log('Captcha Error');
return false;
} else {
console.log('Captcha Validated');
}
});
});
</script>
<script src='https://www.google.com/recaptcha/api.js'></script>
<script>
(function ($) {
if (typeof __doPostBack === 'function') {
var old__doPostBack = __doPostBack;
__doPostBack = function (eventTarget, eventArgument) {
$('form').trigger('beforePostBack');
old__doPostBack(eventTarget, eventArgument);
};
}
$.beforePostBack = function (func) {
$('form').on('beforePostBack', function () {
func();
});
};
})(jQuery);
$(document).ready(function(){
$.beforePostBack(function () {
var v = grecaptcha.getResponse();
if(v.length === 0){
console.log('Captcha Error');
return false;
} else {
console.log('Captcha Validated');
}
});
});
</script>
3.) Now upon a postback of your form, it will check for a response from the captcha. If there is no response, the postback will not occur. I will work on adding a validation message, right now the result is logged to console.
Let me know if this works out for you!
Chris
Tagged:
3
Comments
-
Thanks for posting this, Chris!0
-
This is awesome, thank you for sharing. I can get it working, but it sits at the very bottom of my donation form. How can I ensure it is placed before the submit button?
With thanks,
Cas0 -
Hello Cas,
Since you wont be able to edit the html content directly for the part, you can move the location of the element with JS (or jQuery in this instance).
Locate the submit button in the source and find a unique way to target it, you will need to use the "before" function to place content...before it. Since NetCommunity does not follow standard class conventions, you should use a wilcard selector to target the button.
In example: $('input[id*="partial match"]').before('content');
If you're not familiar with JS or jQuery and need help, send me a message and I can help you out real quick.
Email: mail@chrismcgrane.com
or PM me
- Chris
0 -
Hello all - I've got a bunch of PMs / emails from people saying this method is only partially working. This is because the postback is not prevented by the time the form submission is validated. Here is an updated script that should work a little better. The only part that should be fixed is adding in the validation message for a submission without completing the captcha. the conditional is in there, you will just have to decide how to implement the error message. As always, please feel free to contact me directly if you need help (for free of course).
<div class="g-recaptcha" id="rcaptcha" data-sitekey="YOUR PUBLICKEY"></div>
<script src='https://www.google.com/recaptcha/api.js'></script>
<script>
$(document).ready(function(){
$('.DonationSubmitButton').hide();
$('body').append('<button id="submitDonation" type="button">Submit</button>');
$('body').on('click','#submitDonation',function(e){
var v = grecaptcha.getResponse();
if(v.length === 0){
console.log('Captcha Error');
// Validation message triggered here
return false;
} else {
console.log(v);
__doPostBack('ID OF SUBMIT BUTTON','');
// Example ID: PC2497$btnNext
}
});
});
</script>
- Chris McGrane0
Categories
- All Categories
- Shannon parent
- shannon 2
- shannon 1
- 21 Advocacy DC Users Group
- 14 BBCRM PAG Discussions
- 89 High Education Program Advisory Group (HE PAG)
- 28 Luminate CRM DC Users Group
- 8 DC Luminate CRM Users Group
- Luminate PAG
- 5.9K Blackbaud Altru®
- 58 Blackbaud Award Management™ and Blackbaud Stewardship Management™
- 409 bbcon®
- 2.1K Blackbaud CRM™ and Blackbaud Internet Solutions™
- donorCentrics®
- 1.1K Blackbaud eTapestry®
- 2.8K Blackbaud Financial Edge NXT®
- 1.1K Blackbaud Grantmaking™
- 527 Education Management Solutions for Higher Education
- 1 JustGiving® from Blackbaud®
- 4.6K Education Management Solutions for K-12 Schools
- Blackbaud Luminate Online & Blackbaud TeamRaiser
- 16.4K Blackbaud Raiser's Edge NXT®
- 4.1K SKY Developer
- 547 ResearchPoint™
- 151 Blackbaud Tuition Management™
- 1 YourCause® from Blackbaud®
- 61 everydayhero
- 3 Campaign Ideas
- 58 General Discussion
- 115 Blackbaud ID
- 87 K-12 Blackbaud ID
- 6 Admin Console
- 949 Organizational Best Practices
- 353 The Tap (Just for Fun)
- 235 Blackbaud Community Feedback Forum
- 55 Admissions Event Management EAP
- 18 MobilePay Terminal + BBID Canada EAP
- 36 EAP for New Email Campaigns Experience in Blackbaud Luminate Online®
- 109 EAP for 360 Student Profile in Blackbaud Student Information System
- 41 EAP for Assessment Builder in Blackbaud Learning Management System™
- 9 Technical Preview for SKY API for Blackbaud CRM™ and Blackbaud Altru®
- 55 Community Advisory Group
- 46 Blackbaud Community Ideas
- 26 Blackbaud Community Challenges
- 7 Security Testing Forum
- 1.1K ARCHIVED FORUMS | Inactive and/or Completed EAPs
- 3 Blackbaud Staff Discussions
- 7.7K ARCHIVED FORUM CATEGORY [ID 304]
- 1 Blackbaud Partners Discussions
- 1 Blackbaud Giving Search™
- 35 EAP Student Assignment Details and Assignment Center
- 39 EAP Core - Roles and Tasks
- 59 Blackbaud Community All-Stars Discussions
- 20 Blackbaud Raiser's Edge NXT® Online Giving EAP
- Diocesan Blackbaud Raiser’s Edge NXT® User’s Group
- 2 Blackbaud Consultant’s Community
- 43 End of Term Grade Entry EAP
- 92 EAP for Query in Blackbaud Raiser's Edge NXT®
- 38 Standard Reports for Blackbaud Raiser's Edge NXT® EAP
- 12 Payments Assistant for Blackbaud Financial Edge NXT® EAP
- 6 Ask an All Star (Austen Brown)
- 8 Ask an All-Star Alex Wong (Blackbaud Raiser's Edge NXT®)
- 1 Ask an All-Star Alex Wong (Blackbaud Financial Edge NXT®)
- 6 Ask an All-Star (Christine Robertson)
- 21 Ask an Expert (Anthony Gallo)
- Blackbaud Francophone Group
- 22 Ask an Expert (David Springer)
- 4 Raiser's Edge NXT PowerUp Challenge #1 (Query)
- 6 Ask an All-Star Sunshine Reinken Watson and Carlene Johnson
- 4 Raiser's Edge NXT PowerUp Challenge: Events
- 14 Ask an All-Star (Elizabeth Johnson)
- 7 Ask an Expert (Stephen Churchill)
- 2025 ARCHIVED FORUM POSTS
- 322 ARCHIVED | Financial Edge® Tips and Tricks
- 164 ARCHIVED | Raiser's Edge® Blog
- 300 ARCHIVED | Raiser's Edge® Blog
- 441 ARCHIVED | Blackbaud Altru® Tips and Tricks
- 66 ARCHIVED | Blackbaud NetCommunity™ Blog
- 211 ARCHIVED | Blackbaud Target Analytics® Tips and Tricks
- 47 Blackbaud CRM Higher Ed Product Advisory Group (HE PAG)
- Luminate CRM DC Users Group
- 225 ARCHIVED | Blackbaud eTapestry® Tips and Tricks
- 1 Blackbaud eTapestry® Know How Blog
- 19 Blackbaud CRM Product Advisory Group (BBCRM PAG)
- 1 Blackbaud K-12 Education Solutions™ Blog
- 280 ARCHIVED | Mixed Community Announcements
- 3 ARCHIVED | Blackbaud Corporations™ & Blackbaud Foundations™ Hosting Status
- 1 npEngage
- 24 ARCHIVED | K-12 Announcements
- 15 ARCHIVED | FIMS Host*Net Hosting Status
- 23 ARCHIVED | Blackbaud Outcomes & Online Applications (IGAM) Hosting Status
- 22 ARCHIVED | Blackbaud DonorCentral Hosting Status
- 14 ARCHIVED | Blackbaud Grantmaking™ UK Hosting Status
- 117 ARCHIVED | Blackbaud CRM™ and Blackbaud Internet Solutions™ Announcements
- 50 Blackbaud NetCommunity™ Blog
- 169 ARCHIVED | Blackbaud Grantmaking™ Tips and Tricks
- Advocacy DC Users Group
- 718 Community News
- Blackbaud Altru® Hosting Status
- 104 ARCHIVED | Member Spotlight
- 145 ARCHIVED | Hosting Blog
- 149 JustGiving® from Blackbaud® Blog
- 97 ARCHIVED | bbcon® Blogs
- 19 ARCHIVED | Blackbaud Luminate CRM™ Announcements
- 161 Luminate Advocacy News
- 187 Organizational Best Practices Blog
- 67 everydayhero Blog
- 52 Blackbaud SKY® Reporting Announcements
- 17 ARCHIVED | Blackbaud SKY® Reporting for K-12 Announcements
- 3 Luminate Online Product Advisory Group (LO PAG)
- 81 ARCHIVED | JustGiving® from Blackbaud® Tips and Tricks
- 1 ARCHIVED | K-12 Conference Blog
- Blackbaud Church Management™ Announcements
- ARCHIVED | Blackbaud Award Management™ and Blackbaud Stewardship Management™ Announcements
- 1 Blackbaud Peer-to-Peer Fundraising™, Powered by JustGiving® Blogs
- 39 Tips, Tricks, and Timesavers!
- 56 Blackbaud Church Management™ Resources
- 154 Blackbaud Church Management™ Announcements
- 1 ARCHIVED | Blackbaud Church Management™ Tips and Tricks
- 11 ARCHIVED | Blackbaud Higher Education Solutions™ Announcements
- 7 ARCHIVED | Blackbaud Guided Fundraising™ Blog
- 2 Blackbaud Fundraiser Performance Management™ Blog
- 9 Foundations Events and Content
- 14 ARCHIVED | Blog Posts
- 2 ARCHIVED | Blackbaud FIMS™ Announcement and Tips
- 59 Blackbaud Partner Announcements
- 10 ARCHIVED | Blackbaud Impact Edge™ EAP Blogs
- 1 Community Help Blogs
- Diocesan Blackbaud Raiser’s Edge NXT® Users' Group
- Blackbaud Consultant’s Community
- Blackbaud Francophone Group
- 1 BLOG ARCHIVE CATEGORY
- Blackbaud Community™ Discussions
- 8.3K Blackbaud Luminate Online® & Blackbaud TeamRaiser® Discussions
- 5.7K Jobs Board