Tuesday, May 29, 2007

After doing great usage with CAPTCHA in my site (when adding comments - if you didn't try it I am inviting you to give it a try and add some comments after reading this post...), I decided to give some words about it...

Some definitions...
a CAPTCHA is a type of challenge-response test used in computing to determine whether the user is human, aka "Completely Automated Public Turing test to tell Computers and Humans Apart". A CAPTCHA involves one computer (a server) which asks a user to complete a test. While the computer is able to generate and grade the test, it is not able to solve the test on its own. Because computers are unable to solve the CAPTCHA, any user entering a correct solution is presumed to be human.

There are several approaches to this CAPTCHA mechanism, that comes to supply the same idea of effect (to differ a human user from a computer user of course), like:
- Carnegie Mellon's PIX CAPTCHA, which the user here sees few images and need to differ which one is exceptional.
- Oli Warner's KittenAuth, the user here needs to select all animals of specific speices in the proposed images.
- Microsoft's Asirra, quite similar to KittenAuth, but works under larger amount of images.

Some issues that are important in order of using CAPTCHA in your web site:

  • You must dock the CAPTCHA image/s in a non dominant place in your web site - think about it, the CAPTCHA mechanism is comes to help you to avoid bots, not to take a central place in your site.
  • The CAPTCHA image/s supposed to has as much as small weight (something like between 4 to 8 kb), the site should not be affected from the CAPTCHA image/s creation. I'd rather creating the CAPTCHA image/s using HttpHandler that display the image/s from an outside mechanism.
  • The area of the image/s should be appropriate to the site isuue. Images of cats should not be appropriate to a government site for example, therefore select the image/s properly.
  • Store the CAPTCHA in a safe place and name them in appropriate names in order to use it properly.

OK, what about some implementation? There are a lot of ways to implements this algorithm, which is not so complex. You can find a lot of written open source small application that implements this CAPTCHA mechanism.

In the web application that I am working on at work, we saves all distorted images in a DB (and its images' values of course) and grabs it randomally on each request of the specific page that holds the CAPTCHA. The distorted image is shown to the user and its value is stored in the page viewstate (which is also encripted of course).
After that user enters her input, that value is being validated against the distorted image's value and if it's correct, moves on...

Do you have more suggestions of CAPTCHA implemetations?

Posted by: Eran Nachum (c)
Post Date: 5/29/2007 8:14:09 AM (Jerusalem Standard Time, UTC+02:00)
Disclaimer | | Trackback   #
Related Posts:
Best practices for creating websites in IIS 6.0
Mono 2.0 is out!
Great 6 Websites to Get Free Ebooks
Runtime Error: Cannot Find X509Certificate in CurrentUserStore when User is Logged Off
Google Chart API - Another Great Thing from Google
Not Code Only - Some Music Suggestion

Tracked by:
"Listen To Music Online" (Listen To Music Online) [Trackback]
"Book Reviews Guide Online" (Book Reviews Guide Online) [Trackback]
http://witze-humor.de/templates/images/pages/templates/images/pages/03358445/nat... [Pingback]
http://ncdtnanotechportal.info/generator/pages/72221601/viagra-cialis-kamagra-ch... [Pingback]
http://split-dalmatia.com/split-dalmatia.com/images/pages/33988873/massage-parlo... [Pingback]
http://ipsilon.hr/ipsilon.hr/cms/4/lib/pages/25824053/viagra-safe-for-glaucoma.h... [Pingback]
http://ncdtnanotechportal.info/generator/pages/44390725/cialis-buy-online.html [Pingback]
http://lecouac.org/ecrire/lang/pages/10508910/viagra-pfitzer-alternatives.html [Pingback]
http://entartistes.ca/images/images/pages/13864630/fda-approved-womens-viagra.ht... [Pingback]
http://slaterjohn.com/downloads/2col/18126700/inexpensive-viagra.html [Pingback]
http://legambitdufou.org/Library/pages/09590878/use-viagra-for-muscle-building.h... [Pingback]
http://add2rss.com/img/design/pages/02846484/thick-nude-black-women.html [Pingback]
http://ziaeisoft.com/db/pages/89702300/cialis-viagra.html [Pingback]
http://entartistes.ca/images/images/pages/56759755/dallas-sting-91-girls.html [Pingback]
http://witze-humor.de/templates/images/pages/templates/images/pages/02520825/fir... [Pingback]
http://entartistes.ca/images/images/pages/24987687/medicine-sales-on-line-viagra... [Pingback]
http://realestate.hr/templates/css/pages/31047352/viagra-vega.html [Pingback]
http://ncdtnanotechportal.info/generator/pages/43534178/recherche-de-viagra.html [Pingback]
http://plantmol.com/pages/46412963/get-viagra-avoid-prescription.html [Pingback]
http://entartistes.ca/images/images/pages/43349278/scatickoke-ny.html [Pingback]
http://pddownloads.com/pages/99273746/viagra-cream-for-woman.html [Pingback]
http://coolioness.com/attachments/pages/attachments/pages/75205416/headache-pain... [Pingback]
http://hrvatska.biz/wp-includes/js/pages/37531767/viagra-levitra.html [Pingback]
http://slaterjohn.com/downloads/2col/53744671/healthexpress-co-uk-buy-acomplia-v... [Pingback]
http://pddownloads.com/pages/99273746/new-viagra.html [Pingback]
http://seo4u.at/images/pages/60282272/viagra-after-stroke.html [Pingback]
http://allfreefilms.com/wp-includes/js/48016403/free-sex-mpg-mvp.html [Pingback]
http://blog.netmedia.hr/wp-includes/js/pages/wp-includes/js/pages/98275784/chara... [Pingback]
http://ipsilon.hr/ipsilon.hr/cms/4/lib/pages/22937860/pictures-of-bird-tatoo-s.h... [Pingback]
http://promocija.com.hr/promocija.com.hr/includes/js/pages/58819393/nursery-rhym... [Pingback]
http://martinrozon.com/images/photos/pages/38317589/presctription-viagra.html [Pingback]
http://coolioness.com/attachments/pages/attachments/pages/75205416/cheapest-viag... [Pingback]
http://jivest2006.com/pages/59888246/viagra-compare-prices.html [Pingback]
http://add2rss.com/img/design/pages/66388408/free-hot-mom-pics.html [Pingback]
http://martinrozon.com/images/photos/pages/28629146/viagra-physicians-desk-refer... [Pingback]
http://blog.netmedia.hr/wp-includes/js/pages/wp-includes/js/pages/81123121/index... [Pingback]
http://plantmol.com/pages/33013774/cuckold-viagra-chastity.html [Pingback]
http://modena.intergate.ca/arezzojewelry/celexa.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/effexor/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/clomid/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/prozac.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/melatonin/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/ultram.html [Pingback]
http://modena.intergate.ca/arezzojewelry/clomid.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/cymbalta/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/viagra.html [Pingback]
http://modena.intergate.ca/arezzojewelry/paxil.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/celexa/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/claritin/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/lipitor.html [Pingback]
http://modena.intergate.ca/arezzojewelry/hoodia.html [Pingback]
http://modena.intergate.ca/arezzojewelry/synthroid.html [Pingback]
http://modena.intergate.ca/arezzojewelry/wellbutrin.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/nexium/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/viagra/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/prozac/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/paxil/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/lexapro/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/soma/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/tramadol/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/celebrex.html [Pingback]
http://modena.intergate.ca/arezzojewelry/prilosec.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/prilosec/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/nexium.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/ultram/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/claritin.html [Pingback]
http://modena.intergate.ca/arezzojewelry/cymbalta.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/cialis/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/lexapro.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/synthroid/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/rainbow-brite/index.html [Pingback]
http://blastpr.com/blog/wp-includes/js/pages/lipitor/index.html [Pingback]
http://modena.intergate.ca/arezzojewelry/soma.html [Pingback]
http://blastpr.com/wiki/js/pages/celexa/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/rainbow-brite/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/lexapro/index.html [Pingback]
http://blastpr.com/wiki/js/pages/zoloft/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/coumadin/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/lipitor/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/cymbalta/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/nexium/index.html [Pingback]
http://blastpr.com/wiki/js/pages/lexapro/index.html [Pingback]
http://blastpr.com/wiki/js/pages/viagra/index.html [Pingback]
http://blastpr.com/wiki/js/pages/ultram/index.html [Pingback]
http://blastpr.com/wiki/js/pages/celebrex/index.html [Pingback]
http://blastpr.com/wiki/js/pages/effexor/index.html [Pingback]
http://blastpr.com/wiki/js/pages/soma/index.html [Pingback]
http://blastpr.com/wiki/js/pages/prilosec/index.html [Pingback]
http://blastpr.com/wiki/js/pages/tramadol/index.html [Pingback]
http://blastpr.com/wiki/js/pages/melatonin/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/prozac/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/claritin/index.html [Pingback]
http://blastpr.com/wiki/js/pages/claritin/index.html [Pingback]
http://blastpr.com/wiki/js/pages/cialis/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/celebrex/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/cialis/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/clomid/index.html [Pingback]
http://blastpr.com/wiki/js/pages/nexium/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/prilosec/index.html [Pingback]
http://blastpr.com/wiki/js/pages/lipitor/index.html [Pingback]
http://morningside.edu/mics/_notes/pages/hoodia/index.html [Pingback]
http://blastpr.com/wiki/js/pages/rainbow-brite/index.html [Pingback]
http://blastpr.com/wiki/js/pages/coumadin/index.html [Pingback]
http://blastpr.com/wiki/js/pages/prozac/index.html [Pingback]
http://entartistes.ca/images/images/docs/65934120/index.html [Pingback]
http://martinrozon.com/images/photos/docs/54373182/index.html [Pingback]
http://pddownloads.com/docs/15972574/index.html [Pingback]
http://split-dalmatia.com/split-dalmatia.com/images/docs/84431573/index.html [Pingback]
http://promocija.com.hr/promocija.com.hr/includes/js/docs/37348396/index.html [Pingback]
http://pddownloads.com/docs/66275653/index.html [Pingback]
http://entartistes.ca/images/images/docs/81367526/index.html [Pingback]
http://legambitdufou.org/Library/docs/28049195/index.html [Pingback]
http://promocija.com.hr/promocija.com.hr/includes/js/docs/48335156/index.html [Pingback]
http://thejohnslater.com/pix/img/docs/86193101/index.html [Pingback]
http://jivest2006.com/docs/40579018/index.html [Pingback]
http://lecouac.org/ecrire/lang/docs/25282359/index.html [Pingback]
http://legambitdufou.org/Library/docs/38152786/index.html [Pingback]
http://slaterjohn.com/downloads/2col/66689432/index.html [Pingback]
http://plantmol.com/docs/80639343/index.html [Pingback]
http://hrvatska.biz/wp-includes/js/docs/80692203/index.html [Pingback]
http://lecouac.org/ecrire/lang/docs/20007231/index.html [Pingback]
http://islands-croatia.comislands-croatia.com/includes/js/docs/68291686/index.ht... [Pingback]
http://swellhead.netswellhead.net/docs/79619129/index.html [Pingback]
http://seo4u.at/images/docs/68897595/index.html [Pingback]
http://thebix.com/includes/compat/docs/29852280/index.html [Pingback]
http://realestate.hr/templates/css/docs/28593877/index.html [Pingback]
http://vladan.strigo.net/wp-includes/js/docs/25746442/index.html [Pingback]
http://ipsilon.hr/ipsilon.hr/cms/4/lib/docs/55227677/index.html [Pingback]
http://ipsilon.hr/ipsilon.hr/cms/4/lib/docs/24066563/index.html [Pingback]
http://islands-croatia.comislands-croatia.com/includes/js/docs/60974094/index.ht... [Pingback]
http://promocija.com.hr/promocija.com.hr/includes/js/docs/70471394/index.html [Pingback]
http://martinrozon.com/images/photos/docs/61904307/index.html [Pingback]
http://coolioness.com/attachments/docs/76375390/index.html [Pingback]
http://promocija.com.hr/promocija.com.hr/includes/js/docs/63224938/index.html [Pingback]
http://jivest2006.com/docs/76826750/index.html [Pingback]
http://promocija.com.hr/promocija.com.hr/includes/js/docs/36483653/index.html [Pingback]
http://swellhead.netswellhead.net/docs/42306518/index.html [Pingback]
http://legambitdufou.org/Library/docs/04618667/index.html [Pingback]
http://coolioness.com/attachments/docs/75395149/index.html [Pingback]
http://coolioness.com/attachments/docs/03698289/index.html [Pingback]
http://thebix.com/includes/compat/docs/10152421/index.html [Pingback]
http://swellhead.netswellhead.net/docs/05235252/index.html [Pingback]
http://islands-croatia.comislands-croatia.com/includes/js/docs/06712704/index.ht... [Pingback]
http://sevainc.com/bad_denise/img/9/prozac/ [Pingback]
http://sevainc.com/bad_denise/img/7/melatonin/ [Pingback]
http://sevainc.com/bad_denise/img/11/ultram/ [Pingback]
http://ina-tv.sk/img/viagra/ [Pingback]
http://inatelevizia.sk/ad/img/viagra/ [Pingback]
http://easycanada.info/js/pages/viagra/ [Pingback]
http://easytravelcanada.info/js/pages/2/celexa/ [Pingback]
http://sevainc.com/bad_denise/img/6/lipitor/ [Pingback]
http://sevainc.com/bad_denise/img/10/synthroid/ [Pingback]
http://sevainc.com/bad_denise/img/1/celebrex/ [Pingback]
http://jemnemelodierecords.sk/img/viagra/ [Pingback]
http://easytravelcanada.info/js/pages/4/coumadin/ [Pingback]
http://easymexico.info/images/img/viagra/ [Pingback]
http://sevainc.com/bad_denise/img/1/accutane/ [Pingback]
http://easytravelcanada.info/js/pages/11/ultram/ [Pingback]
http://easytravelcanada.info/js/pages/7/nexium/ [Pingback]
http://easytravelcanada.info/js/pages/6/lipitor/ [Pingback]
http://sevainc.com/bad_denise/img/4/cymbalta/ [Pingback]
http://easytravelcanada.info/js/pages/4/cymbalta/ [Pingback]
http://easytravelcanada.info/js/pages/9/rainbow-brite/ [Pingback]
http://sevainc.com/bad_denise/img/5/effexor/ [Pingback]
http://sevainc.com/bad_denise/img/2/cialis/ [Pingback]
http://sevainc.com/bad_denise/img/9/rainbow-brite/ [Pingback]
http://easytravelcanada.info/js/pages/12/viagra/ [Pingback]
http://easytravelcanada.info/js/pages/1/celebrex/ [Pingback]
http://easytravelcanada.info/js/pages/8/prilosec/ [Pingback]
http://easytravelcanada.info/js/pages/9/prozac/ [Pingback]
http://sevainc.com/bad_denise/img/10/soma/ [Pingback]
http://easymexico.info/images/img/cialis/ [Pingback]
http://abaffy.net/i/img/viagra/ [Pingback]
abaffy.org/la/img/viagra/ [Pingback]
http://abaffydesign.com/la/img/viagra/ [Pingback]
http://simpletravelcanada.info/js/pages/27277365/ [Pingback]
http://easytravelcanada.info/js/pages/12/wellbutrin/ [Pingback]
http://easytravelcanada.info/js/pages/5/hoodia/ [Pingback]
http://easytravelcanada.info/js/pages/10/soma/ [Pingback]
http://odin.net/images/pages/52807681/men-women-having-sex-together.html [Pingback]
http://odin.net/images/pages/52807681/female-piercing-pics.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/oral-sex-instruction-pictu... [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/college-girls-escorts.html [Pingback]
http://odin.net/images/pages/35694472/baby-bop-photos.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/adult-free-gay-porn.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/teen-gay-sex-totaly-free-s... [Pingback]
http://odin.net/images/pages/52807681/webcams-for-couples.html [Pingback]
http://odin.net/images/pages/35694472/anglina-jolie-nude.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/ametuer-zoo-girls.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/undergroung-teen.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/busty-ebony-retro-sylvia-m... [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/foot-fetish-video-s.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/jacqueline-teen-model-is-n... [Pingback]
http://odin.net/images/pages/52807681/hot-teens-pussy.html [Pingback]
http://odin.net/images/pages/52807681/charleston-swingers.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/image-uploading-adult.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/index.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/andy-kim-baby-i-love-you.h... [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/access-to-sex-web-sites.ht... [Pingback]
http://odin.net/images/pages/52807681/best-adult-chat-program.html [Pingback]
http://odin.net/images/pages/35694472/kate-winslet-nude-scenes-in-jude.html [Pingback]
http://odin.net/images/pages/52807681/chimpanzee-sex.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/oops-celeb.html [Pingback]
http://odin.net/images/pages/35694472/hottest-movie-sex-scenes.html [Pingback]
http://odin.net/images/pages/35694472/hot-mom-pics.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/32162341/free-sexualy-graphic-love-s... [Pingback]
http://odin.net/images/pages/52807681/life-teen-mass-balboa.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/sexual-protective-strategie... [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/porn-vagina-sex.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/porn-star-brooke-banner.ht... [Pingback]
http://cidesi.com/images/metro/metro2/pages/32162341/free-hardcore-heterosexual-... [Pingback]
http://odin.net/images/pages/35694472/baby-got-back-by-throwdown.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/53348735/barbue-girl.html [Pingback]
http://odin.net/images/pages/52807681/naruto-hentai.html [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/cute-hairstyle-for-young-g... [Pingback]
http://cidesi.com/images/metro/metro2/pages/32162341/free-sex-torrent.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/32162341/penis-too-small.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/32162341/indian-erotic-sex.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/32162341/sparkle-sweater-girls.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/32162341/a1-thumbnails-posts.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/32162341/asian-woman-for-anal-sex.ht... [Pingback]
http://gatewayplayhouse.com/photos/cai/pages/35807953/lindsay-lohan-nude-picture... [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/view-free-sex-scenes.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/baby-pool.html [Pingback]
http://cidesi.com/images/metro/metro2/pages/99493954/pussy-licking-techniques.ht... [Pingback]
http://cidesi.com/images/metro/metro2/pages/32162341/hot-russian-models-teen-age... [Pingback]
http://odin.net/images/pages/52807681/britney-no-panties-pics.html [Pingback]
http://www.signalprocessingsociety.org/community/forum/buy-valium-online.html [Pingback]
http://www.signalprocessingsociety.org/community/forum/buy-soma-online.html [Pingback]
http://www.signalprocessingsociety.org/community/forum/buy-viagra-online.html [Pingback]
http://www.signalprocessingsociety.org/community/forum/buy-hydrocodone-online.ht... [Pingback]
http://www.signalprocessingsociety.org/community/forum/buy-phentermine-online.ht... [Pingback]