Client-side validation এবং Server-side validation দুটি ভিন্ন ধরনের ডেটা যাচাইকরণ প্রক্রিয়া, যেগুলি web অ্যাপ্লিকেশনগুলিতে ডেটার সঠিকতা নিশ্চিত করতে ব্যবহৃত হয়। এই দুটি যাচাইকরণ প্রক্রিয়া একে অপরকে পরিপূরক হিসেবে কাজ করে, যেখানে client-side validation ব্যবহারকারীর অভিজ্ঞতা উন্নত করে এবং server-side validation সিকিউরিটি এবং ডেটা ইন্টেগ্রিটি নিশ্চিত করে।
Entity Framework (EF) এবং ASP.NET Core সহ অন্যান্য টেকনোলজির সাথে Client-side এবং Server-side validation একত্রে ব্যবহার করলে একটি শক্তিশালী এবং নিরাপদ validation সিস্টেম তৈরি করা সম্ভব।
Client-side validation সাধারণত JavaScript বা jQuery ব্যবহার করে করা হয়, যা ব্যবহারকারীর ব্রাউজারে ফর্ম ডেটা যাচাই করে। এটি ফর্ম সাবমিট হওয়ার আগে ব্যবহারকারীকে ত্রুটি বা ভুল তথ্য জানানোর জন্য কার্যকর। এর প্রধান সুবিধা হল তা সরাসরি ব্যবহারকারীর ডিভাইসে ঘটে, ফলে সিস্টেমের সার্ভার লোড কমে এবং ইউজার ইন্টারঅ্যাকশন দ্রুত হয়।
ASP.NET Core তে jQuery Validation প্লাগিন সাধারণত ব্যবহার করা হয়, যা ক্লায়েন্ট সাইডে ডেটা ভ্যালিডেশন বাস্তবায়ন করে।
<form id="myForm">
<label for="email">Email:</label>
<input type="email" id="email" name="email" required />
<label for="password">Password:</label>
<input type="password" id="password" name="password" required minlength="6" />
<button type="submit">Submit</button>
</form>
<script>
$(document).ready(function() {
$("#myForm").validate({
rules: {
email: {
required: true,
email: true
},
password: {
required: true,
minlength: 6
}
},
messages: {
email: {
required: "Please enter an email address",
email: "Please enter a valid email"
},
password: {
required: "Please enter a password",
minlength: "Password must be at least 6 characters"
}
}
});
});
</script>
এখানে, jQuery Validation প্লাগিন ব্যবহার করে আমরা ফর্মের ইনপুট ভ্যালিডেশন করেছি। যখন ব্যবহারকারী ফর্মটি সাবমিট করার চেষ্টা করবে, তখন email এবং password এর জন্য ত্রুটি বার্তা দেখানো হবে যদি তা সঠিক না হয়।
Server-side validation হল যখন ফর্মের ডেটা সার্ভারে পাঠানো হয় এবং সার্ভার সাইডে তা যাচাই করা হয়। এটি ব্যবহারকারীর ইনপুটের উপর প্রোগ্রাম্যাটিক যাচাইকরণ করে এবং ত্রুটির ক্ষেত্রে সংশোধন প্রক্রিয়া চালায়। Server-side validation এর মূল সুবিধা হল এটি নিরাপত্তা নিশ্চিত করে, কারণ ক্লায়েন্ট সাইডের ভ্যালিডেশন সহজে বাইপাস করা যেতে পারে, কিন্তু সার্ভার সাইড যাচাইকরণ বাইপাস করা সম্ভব নয়।
ASP.NET Core তে Data Annotations ব্যবহার করে server-side validation করা যেতে পারে। Model এর উপরে Data Annotations যোগ করা হয়, যা কনফিগারেশন এবং সঠিকতা নিশ্চিত করে।
public class UserModel
{
[Required(ErrorMessage = "Email is required.")]
[EmailAddress(ErrorMessage = "Invalid email format.")]
public string Email { get; set; }
[Required(ErrorMessage = "Password is required.")]
[MinLength(6, ErrorMessage = "Password must be at least 6 characters long.")]
public string Password { get; set; }
}
public class UserController : Controller
{
[HttpPost]
public IActionResult Register(UserModel model)
{
if (ModelState.IsValid)
{
// Process registration
return RedirectToAction("Success");
}
// Return to the same view with validation errors
return View(model);
}
}
এখানে, UserModel ক্লাসে Data Annotations ব্যবহার করা হয়েছে। ফর্ম সাবমিট হওয়ার পর ModelState.IsValid চেক করে, যদি মডেল বৈধ না হয়, তাহলে ত্রুটি বার্তাগুলি View তে প্রদর্শিত হবে।
যখন আমরা client-side এবং server-side validation একত্রে ব্যবহার করি, তখন একটি দুই স্তরের যাচাইকরণ প্রক্রিয়া তৈরি হয়। এখানে, client-side validation ব্যবহারকারীর কাছে দ্রুত ত্রুটি বার্তা পাঠিয়ে তাদের টাইম সেভ করতে সাহায্য করে, এবং server-side validation নিশ্চিত করে যে, সব ইনপুট ডেটা সঠিক এবং নিরাপদ। এটি একে অপরকে পরিপূরক হিসেবে কাজ করে।
<form id="registrationForm" method="post" asp-action="Register">
<label for="email">Email:</label>
<input type="email" id="email" name="Email" required />
<label for="password">Password:</label>
<input type="password" id="password" name="Password" required minlength="6" />
<button type="submit">Submit</button>
</form>
<script>
$(document).ready(function () {
$("#registrationForm").validate({
rules: {
email: {
required: true,
email: true
},
password: {
required: true,
minlength: 6
}
},
messages: {
email: {
required: "Please enter an email address",
email: "Please enter a valid email address"
},
password: {
required: "Please enter a password",
minlength: "Password must be at least 6 characters"
}
}
});
});
</script>
ASP.NET Core Controller (Server-side Validation)
public class UserModel
{
[Required(ErrorMessage = "Email is required.")]
[EmailAddress(ErrorMessage = "Invalid email format.")]
public string Email { get; set; }
[Required(ErrorMessage = "Password is required.")]
[MinLength(6, ErrorMessage = "Password must be at least 6 characters long.")]
public string Password { get; set; }
}
public class UserController : Controller
{
[HttpPost]
public IActionResult Register(UserModel model)
{
if (ModelState.IsValid)
{
// Process registration
return RedirectToAction("Success");
}
// Return to the same view with validation errors
return View(model);
}
}
এখানে, client-side validation ব্যবহারকারীর ইনপুট ত্রুটির জন্য তৎক্ষণাৎ প্রতিক্রিয়া দেখায় এবং server-side validation নিশ্চিত করে যে, ডেটাবেসে নিরাপদ এবং সঠিক ডেটা সংরক্ষিত হচ্ছে। ফলে, আপনার অ্যাপ্লিকেশন শক্তিশালী এবং সুরক্ষিত হয়।
Client-side validation ব্যবহারকারীর অভিজ্ঞতা উন্নত করে এবং দ্রুত ত্রুটি বার্তা প্রদান করে, যেখানে server-side validation ডেটার সঠিকতা এবং নিরাপত্তা নিশ্চিত করে। এই দুটি একত্রে ব্যবহার করার ফলে আপনার অ্যাপ্লিকেশন দ্রুত, নিরাপদ এবং ব্যবহারকারী-বান্ধব হয়।
common.read_more