Data AccessCore JavaApp FrameworksViewTestingBuildingDeploymentDev ToolsSecurityOpinions

Wednesday, November 30, 2011

Steps to a CAPTCHA Implementation using JAVA/JSP

CAPTCHA can quickly and easily protect your web application against brute force and bot attacks or abuse. There are just a few simple steps to a CAPTCHA implementation in Java/JSP. The solution is simple and the documentation is quite clear, so I only provide the steps and quick links to those resources.

Step 1: Signup for a CAPTCHA account and generate keys for your website domains.
Navigate to http://www.google.com/recaptcha and signup for an account. After obtaining a login, generate keys for your domain.

Step 2: Find the developers guide for CAPTCHA
Navigate to http://code.google.com/apis/recaptcha/intro.html. From here, you'll find all the information you need. Notice in the left hand menu, there's a Java/JSP Plugin link available. Click into that.

Step 3: Download the Java/JSP Plugin and Implement
Navigate to http://code.google.com/apis/recaptcha/docs/java.html where you will find a link to download the plugin, which is a set of Java classes. Extract the source files into your web applications java source tree. The directions on the page are extremely straight forward.

The form page looks like:
 
<%@ page import="net.tanesha.recaptcha.ReCaptcha" %>
<%@ page import="net.tanesha.recaptcha.ReCaptchaFactory" %>

<html>
<body>
<form action="" method="post">
   <%
      ReCaptcha c = ReCaptchaFactory.newReCaptcha("your_public_key", "your_private_key", false);
      out.print(c.createRecaptchaHtml(null, null));
   %>
   <input type="submit" value="submit" />
</form>
</body>
</html>
You also may be using reCaptcha over https. In that case, follow the instructions from this page: http://code.google.com/apis/recaptcha/docs/tips.html
<script type="text/javascript"
   src="https://www.google.com/recaptcha/api/challenge?k=your_public_key">
</script>

<noscript>
   <iframe src="https://www.google.com/recaptcha/api/noscript?k=your_public_key"
       height="300" width="500" frameborder="0"></iframe><br>
   <textarea name="recaptcha_challenge_field" rows="3" cols="40">
   </textarea>
   <input type="hidden" name="recaptcha_response_field"
       value="manual_challenge">
</noscript>
When the form is submitted, the reCaptcha entries can be verified easily.
<%@ page import="net.tanesha.recaptcha.ReCaptchaImpl" %>
<%@ page import="net.tanesha.recaptcha.ReCaptchaResponse" %>

    <html>
       <body>
       <%
        String remoteAddr = request.getRemoteAddr();
        ReCaptchaImpl reCaptcha = new ReCaptchaImpl();
        reCaptcha.setPrivateKey("your_private_key");

        String challenge = request.getParameter("recaptcha_challenge_field");
        String uresponse = request.getParameter("recaptcha_response_field");
        ReCaptchaResponse reCaptchaResponse = reCaptcha.checkAnswer(remoteAddr, challenge, uresponse);

        if (reCaptchaResponse.isValid()) {
          out.print("Answer was entered correctly!");
        } else {
          out.print("Answer is wrong");
        }
      %>
      </body>
    </html>
Step 4: Give the JVM a time interval to refresh its DNS cache
By default the Java Virtual Machine (JVM) caches all DNS lookups forever instead of using the time-to-live (TTL) value which is specified in the DNS record of each host. To fix this issue for good, you can pass -Dsun.net.inetaddr.ttl=30 to your app-server (this tells Java to only cache DNS for 30 seconds).

There is a great article on the JVM and DNS caching. A must read at http://www.sdn.sap.com/irj/scn/weblogs?blog=/pub/wlg/1887

The steps above are quick and easy to implement, post back and let me know if you have any issues with the implementation and I will try and assist.

65 comments:

  1. why my recaptcha gives Answer is Wrong whenever i put correct text into textfield of captcha??help me

    ReplyDelete
  2. Hey Itz Showing Null PointorException When i run this Application

    ReplyDelete
  3. Whay am I getting "org.apache.jasper.JasperException: Unable to compile class for JSP" error ?
    Please help....

    ReplyDelete
  4. This is jonesdruman This blog was simply great post byb you. I really appreciate your blog. Really awesome blog I would like to know more about this. Please give some ideas about your blog. Thanks…………………………………….
    T20 World Cup 2016 Tickets Available
    T20 World Cup 2016 Expected Players List

    ReplyDelete
  5. This was worth reading article, java is no doubt the most powerful programming languages yet more demanding as well. <
    Regards,
    PHP Training in Chennai|JAVA Course in Chennai|Best JAVA Training in Chennai|JAVA Training

    ReplyDelete
  6. Why I always get the error message never get into the valid condition ?

    ReplyDelete
  7. The strategy you have posted on this technology hepled me to get into the next level and had lot of informations in it.
    salesforce training in chennai | salesforce training institute in chennai

    ReplyDelete

  8. The strategy you have posted on this technology hepled me to get into the next level and had lot of informations in it. Python is one of the basic level programming and is very important one.
    Python Training in Chennai | Python Course in Chennai

    ReplyDelete
  9. Thanks for sharing such a useful post here.Really good to see this.I got more information about java.I will definitely follow your steps.Keep posting stuff like this.
    Java Training in chennai | Software Testing Training in chennai | Digital Marketing Training in Chennai

    ReplyDelete
  10. Thanks for sharing such a useful post here.Really good to see this.I got more information about java.I will definitely follow your steps.Keep posting stuff like this.
    العاب
    cooking games

    ReplyDelete
  11. As the demand of java programming application keeps on increasing, there is massive demand for java professionals in software development industries. Thus, taking training will assist students to be skilled java developers in leading MNCs.
    JAVA J2EE Training in Chennai | JAVA J2EE Training Institutes in Chennai

    ReplyDelete
  12. Have a look at Happy Veterans Day 2016 if you want to know about veterans day, which is one of the most important holidays in the U.S and why is it celebrated. Stay updated with all the latest information.

    ReplyDelete
  13. Thanks admin,I had spend more time with your website, because this is one of the best resources I have have found it.Your information is really useful to me.
    DOTNET Training in Chennai | DOTNET course in Chennai | DOTNET Training Institutes in Chennai

    ReplyDelete
  14. Very good business i liked my friend! Thank you for this beauty information.
    Best game car. لعبة سباق التيربو

    ReplyDelete
  15. Congratulations! this blog is very interesting and has information most important we invite you to visit our blog
    fireboy watergirl
    Geometry Dash online

    ReplyDelete

  16. هل بدأت تشعر بالملل من Clash of Clans، هل تشعر بأن مراحل اللعبة أصبحت مكررة ولا جديد فيها؟،
    هل تريد القيام بتحدٍ جديد؟، جهّز نفسك لأننا نريد أن نقدم لكم المنافس الجديد لها والتي ستتيح لك أنماط لعب أكثر وحرية أكثر!

    فجر الأسطورة هي لعبة إستراتيجية مجانية وبسيطة والتي تسمح لك ببناء مملكة خاصة بك وتدريب جيوش كبيرة تحت سيطرة الابطال.
    اللعبة تقدم أكثر من 150 بطل لتختار من بينهم، كل واحد منهم يستطيع أن يظهر لك قدرة خاصة.
    يمكن أيضا أن ترفع من مستواهم، بل ويمكنك أيضا دمجهم لتطويرهم، والذي يمكن أن يعطيك أبطال غير عاديين بقدرات غير مألوفة!
    الأبطال هم دائما قادة فريقك وجعلهم أقوى يساعدك في بناء فريق أقوى.

    تعطيك اللعبة مهام خاصة كل يوم، والتي تسمح لك بالحصول على سلع ومواد محدودة.
    الحصول على الموارد الأساسية مثل الذهب والفاكهة السحرية أمر سهل للغاية، يمكنك سرقتها من الممالك التي قمت بتدميرها في المعارك.
    اللعبة تقدم بعض الإضافات المدفوعة أيضا ولكنها إختيارية تماما. العملة المدفوعة - الشهب،
    تتيح للاعبين الحصول على أشياء رائعة مثل الدروع والتي تساعدهم في بناء بطل أكثر قوة!

    لعبة فجر الأسطورة تحاول ببساطة أن لا تكون مجرد نسخة من "Clash of Clans" فاللعبة تقدم لك حرية أكثر، خاصة من خلال توفير الأبطال.
    إختلاف اخر هو أن فجر الأسطورة تظهر لك المزيد من إمكانيات المعركة. يمكنك الإنضمام إلى الحلبة أو حرب التحالف.
    الحلبة بها معارك يومية قصيرة بينما التحالف فعالية اسبوعية أكبر.
    الأصعب لها جوائز أفضل. فجر الأسطورة متاحة بالفعل في متجر الاب للـiOS و Google Play للأندرويد. جربها الان!











    ReplyDelete


  17. منتديات أسامر
    اسلاميات,عامه,ادبيه,اسرة مجتمع,حياه,صوتيات,ديكور,ترفيهي,انمي,العاب,game,منتديات اسامر افضل منتدي عربي و فيه عدة اقسام و هي اتصلات وتقنيه
    منتدي أسامر

    ReplyDelete

  18. منتديات أسامر
    اسلاميات,عامه,ادبيه,اسرة مجتمع,حياه,صوتيات,ديكور,ترفيهي,انمي,العاب,game,اتصلات وتقنيه.
    منتدي أسامر

    ReplyDelete

  19. العاب فلاش
    العاب فلاش سيارات 2017

    العاب سباق سيارات 2017
    العاب سباق
    سباق سيارات
    موقعي
    موقعي الشخصي
    اضغط هنا

    ReplyDelete
  20. Your blog posts are more interesting and impressive. I think there are many people like and visit it regularly, including me.I actually appreciate your own position and I will be sure to come back here.
    temple run 2 l download temple run 2 l temple run 2 game l temple run 2 download l temple run 2 app

    ReplyDelete
  21. Thank you for this valuable information. We are the best erp software solutions in chennai. Contact us on info@bravetechnologies.in.
    erp in chennai

    ReplyDelete
  22. I really love reading and following your post as I find them extremely informative and interesting. This post is equally informative as well as interesting . Six Sigma Certification Training in Chennai | Linux Certification Training in Chennai | Microsoft Certification Training in Chennai

    ReplyDelete
  23. Interesting blog.. you have furnished the right information that will be useful to anyone at all time. Thanks for sharing your Ideas.Best Dot Net Training in Chennai | Best Java Training Institute in Chennai | Best Web Design Training in Chennai

    ReplyDelete
  24. When you take the service of us, you will feel that the Mumbai Escorts always become best companion of you. For other additional platform you can hire escorts such as dinner date, business party, bachelor party and many more.

    ReplyDelete
  25. The best thing is that your blog really informative thanks for your great information..Embedded Projects Center in Chennai | Embedded Projects Center in Velachery

    ReplyDelete
  26. Yes my friend I think it's a great story and it's really scary. Wow, I like it a lot.
    แทงบอล maxbet

    แทงบอล maxbet

    ทางเข้า maxbet

    ReplyDelete
  27. Great.. Tutorial is just awesome..It is really helpful for a newbie like me.. I am a regular follower of your blog. Kindly keep blogging.
    BE/B.Tech Project Center in Chennai | ME/M.Tech Project Center in Chennai | Final Year Project Center in Chennai

    ReplyDelete
  28. You guys are really doing great work. I am sure you're doing research to

    provide such kind of stuff to us. Feeling proud that people like you still

    exist in the world.
    ipl live score
    free ipl score
    ipl live stream
    ipl final 2018
    ipl live streaming
    ipl final score
    ipl live stream 2018
    ipl live score 2018
    ipl 2018 Schedule match
    watch ipl online live

    ReplyDelete
  29. Cricket could be a bat-and-ball game vie between 2 groups of 11 players every on a cricket field, at the centre of that could be a rectangular 22-yard-long (20 metres) pitch with a target at every finish referred to as the wicket (a set of 3 picket stumps upon that 2 bails sit).
    ipl live score
    free ipl score
    ipl final live streaming
    ipl final 2018
    ipl live streaming
    ipl final score
    ipl live stream 2018
    ipl live score 2018
    ipl Schedule 2018
    watch ipl online live

    ReplyDelete
  30. I was looking for some solution on google and then I cam across your website and got addicted. Such a nice way of website management, colours, way of writing and layout is attractive.
    IPL live score
    ipl final live streaming 2018
    ipl live score 2018
    ipl Schedule 2018
    watch ipl online live
    ipl live score
    free ipl score
    ipl live stream
    ipl final 2018
    IPL live streaming
    IPL opening ceremony

    ReplyDelete
  31. Cricket could be a bat-and-ball game vie between 2 groups of 11 players every on a cricket field, at the centre of that could be a rectangular 22-yard-long (20 metres) pitch with a target at every finish referred to as the wicket (a set of 3 picket stumps upon that 2 bails sit).
    ipl live score
    ipl score live
    free ipl score
    ipl final live streaming
    ipl final 2018
    ipl live streaming
    ipl final score
    ipl live stream 2018
    ipl live score 2018
    ipl Schedule 2018
    watch ipl online live
    ipl live score card
    ipl final
    ipl live stream
    live ipl score
    extra cover.net
    today ipl live score

    ReplyDelete
  32. . A vehicle title bank won't squander your chance; as long as you get all the capability data, once your auto is evaluated, you will know immediately regardless of whether your application has been affirmed.

    Check Cashing Corona
    Check Cashing Chula-vista
    Auto Title Loans Chicago

    ReplyDelete
  33. Your good knowledge and kindness in playing with all the pieces were very useful. I don’t know what I would have done if I had not encountered such a step like this.

    white label website builder

    mobile website builder

    ReplyDelete
  34. Looking forward to reading more. Opportunity for you to optimize your website on best price by us
    Mobile App Development Company NYC

    ReplyDelete
  35. Those guidelines additionally worked to become a good way to recognize that other people online have the identical fervor like mine to grasp great deal more around this condition.

    Best AWS training in bangalore

    ReplyDelete
  36. Your posts is really helpful for me.Thanks for your wonderful post..Java Summer Courses in Chennai | Summer Courses in Chennai

    ReplyDelete
  37. This comment has been removed by the author.

    ReplyDelete
  38. There are different components which influence the rates of iPhone application builder and they are cash contrasts between the nations which have a critical impact to bring down the rates further. convert website to app

    ReplyDelete
  39. The best thing is that your blog really informative thanks for your great information!
    VMware Exam Centers in Chennai | VMware Exam Centers in Velachery

    ReplyDelete
  40. Individual fund specialists have been worried about the measure of obligation ascending in homes for quite a long time. quick cash advance chula vista

    ReplyDelete
  41. Excellent article. Very interesting to read. I really love to read such a nice article. Thanks! keep rocking. Learn here

    ReplyDelete




  42. After this brings up its clients get entertained well with its premium services, theRussian Escorts in Gurgaonis liable to increase the level of fun by its quality services dissimilar to get anywhere. So, let us forget everything and take pleasure in what you wait for a long time. Check our other Services...
    Call Girls in Gurgaon
    Escorts in Gurgaon
    Escorts Service in Gurgaon
    Escorts Service in Gurgaon
    Female Escorts in Gurgaon

    ReplyDelete