CodeGym /Java Blog /এলোমেলো /নিরাপত্তাই প্রথম. জাভা কি একটি ভাল কারণে একটি নিরাপদ ভাষা...
John Squirrels
লেভেল 41
San Francisco

নিরাপত্তাই প্রথম. জাভা কি একটি ভাল কারণে একটি নিরাপদ ভাষা বলা হয়?

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

কি জাভা একটি নিরাপদ ভাষা করে তোলে?

জাভা নিরাপদ? জাভাকে একটি সুরক্ষিত প্রোগ্রামিং ভাষা বলার অনেক কারণ রয়েছে, যদিও জাভাকে অন্যান্য ভাষার তুলনায় অনেক বেশি সুরক্ষিত বলাটাই সঠিক উপায় হবে কারণ এই বৈশিষ্ট্যগুলি আসলে জাভাকে একেবারে সুরক্ষিত করে না, তারা মূলত জাভা কোড নির্বাহের নিরাপত্তা উন্নত করুন।
  • বাইটকোড যাচাইকরণ।
বাইটকোড যাচাইকরণ হল জাভা কোডের নিরাপত্তা নিশ্চিত করার মূল বৈশিষ্ট্যগুলির মধ্যে একটি। একটি বাইটকোড যাচাইকরণের অর্থ হল জাভা একটি কম্পাইলার ব্যবহার করে, যা জাভা কোড পড়ে এবং এটিকে একটি মেশিন-স্বাধীন বাইটকোড উপস্থাপনায় অনুবাদ করে। এটি নিশ্চিত করতে দেয় যে কেবলমাত্র বৈধ বাইটকোডগুলি কার্যকর করা হয়েছে এবং কোনও দূষিত কোড সিস্টেমে প্রবেশ করতে পারে না। কম্পাইলার চেক করে যে বাইটকোডগুলি জাভা ল্যাঙ্গুয়েজ স্পেসিফিকেশনের সাথে সঙ্গতিপূর্ণ এবং জাভা ভাষার নিয়ম বা নেমস্পেস সীমাবদ্ধতা লঙ্ঘন করে না। কোডটি আরও অনেকগুলি 'লাল পতাকা'র জন্যও পরীক্ষা করা হয়, যেমন অবৈধ ডেটা টাইপকাস্ট, স্ট্যাক আন্ডারফ্লো এবং ওভারফ্লো, বা মেমরি ব্যবস্থাপনা লঙ্ঘন। এটিকে আরও সহজ উপায়ে ব্যাখ্যা করার জন্য, জাভা প্রোগ্রামগুলি কামড় কোড হিসাবে সংকলিত হয়, যা পরে একটি ভার্চুয়াল মেশিনের ভিতরে চলে এবং এটি যে কম্পিউটারে চলে তা অ্যাক্সেস করতে পারে না। এটি এই কোডটি ব্যবহার করা আরও নিরাপদ করে তোলে,
  • স্বয়ংক্রিয় মেমরি ব্যবস্থাপনা।
একটি নিরাপদ ভাষা হিসাবে জাভার আরেকটি গুরুত্বপূর্ণ বৈশিষ্ট্য হল স্বয়ংক্রিয় মেমরি ম্যানেজমেন্ট এবং আবর্জনা সংগ্রহ, যা জাভাকে কোডারের জন্য অনেক সহজ ভাষা করে তোলে কারণ জাভা স্বয়ংক্রিয়ভাবে সমস্ত অভ্যন্তরীণ মেমরি সমস্যা এবং ডেটা ম্যানেজমেন্ট সিস্টেমের যত্ন নেয়। এটি প্রোগ্রামারকে একটি প্রোগ্রাম তৈরি করার সময় মেমরির সমস্যাগুলি নিয়ে উদ্বিগ্ন হতে দেয় না, পরিবর্তে অন্যান্য গুরুত্বপূর্ণ বিষয়গুলিতে ফোকাস করে। আবর্জনা সংগ্রহ, উদাহরণস্বরূপ, যখন এটি প্রয়োজন হয় তখন স্বয়ংক্রিয়ভাবে মেমরি মুক্ত করে। যাইহোক, জাভাতে এই সমস্ত ম্যানেজমেন্ট অটোমেশনের আরেকটি প্রধান সুবিধা হল যে এটি সামগ্রিক উন্নয়ন খরচ কমিয়ে দেয় (যেহেতু বেশ কয়েকটি গুরুত্বপূর্ণ ফাংশন এবং প্রক্রিয়াগুলি স্বয়ংক্রিয়)।
  • কোন পয়েন্টার নেই।
অন্যান্য অনেক প্রোগ্রামিং ভাষার বিপরীতে, C এবং C+ উদাহরণস্বরূপ, যেগুলি অ্যাপ্লিকেশন মেমরি পরিচালনা করতে পয়েন্টার মান ব্যবহার করে, জাভাতে পয়েন্টারগুলির কোনও ধারণা নেই। যদিও মূলত একটি নিরাপত্তা ব্যবস্থা হিসাবে ডিজাইন করা হয়েছে (চোরদের থেকে ব্যক্তিগত ডেটা রক্ষা করার জন্য), পয়েন্টারগুলিও সেই ক্ষেত্রে একটি বড় দুর্বলতা হতে পারে যখন কিছু ধরণের ম্যালফ্যাক্টর তাদের অ্যাক্সেস পেতে পরিচালনা করে কারণ পয়েন্টারগুলির কাছে অনুমোদন যাচাই করার কোনও উপায় নেই। , মূলত যে কাউকে অ্যাপ্লিকেশনের মেমরি অ্যাক্সেস করার অনুমতি দেয়। জাভা, যেমন আমরা বলেছি, কোনও অননুমোদিত অ্যাক্সেস থেকে ডেটা রক্ষা করার উপায় হিসাবে তার ডেটা ম্যানেজমেন্ট সিস্টেম এবং অভ্যন্তরীণ মেমরির উপর নির্ভর করে, পয়েন্টার ব্যবহার করে না। এটি হ্যাকারদের পক্ষে জাভা অ্যাপ্লিকেশনের মেমরিতে অনুপ্রবেশ করা প্রায় অসম্ভব করে তোলে। বোধগম্যভাবে, জাভা এন্টারপ্রাইজ ডেভেলপমেন্টে জনপ্রিয় হওয়ার আরেকটি কারণ,
  • জাভা কম্পাইলার স্বয়ংক্রিয়ভাবে কোডে ত্রুটিগুলি পরীক্ষা করে, সনাক্ত করে এবং সংশোধন করে।
ত্রুটির জন্য কোডের স্বয়ংক্রিয় চেকিং জাভার আরেকটি গুরুত্বপূর্ণ বৈশিষ্ট্য যা এটিকে আরও সুরক্ষিত করে তোলে। কম্পাইলার কোড পরীক্ষা করে, ত্রুটি সনাক্ত করে, প্রোগ্রামারকে এই তীরগুলি সম্পর্কে সতর্ক করে এবং সেগুলি ঠিক করার উপায়গুলি প্রস্তাব করে। এটি আবার, প্রোগ্রামারের কাজকে সহজ করে, জাভা অ্যাপ্লিকেশনগুলিকে অনেক বেশি স্থিতিশীল করে তোলে এবং শেষ পর্যন্ত, বিকাশের খরচ কমিয়ে দেয় (যেকোনো কোম্পানির জন্য কারণ নম্বর 1)। এটির সুরক্ষা অংশ হিসাবে, এটি আপনার প্রোগ্রামে অননুমোদিত পরিবর্তন করে বহিরাগত ক্ষতিকারক কোড প্রবেশের সম্ভাবনাকেও কমিয়ে দেয়।
  • জাভা স্বয়ংক্রিয় ডেটা টাইপ চেকিং করে।
ত্রুটির জন্য কোড চেক করার পাশাপাশি, জাভা কম্পাইলার স্বয়ংক্রিয়ভাবে কোডের ভেরিয়েবলগুলি পরীক্ষা করে, যাতে ভেরিয়েবলে ডেটা এন্ট্রির ভুল থেকে উদ্ভূত কোনো নিরাপত্তা উদ্বেগ নেই। এটি সিস্টেমকে অনুপ্রবেশ এবং ডেটা চুরি হওয়া থেকে রক্ষা করার আরেকটি উপায়।

কোন জাভা উপাদানগুলি আসলে এটিকে সুরক্ষিত করে তোলে?

নির্দিষ্ট জাভা উপাদানগুলির জন্য যা এটির নিরাপত্তায় সবচেয়ে গুরুত্বপূর্ণ ভূমিকা পালন করে, এখানে একটি দ্রুত তালিকা দেওয়া হল আপনাকে একটি পরিষ্কার বোঝার জন্য, একটি প্রাথমিক স্তরে, এটি কীভাবে কাজ করে এবং ঠিক কী জাভাকে নিরাপদ করে।
  • জাভা ভার্চুয়াল মেশিন (JVM)।
JVM, একটি ভার্চুয়াল মেশিন যা একটি জাভা প্রোগ্রামের বাইটকোড উপস্থাপনা চালায়, স্পষ্টতই জাভার সামগ্রিক নিরাপত্তায় একটি অত্যন্ত গুরুত্বপূর্ণ ভূমিকা পালন করে। JVM ব্যবহার করে আপনি একটি প্রোগ্রামের যেকোনো সম্ভাব্য অনিরাপদ অপারেশন ব্লক করতে পারবেন।
  • জাভা ক্রিপ্টোগ্রাফি আর্কিটেকচার (JCA)।
জাভা ক্রিপ্টোগ্রাফি আর্কিটেকচার হল একটি ফ্রেমওয়ার্ক যা আপনাকে জাভা প্ল্যাটফর্মের জন্য ক্রিপ্টোগ্রাফিক কার্যকারিতা যোগ করতে দেয়। জাভা ক্রিপ্টোগ্রাফি আর্কিটেকচার ব্যবহার করা গ্যারান্টি দেয় যে আপনার ডেটা এনক্রিপ্ট করা হবে এবং সুরক্ষিত থাকবে।
  • পাবলিক কী অবকাঠামো (PKI)।
পাবলিক কী ইনফ্রাস্ট্রাকচার হল আরেকটি ফ্রেমওয়ার্ক, যা আপনাকে পাবলিক-কি ক্রিপ্টোগ্রাফি প্রয়োগ করতে দেয়। ডেটার একটি নিরাপদ বিনিময় অর্জন করতে। PKI ব্যবহার করে, আপনি ডিজিটাল শংসাপত্রের সাথে পরিচয় সংযুক্ত করতে পারেন এবং প্রয়োজনে শংসাপত্রের সত্যতা যাচাই করতে পারেন।
  • নিরাপত্তা ব্যবস্থাপক.
জাভাতে নিরাপত্তা ব্যবস্থাপক মূলত একটি শ্রেণী, যা অ্যাপ্লিকেশনগুলিকে একটি নিরাপত্তা নীতি বাস্তবায়ন করতে দেয়, তাদের জন্য নিরাপত্তা নীতি নির্ধারণ করে এবং একজন প্রোগ্রামারকে একটি অ্যাপের জন্য একটি নিরাপত্তা স্তর সেট করার অনুমতি দেয়।
  • জাভা স্যান্ডবক্স।
জাভা স্যান্ডবক্স হল জাভা অ্যাপলেট চালানোর জন্য একটি প্রোগ্রাম এলাকা, যা নিরাপত্তার সাথে আপস করবে না এবং নিরাপত্তা পরীক্ষা ছাড়া সিস্টেম রিসোর্সে যেতে পারবে না তা নিশ্চিত করতে অ্যাপলেট কী করতে পারে তা সীমাবদ্ধ করে।

মতামত

বছরের অভিজ্ঞতার সাথে পেশাদার জাভা বিকাশকারীরা কি বিশ্বাস করেন যে এই ভাষা নিরাপদ? এখানে উদ্ধৃতি একটি দম্পতি আছে. “আমি বলব জাভা তেমন সুরক্ষিত নয় (কোন প্রোগ্রামিং ভাষা নয়), তবে JVM এমন বৈশিষ্ট্যগুলি অফার করে যা সুরক্ষা প্রদান করে। সুতরাং জাভা আপনাকে সবকিছু থেকে রক্ষা করবে না, এটি আপনাকে সম্পূর্ণ শ্রেণির সমস্যা থেকে রক্ষা করবে যা বাফার ওভাররানের কারণে হয়,” বলেনগ্যারি টেলর, একজন অভিজ্ঞ প্রোগ্রামার এবং ব্ল্যাক স্পার্ক মিডিয়া কোম্পানির সিটিও। "জাভা একটি অ্যাপলেটকে জাভা এক্সিকিউশন এনভায়রনমেন্টে সীমাবদ্ধ করে এবং এটিকে কম্পিউটারের অন্যান্য অংশ অ্যাক্সেস করার অনুমতি না দিয়ে নিরাপত্তা উন্নত করে। কোনো ক্ষতি হবে না এবং কোনো নিরাপত্তা লঙ্ঘন হবে না এমন আত্মবিশ্বাসের সাথে অ্যাপলেট ডাউনলোড করার ক্ষমতাকে অনেকেই জাভা-এর একক সবচেয়ে উদ্ভাবনী দিক বলে মনে করেন,” IBM-এর একজন সফটওয়্যার ইঞ্জিনিয়ার স্মিত প্রকাশ উল্লেখ করেছেন।

সারসংক্ষেপ

তাই, জাভা নিরাপদ? এটির সংক্ষিপ্তসারে, জাভাতে অবশ্যই অনেকগুলি দুর্দান্ত বৈশিষ্ট্য এবং অন্তর্নির্মিত সরঞ্জাম রয়েছে যা এটিকে আরও সুরক্ষিত করে তোলে। এই বৈশিষ্ট্যগুলির মধ্যে অনেকগুলি জাভার সামগ্রিক জনপ্রিয়তায় একটি গুরুত্বপূর্ণ ভূমিকা পালন করে, বিশেষ করে এন্টারপ্রাইজ মার্কেটে, যেহেতু তারা কোম্পানিগুলিকে তাদের ডেটা অননুমোদিত অ্যাক্সেস থেকে কার্যকরভাবে রক্ষা করার অনুমতি দেয়, পাশাপাশি অনেকগুলি উন্নয়ন প্রক্রিয়া স্বয়ংক্রিয় করে যা অন্যান্য ভাষা দ্বারা স্বয়ংক্রিয় নয়। কিন্তু, আমরা জাভা নিয়ে বড়াই করতে যতটা ভালবাসি এবং এটি কতটা দুর্দান্ত, জাভা এখনও সম্পূর্ণ সুরক্ষিত থেকে অনেক দূরে। প্রকৃতপক্ষে, কোনো প্রোগ্রামিং ভাষাই সম্পূর্ণ সুরক্ষিত নয়, প্রত্যেকটির নিজস্ব শক্তি এবং দুর্বলতা (দুর্বলতা) রয়েছে। সাধারণভাবে বলতে গেলে, সি বিবেচনা করা হয়সেখানে সবচেয়ে ঝুঁকিপূর্ণ প্রোগ্রামিং ভাষা হতে হবে. জাভা, উপরে বর্ণিত বেশ কয়েকটি দুর্দান্ত সুরক্ষা বৈশিষ্ট্য থাকা সত্ত্বেও, সার্ভার-সাইডে এখনও দুর্বল, এবং শোষণের শিকার হতে পারে, বিশেষজ্ঞরা বলছেন
মন্তব্য
TO VIEW ALL COMMENTS OR TO MAKE A COMMENT,
GO TO FULL VERSION