Unlimited Wordpress themes, plugins, graphics & courses! Unlimited asset downloads! From $16.50/m
Advertisement
  1. Web Design
  2. Form Design
Webdesign

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

by
Difficulty:BeginnerLength:LongLanguages:

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

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

A 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 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
Advertisement
Advertisement
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.