7 days of unlimited WordPress themes, plugins & graphics - for free!* Unlimited asset downloads! Start 7-Day Free Trial
Advertisement
  1. Web Design
  2. Form Design

কীভাবে আপনার ওয়েবসাইটে “No CAPTCHA reCAPTCHA” ব্যবহার করবেন

Scroll to top
Read Time: 6 mins

Bengali (বাংলা) translation by Bint Salim (you can also view the original English article)

ক্যাপচা সমাধান করা সম্ভবত ওয়েবের মধ্যে সবচেয়ে বেশি বিরক্তিকর কাজ। এগুলো বেশীরভাগ ব্যবহারকারীর জন্য ঝামেলাপূর্ণ, বিশেষ করে যারা দৃষ্টিশক্তিহীন অথবা যারা প্রতিবন্ধী এবং ইন্টারনেট চালানোর জন্য বিভিন্ন সহায়ক টেকনোলজির উপর নির্ভরশীল, যেমন স্ক্রিন-রিডার। তবে, দুঃখের বিষয় হচ্ছে, স্প্যামের বিরুদ্ধে যুদ্ধ করতে ক্যাপচাগুলি একেবারে অপরিহার্য।

A necessary evil thanks spammersA necessary evil thanks spammersA necessary evil thanks spammers
ক্যাপচা হচ্ছে একটি প্রয়োজনীয় মন্দ বিষয় (এজন্য স্প্যামারদেরকে ধন্যবাদ)

মজার ব্যপার হচ্ছে, যদিও এই ট্রাডিশনাল "বিকৃত পাঠ্য" ক্যাপচাগুলি মানুষ ব্যবহারকারীদের পড়ার জন্য বিরক্তিকর, কিন্তু আধুনিক কৃত্রিম বুদ্ধিমত্তাসম্পন্ন প্রযুক্তি এগুলো সমাধান করতে ব্যর্থ হয়েছে। এমনকি গুগলও একই ধরনের টেকনোলোজি ব্যবহার করে গুগলের স্ট্রীট ভিউ লোকেশন যেমনঃ হাউজ নম্বর, রোড সাইন ইত্যাদি নিশ্চিত করে থাকে! 

গুগল রোবট সঠিকভাবে এইগুলো পড়তে পারে

এটা শুধুমাত্র সংখ্যানির্ভর, যার ফলে ২০১৪ সালের শেষের দিকে, গুগলের ডেভেলপাররা সবচেয়ে সেরা ক্যাপচা সমাধান নিয়ে এসেছে। নো-ক্যাপচা রি-ক্যাপচার জন্য কিছুই লাগে না শুধু একটু আঙ্গুলের স্পর্শ, একটি মাউস ক্লিক অথবা কী-বোর্ড দিয়ে ইনপুটের উপর ফোকাস করা এবং স্পেসবারে চাপ দেয়াই যথেষ্ট।

এটা খুবই সহজ, কিন্তু গুগলের রিস্ক এনালাইসিস যদি এখনো নিশ্চিত হতে না পারে যে আপনি মানুষ কিনা, তাহলে দ্বিতীয় প্রম্পট প্রদর্শিত হবে।

আপনি এটি ইতিমধ্যেই ওয়েব জুড়ে বিভিন্ন সাইটে দেখতে পাবেন, উদাহরণস্বরূপ submission page of @materialup এ যেমন দেখা যাচ্ছে।

নো-ক্যাপচা রিক্যাপচা কীভাবে পাবেন

চলুন তাহলে এবার ওয়েবসাইটের ঝুঁকি এড়াতে নিজের ওয়েবসাইটে একটি নো-ক্যাপচা সেটআপ করে নেই।

ধাপ ১

প্রথমত, আমাদের একটি API কী দরকার, সেজন্য নীচের ঠিকানায় যেতে হবে https://www.google.com/recaptcha/admin। এই পেইজে অ্যাক্সেস করতে আপনাকে একটি গুগল একাউণ্টে লগ-ইন করতে হবে। আপনাকে আপনার ওয়েবসাইট নিবন্ধন করতে বলা হবে, তাই একটি উপযুক্ত নাম দিন, তারপর নির্দিষ্ট ডোমেইন তালিকাভুক্ত করুন (উদাহরণস্বরূপ tutsplus.com) যেখানে এই নির্দিষ্ট রিক্যাপচাটি ব্যবহার করা হবে। সাবডোমেইনসমূহ (যেমন webdesign.tutsplus.com এবং code.tutsplus.com) স্বয়ংক্রিয়ভাবে এই একাউণ্টে যুক্ত হয়ে যাবে।

ধাপ ২

এগুলো সম্পন্ন করলে আপনাকে একটি সাইট কী এবং তার অংশিদারীত্বের গোপন কী দেয়া হবে:

ধাপ ৩

এই কী গুলোর নীচে আপনি বেশ কিছু কোড স্নিপেট দেখতে পাবেন যা দিয়ে আপনার ওয়েবসাইটে রি-ক্যাপচা অন্তর্ভুক্ত করতে পারবেন। প্রথমে আছে জাভাস্ক্রিপ্ট:

কোড স্ট্রিং-এ একটি প্যারামিটার যোগ করে আপনি ৪০ টি সমর্থিত ভাষার কোনটি ব্যবহার করছেন তা নির্ধারণ করতে পারেন। আমরা এখানে es যোগ করছি যেটা আমাদের স্প্যানিশ ভাষার রি-ক্যাপচা ব্যবহারের সু্যোগ দিবে:

এই স্ক্রিপ্ট ট্যাগটি আপনার পেইজের ফুটারে যুক্ত করুন (অথবা যেই ফরমে আপনার রি-ক্যাপচাটি দেখাবে, তার ঠিক নীচে যুক্ত করুন, এটা নির্ভর করে আপনি কীভাবে আপনার পেইজটি লোড করতে চাচ্ছেন তার উপর)।

ধাপ ৪

তারপর আছে স্থানধারক বা প্লেসহোল্ডার যেটা আপনি আপনার ফরম মার্কআপ বা কোডে যুক্ত করবেন, ঠিক যেখানে আপনি রিক্যাপচাটি দেখাতে চান।

দ্রষ্টব্য: data-sitekey অ্যাট্রিবিউট আপনার কী-এর প্রকৃত মান ধারণ করবে, উদাহরণস্বরূপ দেয়া  নকল মানটি নয়। 

এই পর্যন্ত এসে আরও বেশ কিছু অ্যাট্রিবিউট আছে যা আপনি আপনার রি-ক্যাপচাটির গঠন ও কার্যকারিতা পরিবর্তন করতে ব্যবহার করতে পারেন। উদাহরন স্বরূপ, এই div এ data-theme="dark" যুক্ত করলে আপনি একটি গাড় রঙের সংস্করণ পাবেন, যেটা হয়তোবা আপনার ইউজার ইণ্টারফেসের সাথে আরও ভালোভাবে মানিয়ে যাবে:

আপনার রি-ক্যাপচা কনফিগার করার আরো বিশদ বিবরণের জন্য developers.google.com দেখুন।

সব একত্র করুন।

এখন আমরা আমাদের প্রাথমিক উপাদানগুলো পেয়েছি। এবার এগুলোকে কর্মক্ষেত্রে প্রয়োগ করার পালা।

ধাপ ১

চলুন আমরা আমাদের স্ক্রিপ্ট ট্যাগ এবং প্লেসহোল্ডারকে একটি সহজ ফর্মের মধ্যে রাখি:

এখানে আমরা একটি খালি পেইজ কাঠামো ব্যবহার করেছি যাতে শুধুমাত্র একটি  ফরমে একটি name ইনপুট, একটি email ইনপুট এবং একটি সাবমিট বাটন থাকবে। এখানে কোন স্টাইল করা হয় নি কারণ এটা এই টিউটোরিয়ালের জন্য দরকার নেই।

our captcha formour captcha formour captcha form
আপনার ফলাফলটি এটার মত দেখাবে

রি-ক্যাপচা পরীক্ষায় পাস করা হয়েছে তা দেখানোর জন্য আমাদের কিছু সার্ভার-সাইড পরীক্ষা চালানোর প্রয়োজন হবে। এক্ষেত্রে, আমরা এই কাজটি PHP দিয়েও করতে পারি, এজন্য এই ফাইলটি একটি নতুন প্রজেক্টে index.php হিসেবে সংরক্ষণ করুন।

ধাপ ২

আপনি হয়তো খেয়াল করেছেন ফরমের পদ্ধতিটি হচ্ছে post, তাই যখন আমরা ফরম ডাটা সাবমিট করবো, তখন এটা এই পেইজে ভেরিয়েবলসমূহের একটি অ্যারে হিসেবে ফেরত আসবে।  আমরা এই ভেরিয়েবলের মানগুলো লুপের মাধ্যমে আউটপুট হিসেবে পেতে পারি, তাই আপনার পেইজের কোন এক জায়গায় নিন্মোক্ত কোডসমূহ যুক্ত করুন:

এটা আমাদের $_POST অ্যারেতে থাকা যেকোনো কী/মান গ্রহণ করে এবং কিছুটা ফরম্যাট করার পর তাঁর আউটপুট প্রদান করে।  এবার আপনি যখন ফরমটি সাবমিট করবেন তখন নীচের মত কিছু একটা দেখতে পাবেন:

আপনি দেখতে পাবেন name এবং email জন্য মানটি ফিরে এসেছে, কিন্তু একইসাথে g-recaptcha-response জন্যও একটি মান ফিরে এসেছে। আপনি যদি ক্যাপচা টেস্ট পূর্ণ করতে ব্যর্থ হোন, তাহলে এই মানটি খালি থাকবে, কিন্তু আপনি যদি “I’m not a robot” এই বক্সটি চেক করেন তাহলে অক্ষরের একটি বিশাল স্ট্রিং দেখতে পাবেন।

এটা হচ্ছে সেই মান যা আমরা গুগলে পাঠাবো যাতে এটি ভেরিফাই হতে পারে, তাই চলুন এবার এটা করি।

ধাপ ৩

ভাগ্যিস, গুগল ডেভেলপার টিম এই কঠিন কাজটি আমাদের জন্য এখানে সম্পন্ন করে দিয়েছে, তাই গিটহাবের রি-ক্যাপচা প্রজেক্টে যান এবং recaptchalib.php লাইব্রেরী থেকে একটি কপি নিয়ে নিন। এটা আপনার প্রজেক্ট রুটে রাখুন এবং তারপর আপনার index.php ফাইলে এর রেফারেন্স দিন:

ধাপ ৪

এই লাইব্রেরীতে ফাংশনের একটি সংগ্রহ আছে যেটা g-recaptcha-response কে (গোপন কীসহ) HTTP রিকুয়েস্টের মাধ্যমে গুগলে পাঠায়। তারপর কি প্রতিক্রিয়া আসে তা সংগ্রহ করে, এবং চেক করে দেখে যে ক্যাপচাটি সফল হলো কি হলো না। এটা ব্যবহার করতে আমাদের প্রথমে বেশ কিছু ভেরিয়েবল সেটআপ করতে হবে, PHP এর শেষের ট্যাগের আগে:

ReCaptcha() আমাদের গোপন কী উপস্থিত আছে কিনা তা চেক করে দেখবে। যদি না থাকে তবে এই প্রক্রিয়াটি বন্ধ করে দিবে এবং আমাদেরকে চলে যেতে বলবে এবং নতুন কী নিয়ে আসতে বলবে। এবার আমরা আমাদের বিবরণ নীচের কোডের মাধ্যমে চালু করবো:

ধাপ ৫

ফরমে সাবমিট করা সব কিছু যদি ভালো থাকে, তাহলে $response ভেরিয়েবলটি "সফল" হয়েছে বলে রিপোর্ট প্রদান করে এবং আমরা ফরম ডাটা প্রক্রিয়াকরণ অব্যাহত রাখতে পারি। এটা সম্ভবত নীচের মত দেখতে হবে: যেখানে আমরা ফরম ডাটার জন্য লুপ তৈরি করেছি সে অংশটি মুছে ফেলুন, তারপর নীচের অংশটি ফরমের উপরের অংশে যুক্ত করুন:

সবশেষে, ফরমের পরে একটি ক্লোজিং PHP ট্যাগ যুক্ত করুন:

এটি একটি ফরম প্রদর্শন করবে, যতক্ষন না এটাকে সফলভাবে জমাদান করা না হয়। যখন জমা দেয়া হবে, তখন ছোট একটি ধন্যবাদ বিজ্ঞপ্তি দেয়া হবে। এখানে চূড়ান্ত ডেমোটি দেয়া হলো

পরিশিষ্ট

এটা নো-ক্যাপচা, রিক্যাপচার একটি মোটামুটিভাবে প্রস্তুত PHP ইমপ্লিমেণ্টেশন ছিলো। এই প্রক্রিয়াটিকে আরও অনেক বেশী উন্নত করা সম্ভব, কিন্তু আশা করি আপনি এটার মূল বিষয়টি উপলব্ধি করতে পেরেছেন। লাইব্রেরীর জন্য মূল ক্রেডিট হচ্ছে গুগল ডেভেলপার টিমের এবং আমাকে এই বিষয়ে জানানোর জন্য Matt Aussaguel কেও ধন্যবাদ।

উপকারী রিসোর্সসমূহ

Advertisement
Did you find this post useful?
Want a weekly email summary?
Subscribe below and we’ll send you a weekly email summary of all new Web Design tutorials. Never miss out on learning about the next big thing.
Advertisement
Looking for something to help kick start your next project?
Envato Market has a range of items for sale to help get you started.