OWASP বিভাগ: MASVS-CODE: কোড গুণমান
ওভারভিউ
একটি অ্যাপ্লিকেশনে গতিশীলভাবে কোড লোড করা একটি ঝুঁকির স্তর প্রবর্তন করে যা প্রশমিত করতে হবে। আক্রমণকারীরা সম্ভাব্য সংবেদনশীল ডেটা অ্যাক্সেস করতে বা ক্ষতিকারক ক্রিয়া সম্পাদন করতে কোডের সাথে ছত্রভঙ্গ বা প্রতিস্থাপন করতে পারে।
অনেক ধরনের ডায়নামিক কোড লোডিং, বিশেষ করে যেগুলি রিমোট সোর্স ব্যবহার করে, Google Play নীতি লঙ্ঘন করে এবং Google Play থেকে আপনার অ্যাপকে সাসপেনশন করতে পারে।
প্রভাব
আক্রমণকারীরা যদি অ্যাপ্লিকেশনটিতে লোড করা কোডটিতে অ্যাক্সেস পেতে পরিচালনা করে তবে তারা তাদের লক্ষ্যগুলি সমর্থন করার জন্য এটিকে সংশোধন করতে পারে। এটি ডেটা এক্সফিল্ট্রেশন এবং কোড এক্সিকিউশন শোষণের দিকে নিয়ে যেতে পারে। এমনকি যদি আক্রমণকারীরা তাদের পছন্দের স্বেচ্ছাচারী ক্রিয়া সম্পাদনের জন্য কোডটি সংশোধন করতে না পারে, তবুও এটি সম্ভব যে তারা কোডটি দুর্নীতিগ্রস্ত বা অপসারণ করতে পারে এবং এইভাবে অ্যাপ্লিকেশনের প্রাপ্যতাকে প্রভাবিত করতে পারে।
প্রশমন
ডায়নামিক কোড লোডিং ব্যবহার করা এড়িয়ে চলুন
ব্যবসার প্রয়োজন না থাকলে, ডায়নামিক কোড লোডিং এড়িয়ে চলুন। আপনি যখনই সম্ভব, অ্যাপ্লিকেশনটিতে সরাসরি সমস্ত কার্যকারিতা অন্তর্ভুক্ত করতে পছন্দ করবেন।
বিশ্বস্ত উত্স ব্যবহার করুন
যে কোডটি অ্যাপ্লিকেশনে লোড করা হবে তা বিশ্বস্ত স্থানে সংরক্ষণ করা উচিত। স্থানীয় স্টোরেজ সম্পর্কে, অ্যাপ্লিকেশন অভ্যন্তরীণ সঞ্চয়স্থান বা স্কোপড স্টোরেজ (অ্যান্ড্রয়েড 10 এবং পরবর্তীতে) প্রস্তাবিত স্থান। অন্যান্য অ্যাপ্লিকেশন এবং ব্যবহারকারীদের কাছ থেকে সরাসরি অ্যাক্সেস এড়াতে এই অবস্থানগুলিতে ব্যবস্থা রয়েছে৷
ইউআরএলের মতো দূরবর্তী অবস্থান থেকে কোড লোড করার সময়, সম্ভব হলে তৃতীয় পক্ষ ব্যবহার করা এড়িয়ে চলুন এবং নিরাপত্তার সর্বোত্তম অনুশীলন অনুসরণ করে কোডটি আপনার নিজস্ব পরিকাঠামোতে সংরক্ষণ করুন। আপনি যদি তৃতীয় পক্ষের কোড লোড করতে চান, তাহলে নিশ্চিত করুন যে প্রদানকারী বিশ্বস্ত।
অখণ্ডতা চেক সঞ্চালন
অখণ্ডতা চেক করার সুপারিশ করা হয় যাতে নিশ্চিত করা হয় যে কোডের সাথে কোনো হেরফের করা হয়নি। অ্যাপ্লিকেশনে কোড লোড করার আগে এই চেকগুলি করা উচিত।
দূরবর্তী সংস্থানগুলি লোড করার সময়, অ্যাক্সেস করা সংস্থানগুলির অখণ্ডতা যাচাই করার জন্য সাবরিসোর্স অখণ্ডতা ব্যবহার করা যেতে পারে।
বাহ্যিক সঞ্চয়স্থান থেকে সংস্থানগুলি লোড করার সময়, অন্য কোনও অ্যাপ্লিকেশন এই ডেটা বা কোডের সাথে হেরফের করেনি তা যাচাই করতে অখণ্ডতা পরীক্ষা ব্যবহার করুন৷ ফাইলগুলির হ্যাশগুলি একটি নিরাপদ পদ্ধতিতে সংরক্ষণ করা উচিত, বিশেষত এনক্রিপ্ট করা এবং অভ্যন্তরীণ স্টোরেজে।
কোটলিন
package com.example.myapplication
import java.io.BufferedInputStream
import java.io.FileInputStream
import java.io.IOException
import java.security.MessageDigest
import java.security.NoSuchAlgorithmException
object FileIntegrityChecker {
@Throws(IOException::class, NoSuchAlgorithmException::class)
fun getIntegrityHash(filePath: String?): String {
val md = MessageDigest.getInstance("SHA-256") // You can choose other algorithms as needed
val buffer = ByteArray(8192)
var bytesRead: Int
BufferedInputStream(FileInputStream(filePath)).use { fis ->
while (fis.read(buffer).also { bytesRead = it } != -1) {
md.update(buffer, 0, bytesRead)
}
}
private fun bytesToHex(bytes: ByteArray): String {
val sb = StringBuilder(bytes.length * 2)
for (b in bytes) {
sb.append(String.format("%02x", b))
}
return sb.toString()
}
@Throws(IOException::class, NoSuchAlgorithmException::class)
fun verifyIntegrity(filePath: String?, expectedHash: String): Boolean {
val actualHash = getIntegrityHash(filePath)
return actualHash == expectedHash
}
@Throws(Exception::class)
@JvmStatic
fun main(args: Array<String>) {
val filePath = "/path/to/your/file"
val expectedHash = "your_expected_hash_value"
if (verifyIntegrity(filePath, expectedHash)) {
println("File integrity is valid!")
} else {
println("File integrity is compromised!")
}
}
}
জাভা
package com.example.myapplication;
import java.io.BufferedInputStream;
import java.io.FileInputStream;
import java.io.IOException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
public class FileIntegrityChecker {
public static String getIntegrityHash(String filePath) throws IOException, NoSuchAlgorithmException {
MessageDigest md = MessageDigest.getInstance("SHA-256"); // You can choose other algorithms as needed
byte[] buffer = new byte[8192];
int bytesRead;
try (BufferedInputStream fis = new BufferedInputStream(new FileInputStream(filePath))) {
while ((bytesRead = fis.read(buffer)) != -1) {
md.update(buffer, 0, bytesRead);
}
}
byte[] digest = md.digest();
return bytesToHex(digest);
}
private static String bytesToHex(byte[] bytes) {
StringBuilder sb = new StringBuilder(bytes.length * 2);
for (byte b : bytes) {
sb.append(String.format("%02x", b));
}
return sb.toString();
}
public static boolean verifyIntegrity(String filePath, String expectedHash) throws IOException, NoSuchAlgorithmException {
String actualHash = getIntegrityHash(filePath);
return actualHash.equals(expectedHash);
}
public static void main(String[] args) throws Exception {
String filePath = "/path/to/your/file";
String expectedHash = "your_expected_hash_value";
if (verifyIntegrity(filePath, expectedHash)) {
System.out.println("File integrity is valid!");
} else {
System.out.println("File integrity is compromised!");
}
}
}
কোড সাইন ইন করুন
ডেটার অখণ্ডতা নিশ্চিত করার আরেকটি বিকল্প হল কোডটি স্বাক্ষর করা এবং এটি লোড করার আগে তার স্বাক্ষর যাচাই করা। এই পদ্ধতিতে হ্যাশ কোডের অখণ্ডতা নিশ্চিত করার সুবিধা রয়েছে, শুধুমাত্র কোডই নয়, যা একটি অতিরিক্ত অ্যান্টি-টেম্পারিং সুরক্ষা প্রদান করে।
যদিও কোড সাইনিং অতিরিক্ত নিরাপত্তা স্তর প্রদান করে, তবে এটি বিবেচনা করা গুরুত্বপূর্ণ যে এটি একটি আরও জটিল প্রক্রিয়া যা সফলভাবে বাস্তবায়নের জন্য অতিরিক্ত প্রচেষ্টা এবং সম্পদের প্রয়োজন হতে পারে।
কোড স্বাক্ষরের কিছু উদাহরণ এই নথির সম্পদ বিভাগে পাওয়া যাবে।