Whiz Tools

பேஸ்64 குறியாக்கி/உருக்கொடுக்கி

உரை மற்றும் பேஸ்64 குறியாக்கத்திற்கான மாற்றம்

நகலெடு

Base64 குறியாக்கி மற்றும் குறியாக்கி

அறிமுகம்

Base64 என்பது பைனரி தரவுகளை ASCII சரம் வடிவத்தில் பிரதிநிதித்துவப்படுத்தும் பைனரி-க்கு-உரை குறியாக்க திட்டமாகும். இது பைனரி வடிவங்களில் சேமிக்கப்பட்ட தரவுகளை உரை உள்ளடக்கம் மட்டுமே நம்பகமாக ஆதரிக்கும் சேனல்களால் கடத்துவதற்கு வடிவமைக்கப்பட்டுள்ளது. Base64 குறியாக்கம் பைனரி தரவுகளை 64 எழுத்துக்களின் தொகுப்பாக மாற்றுகிறது (எனவே பெயர்) இது உரை அடிப்படையிலான நெறிமுறைகளில் தரவுகளை பாதுகாப்பாக அனுப்புவதற்கு எந்தவொரு தரவுப் பிழையும் இல்லாமல்.

Base64 எழுத்துக்களின் தொகுப்பு:

  • பெரிய எழுத்துக்கள் A-Z (26 எழுத்துகள்)
  • சிறிய எழுத்துக்கள் a-z (26 எழுத்துகள்)
  • எண்கள் 0-9 (10 எழுத்துகள்)
  • இரண்டு கூடுதல் எழுத்துகள், பொதுவாக "+" மற்றும் "/" (2 எழுத்துகள்)

இந்த கருவி உங்களுக்கு எளிதாக உரையை Base64 வடிவத்திற்கு குறியாக்கம் செய்யவும் அல்லது Base64 சரங்களை அவற்றின் оригинல் உரைக்கு மீண்டும் குறியாக்கம் செய்யவும் அனுமதிக்கிறது. இது குறிப்பாக டெவலப்பர்கள், IT தொழில்முனைவோர் மற்றும் உரை அடிப்படையிலான சேனல்களில் பாதுகாப்பாக அனுப்பப்பட வேண்டிய தரவுடன் வேலை செய்யும் எந்தவொரு நபருக்கும் பயனுள்ளதாக இருக்கும்.

Base64 குறியாக்கம் எப்படி செயல்படுகிறது

குறியாக்க செயல்முறை

Base64 குறியாக்கம் பைனரி தரவின் ஒவ்வொரு மூன்று பைட்டுகளை (24 பிட்கள்) நான்கு Base64 எழுத்துக்களில் மாற்றுவதன் மூலம் செயல்படுகிறது. செயல்முறை இவ்வாறு உள்ளது:

  1. உள்ளீட்டு உரையை அதன் பைனரி பிரதிநிதித்துவத்தில் மாற்றவும் (ASCII அல்லது UTF-8 குறியாக்கத்தைப் பயன்படுத்தி)
  2. பைனரி தரவுகளை 24 பிட்கள் (3 பைட்) கொண்ட குழுக்களில் தொகுக்கவும்
  3. ஒவ்வொரு 24 பிட்கள் குழுவினையும் நான்கு 6 பிட்கள் குழுக்களாகப் பிரிக்கவும்
  4. ஒவ்வொரு 6 பிட்கள் குழுவையும் அதன் தொடர்புடைய Base64 எழுத்துக்களில் மாற்றவும்

உள்ளீட்டு நீளம் 3-க்கு பகுத்தால், "=" எழுத்துக்களால் நிரப்புதல் சேர்க்கப்படுகிறது, இது வெளியீட்டு மற்றும் உள்ளீட்டு நீளங்களின் 4:3 விகிதத்தை பராமரிக்கிறது.

கணித பிரதிநிதित्वம்

ஒரு பைட்டுகளின் b1,b2,b3b_1, b_2, b_3 வரிசைக்கான தொடர்புடைய Base64 எழுத்துக்கள் c1,c2,c3,c4c_1, c_2, c_3, c_4 இவ்வாறு கணக்கிடப்படுகின்றன:

c1=Base64[(b1>>2)]c_1 = \text{Base64}[(b_1 >> 2)]
c2=Base64[((b1&3)<<4)(b2>>4)]c_2 = \text{Base64}[((b_1 \& 3) << 4) | (b_2 >> 4)]
c3=Base64[((b2&15)<<2)(b3>>6)]c_3 = \text{Base64}[((b_2 \& 15) << 2) | (b_3 >> 6)]
c4=Base64[(b3&63)]c_4 = \text{Base64}[(b_3 \& 63)]

இங்கு Base64[i]\text{Base64}[i] என்பது Base64 அகராதியில் ii-வது எழுத்து.

குறியாக்க செயல்முறை

Base64 குறியாக்கம் குறியாக்க செயல்முறையை மாறுபடுத்துகிறது:

  1. ஒவ்வொரு Base64 எழுத்துக்களையும் 6 பிட்கள் மதிப்பாக மாற்றவும்
  2. இந்த 6 பிட்கள் மதிப்புகளை இணைக்கவும்
  3. பிட்களை 8 பிட்கள் குழுக்களாக (பைட்டுகள்) தொகுக்கவும்
  4. ஒவ்வொரு பைட்டையும் அதன் தொடர்புடைய எழுத்துக்கு மாற்றவும்

நிரப்புதல்

குறியாக்கம் செய்ய வேண்டிய பைட்டுகள் 3-க்கு பகுத்தால், நிரப்புதல் செயல்படுகிறது:

  • ஒரு பைட் மீதமுள்ளால், இது இரண்டு Base64 எழுத்துக்களுக்கு மாற்றப்படுகிறது, பின்னர் "=="
  • இரண்டு பைட்டுகள் மீதமுள்ளால், அவற்றை மூன்று Base64 எழுத்துக்களுக்கு மாற்றுகிறார்கள், பின்னர் "="

உதாரணம்

"Hello" என்ற உரையை Base64-க்கு குறியாக்குவோம்:

  1. "Hello" இன் ASCII பிரதிநிதித்துவம்: 72 101 108 108 111
  2. பைனரி பிரதிநிதித்துவம்: 01001000 01100101 01101100 01101100 01101111
  3. 6 பிட்கள் குழுக்களில் தொகுக்கிறது: 010010 000110 010101 101100 011011 000110 1111
  4. கடைசி குழுவில் 4 பிட்கள் மட்டுமே உள்ளன, எனவே, மின்வெளி சேர்க்கப்படுகிறது: 010010 000110 010101 101100 011011 000110 111100
  5. பின்வட்டத்தில் மாற்றுவது: 18, 6, 21, 44, 27, 6, 60
  6. Base64 அகராதியில் தேடுதல்: S, G, V, s, b, G, 8
  7. முடிவு "SGVsbG8="

முடிவில் "=" நிரப்புதல் உள்ளது, ஏனெனில் உள்ளீட்டு நீளம் (5 பைட்டுகள்) 3-க்கு பகுத்தால் இல்லை.

சூத்திரம்

Base64 குறியாக்கப்பட்ட சரத்தின் நீளத்தை கணக்கிடுவதற்கான பொதுவான சூத்திரம்:

encoded_length=4×input_length3\text{encoded\_length} = 4 \times \lceil \frac{\text{input\_length}}{3} \rceil

இங்கு x\lceil x \rceil என்பது மேலே உள்ள முழு எண்ணிற்கு (உருப்படியை அருகிலுள்ள முழு எண்ணாகச் சுற்றுவது).

பயன்பாட்டு வழிகள்

Base64 குறியாக்கம் பல பயன்பாடுகளில் பரவலாகப் பயன்படுத்தப்படுகிறது:

  1. மின்னஞ்சல் இணைப்புகள்: MIME (பலவகை இணைய மின் அஞ்சல் நீட்டிப்புகள்) Base64 ஐ மின்னஞ்சலில் பைனரி இணைப்புகளை குறியாக்குவதற்கு பயன்படுத்துகிறது.

  2. தரவுகள் URL: HTML, CSS அல்லது JavaScript இல் சிறிய படங்கள், எழுத்துருக்கள் அல்லது பிற வளங்களை நேரடியாக சேர்க்கவும் data: URL திட்டத்தைப் பயன்படுத்துகிறது.

  3. API தொடர்புகள்: JSON payloads அல்லது பிற உரை அடிப்படையிலான API வடிவங்களில் பைனரி தரவுகளை பாதுகாப்பாக அனுப்புவது.

  4. உரை வடிவங்களில் பைனரி தரவுகளை சேமித்தல்: பைனரி தரவுகளை XML, JSON அல்லது பிற உரை அடிப்படையிலான வடிவங்களில் சேமிக்க வேண்டிய போது.

  5. அங்கீகார அமைப்புகள்: HTTP இல் அடிப்படையான அங்கீகாரம் Base64 குறியாக்கத்தைப் பயன்படுத்துகிறது (ஆனால் இது பாதுகாப்பிற்காக அல்ல, குறியாக்கத்திற்காகவே).

  6. கிரிப்டோகிராபி: பல கிரிப்டோகிராபிக் நெறிமுறைகள் மற்றும் அமைப்புகளில், பெரும்பாலும் விசைகள் அல்லது சான்றிதழ்களை குறியாக்குவதற்காக.

  7. குக்கீ மதிப்புகள்: குக்கீக்களில் சேமிக்கப்பட வேண்டிய சிக்கலான தரவுப் கட்டமைப்புகளை குறியாக்கம் செய்வது.

மாற்றுகள்

Base64 பரவலாகப் பயன்படுத்தப்படுவதற்கு, சில சூழ்நிலைகளில் அதிக பொருத்தமான மாற்றுகள் இருக்கலாம்:

  1. URL-பாதுகாப்பான Base64: "+" மற்றும் "/" ஐ "-" மற்றும் "_" க்கு மாற்றும் ஒரு மாறுபாடு, URL குறியாக்கப் பிரச்சினைகளைத் தவிர்க்க. URL இல் உள்ள தரவிற்காக பயனுள்ளதாக உள்ளது.

  2. Base32: 32 எழுத்துக்களைக் கொண்டது, இது நீளமான வெளியீட்டை உருவாக்குகிறது ஆனால் மனித வாசிக்கக்கூடிய மற்றும் வழக்கமாக உள்ளடக்கத்தைக் கொண்டுள்ளது.

  3. Hex குறியாக்கம்: எளிய hexadecimal க்கு மாற்றம், இது குறைவான திறன்திறனை (அளவைக் இரட்டிப்பாக்குகிறது) ஆனால் மிகவும் எளிமையானது மற்றும் பரவலாக ஆதரிக்கப்படுகிறது.

  4. பைனரி பரிமாற்றம்: பெரிய கோப்புகள் அல்லது திறன்திறனை மிகுந்த முக்கியத்துவம் வாய்ந்த போது, நேரடி பைனரி பரிமாற்ற நெறிமுறைகள், HTTP உடன் சரியான உள்ளடக்கம் வகை தலைப்புகளைப் பயன்படுத்துவது சிறந்தது.

  5. சுருக்கம் + Base64: பெரிய உரை தரவிற்காக, குறியாக்கத்திற்கு முன் சுருக்கம் செய்வது அளவைக் குறைக்கலாம்.

  6. JSON/XML சீரமைப்பு: கட்டமைக்கப்பட்ட தரவிற்காக, Base64 குறியாக்கத்தைப் பயன்படுத்துவதற்குப் பதிலாக உள்ளூர் JSON அல்லது XML சீரமைப்பைப் பயன்படுத்துவது அதிக பொருத்தமாக இருக்கலாம்.

வரலாறு

Base64 குறியாக்கம் ஆரம்ப கணினி மற்றும் தொலைத்தொடர்பு அமைப்புகளில் அதன்根源ம், அங்கு பைனரி தரவுகளை உரை வடிவங்களில் பரிமாற்ற வேண்டும்.

Base64 இன் அதிகாரப்பூர்வ விவரணம் முதன்முதலில் 1987 இல் RFC 989 இல் வெளியிடப்பட்டது, இது தனியுரிமை மேம்படுத்தப்பட்ட மின்னஞ்சலை (PEM) வரையறுக்கிறது. இது பின்னர் RFC 1421 (1993) மற்றும் RFC 2045 (1996, MIME இன் ஒரு பகுதியாக) இல் புதுப்பிக்கப்பட்டது.

"Base64" என்ற சொல், குறியாக்கம் 64 வெவ்வேறு ASCII எழுத்துக்களை பைனரி தரவுகளை பிரதிநிதித்துவப்படுத்துவதற்காகப் பயன்படுத்துவதிலிருந்து வந்தது. இந்த 64 எழுத்துக்களின் தேர்வு நோக்கம், 64 என்பது 2 இன் சக்தி (2^6) என்பதால், பைனரி மற்றும் Base64 இடையே மாற்றத்தை திறம்பட செய்வதற்காகவே.

காலப்போக்கில், Base64 இன் பல மாறுபாடுகள் உருவாகின:

  • மாதிரியாக Base64: RFC 4648 இல் வரையறுக்கப்பட்ட, A-Z, a-z, 0-9, +, / மற்றும் = ஐ நிரப்புவதற்காகப் பயன்படுத்துகிறது
  • URL-பாதுகாப்பான Base64: "+" மற்றும் "/" க்கு பதிலாக "-" மற்றும் "_" ஐப் பயன்படுத்துகிறது, URL குறியாக்கப் பிரச்சினைகளைத் தவிர்க்க
  • IMAP க்கான மாற்றப்பட்ட Base64: IMAP நெறிமுறையில் பயன்படுத்தப்படுகிறது, வேறு சிறப்பு எழுத்துக்களின் தொகுப்புடன்
  • பயன்பாட்டு Base64: பைனரி தரவுகளை உரை வடிவத்தில் பாதுகாப்பாக அனுப்புவதற்கு

மூன்று தசாப்தங்களுக்கு மேலாக இருந்தாலும், Base64 இன்றைய கணினி உலகில் அடிப்படை கருவியாகவே உள்ளது, குறிப்பாக இணைய பயன்பாடுகள் மற்றும் JSON போன்ற உரை அடிப்படையிலான தரவுப் வடிவங்களை அடிப்படையாகக் கொண்ட API களை உருவாக்குவதில்.

குறியீட்டு எடுத்துக்காட்டுகள்

பல்வேறு நிரலாக்க மொழிகளில் Base64 குறியாக்கம் மற்றும் குறியாக்கத்தின் எடுத்துக்காட்டுகள் இங்கே உள்ளன:

// JavaScript Base64 குறியாக்கம்/குறியாக்கம்
function encodeToBase64(text) {
  return btoa(text);
}

function decodeFromBase64(base64String) {
  try {
    return atob(base64String);
  } catch (e) {
    throw new Error("செல்லுபடியாகாத Base64 சரம்");
  }
}

// எடுத்துக்காட்டு பயன்பாடு
const originalText = "Hello, World!";
const encoded = encodeToBase64(originalText);
console.log("குறியாக்கம்:", encoded);  // SGVsbG8sIFdvcmxkIQ==

try {
  const decoded = decodeFromBase64(encoded);
  console.log("குறியாக்கப்பட்டது:", decoded);  // Hello, World!
} catch (error) {
  console.error(error.message);
}
# Python Base64 குறியாக்கம்/குறியாக்கம்
import base64

def encode_to_base64(text):
    # சரத்தை பைட்டுகளுக்கு மாற்றி, பின்னர் குறியாக்கம் செய்க
    text_bytes = text.encode('utf-8')
    base64_bytes = base64.b64encode(text_bytes)
    return base64_bytes.decode('utf-8')

def decode_from_base64(base64_string):
    try:
        # Base64 சரத்தை பைட்டுகளுக்கு மாற்றி, பின்னர் குறியாக்கம் செய்க
        base64_bytes = base64_string.encode('utf-8')
        text_bytes = base64.b64decode(base64_bytes)
        return text_bytes.decode('utf-8')
    except Exception as e:
        raise ValueError(f"செல்லுபடியாகாத Base64 சரம்: {e}")

# எடுத்துக்காட்டு பயன்பாடு
original_text = "Hello, World!"
encoded = encode_to_base64(original_text)
print(f"குறியாக்கம்: {encoded}")  # SGVsbG8sIFdvcmxkIQ==

try:
    decoded = decode_from_base64(encoded)
    print(f"குறியாக்கப்பட்டது: {decoded}")  # Hello, World!
except ValueError as e:
    print(e)
// Java Base64 குறியாக்கம்/குறியாக்கம்
import java.util.Base64;
import java.nio.charset.StandardCharsets;

public class Base64Example {
    public static String encodeToBase64(String text) {
        byte[] textBytes = text.getBytes(StandardCharsets.UTF_8);
        byte[] encodedBytes = Base64.getEncoder().encode(textBytes);
        return new String(encodedBytes, StandardCharsets.UTF_8);
    }
    
    public static String decodeFromBase64(String base64String) {
        try {
            byte[] base64Bytes = base64String.getBytes(StandardCharsets.UTF_8);
            byte[] decodedBytes = Base64.getDecoder().decode(base64Bytes);
            return new String(decodedBytes, StandardCharsets.UTF_8);
        } catch (IllegalArgumentException e) {
            throw new IllegalArgumentException("செல்லுபடியாகாத Base64 சரம்: " + e.getMessage());
        }
    }
    
    public static void main(String[] args) {
        String originalText = "Hello, World!";
        String encoded = encodeToBase64(originalText);
        System.out.println("குறியாக்கம்: " + encoded);  // SGVsbG8sIFdvcmxkIQ==
        
        try {
            String decoded = decodeFromBase64(encoded);
            System.out.println("குறியாக்கப்பட்டது: " + decoded);  // Hello, World!
        } catch (IllegalArgumentException e) {
            System.err.println(e.getMessage());
        }
    }
}
<?php
// PHP Base64 குறியாக்கம்/குறியாக்கம்
function encodeToBase64($text) {
    return base64_encode($text);
}

function decodeFromBase64($base64String) {
    $decoded = base64_decode($base64String, true);
    if ($decoded === false) {
        throw new Exception("செல்லுபடியாகாத Base64 சரம்");
    }
    return $decoded;
}

// எடுத்துக்காட்டு பயன்பாடு
$originalText = "Hello, World!";
$encoded = encodeToBase64($originalText);
echo "குறியாக்கம்: " . $encoded . "\n";  // SGVsbG8sIFdvcmxkIQ==

try {
    $decoded = decodeFromBase64($encoded);
    echo "குறியாக்கப்பட்டது: " . $decoded . "\n";  // Hello, World!
} catch (Exception $e) {
    echo "பிழை: " . $e->getMessage() . "\n";
}
?>
// C# Base64 குறியாக்கம்/குறியாக்கம்
using System;
using System.Text;

class Base64Example
{
    public static string EncodeToBase64(string text)
    {
        byte[] textBytes = Encoding.UTF8.GetBytes(text);
        return Convert.ToBase64String(textBytes);
    }
    
    public static string DecodeFromBase64(string base64String)
    {
        try
        {
            byte[] base64Bytes = Convert.FromBase64String(base64String);
            return Encoding.UTF8.GetString(base64Bytes);
        }
        catch (FormatException)
        {
            throw new FormatException("செல்லுபடியாகாத Base64 சரம்");
        }
    }
    
    static void Main()
    {
        string originalText = "Hello, World!";
        string encoded = EncodeToBase64(originalText);
        Console.WriteLine($"குறியாக்கம்: {encoded}");  // SGVsbG8sIFdvcmxkIQ==
        
        try
        {
            string decoded = DecodeFromBase64(encoded);
            Console.WriteLine($"குறியாக்கப்பட்டது: {decoded}");  // Hello, World!
        }
        catch (FormatException e)
        {
            Console.WriteLine($"பிழை: {e.Message}");
        }
    }
}
# Ruby Base64 குறியாக்கம்/குறியாக்கம்
require 'base64'

def encode_to_base64(text)
  Base64.strict_encode64(text)
end

def decode_from_base64(base64_string)
  begin
    Base64.strict_decode64(base64_string)
  rescue ArgumentError => e
    raise "செல்லுபடியாகாத Base64 சரம்: #{e.message}"
  end
end

# எடுத்துக்காட்டு பயன்பாடு
original_text = "Hello, World!"
encoded = encode_to_base64(original_text)
puts "குறியாக்கம்: #{encoded}"  # SGVsbG8sIFdvcmxkIQ==

begin
  decoded = decode_from_base64(encoded)
  puts "குறியாக்கப்பட்டது: #{decoded}"  # Hello, World!
rescue StandardError => e
  puts "பிழை: #{e.message}"
end
// Go Base64 குறியாக்கம்/குறியாக்கம்
package main

import (
    "encoding/base64"
    "fmt"
)

func encodeToBase64(text string) string {
    return base64.StdEncoding.EncodeToString([]byte(text))
}

func decodeFromBase64(base64String string) (string, error) {
    bytes, err := base64.StdEncoding.DecodeString(base64String)
    if err != nil {
        return "", fmt.Errorf("செல்லுபடியாகாத Base64 சரம்: %v", err)
    }
    return string(bytes), nil
}

func main() {
    originalText := "Hello, World!"
    encoded := encodeToBase64(originalText)
    fmt.Println("குறியாக்கம்:", encoded)  // SGVsbG8sIFdvcmxkIQ==
    
    decoded, err := decodeFromBase64(encoded)
    if err != nil {
        fmt.Println("பிழை:", err)
    } else {
        fmt.Println("குறியாக்கப்பட்டது:", decoded)  // Hello, World!
    }
}
// Swift Base64 குறியாக்கம்/குறியாக்கம்
import Foundation

func encodeToBase64(_ text: String) -> String? {
    if let data = text.data(using: .utf8) {
        return data.base64EncodedString()
    }
    return nil
}

func decodeFromBase64(_ base64String: String) -> String? {
    if let data = Data(base64Encoded: base64String) {
        return String(data: data, encoding: .utf8)
    }
    return nil
}

// எடுத்துக்காட்டு பயன்பாடு
let originalText = "Hello, World!"
if let encoded = encodeToBase64(originalText) {
    print("குறியாக்கம்: \(encoded)")  // SGVsbG8sIFdvcmxkIQ==
    
    if let decoded = decodeFromBase64(encoded) {
        print("குறியாக்கப்பட்டது: \(decoded)")  // Hello, World!
    } else {
        print("பிழை: Base64 சரத்தை குறியாக்க முடியவில்லை")
    }
} else {
    print("பிழை: சரத்தை குறியாக்க முடியவில்லை")
}
' Excel VBA Base64 குறியாக்கம்/குறியாக்கம்
' குறிப்பு: இது Microsoft XML, v6.0 க்கு ஒரு மேற்கோளைப் தேவைப்படுகிறது
Function EncodeToBase64(text As String) As String
    Dim xmlObj As Object
    Set xmlObj = CreateObject("MSXML2.DOMDocument")
    
    Dim xmlNode As Object
    Set xmlNode = xmlObj.createElement("b64")
    
    xmlNode.DataType = "bin.base64"
    xmlNode.nodeTypedValue = StrConv(text, vbFromUnicode)
    
    EncodeToBase64 = xmlNode.text
    
    Set xmlNode = Nothing
    Set xmlObj = Nothing
End Function

Function DecodeFromBase64(base64String As String) As String
    On Error GoTo ErrorHandler
    
    Dim xmlObj As Object
    Set xmlObj = CreateObject("MSXML2.DOMDocument")
    
    Dim xmlNode As Object
    Set xmlNode = xmlObj.createElement("b64")
    
    xmlNode.DataType = "bin.base64"
    xmlNode.text = base64String
    
    DecodeFromBase64 = StrConv(xmlNode.nodeTypedValue, vbUnicode)
    
    Set xmlNode = Nothing
    Set xmlObj = Nothing
    Exit Function
    
ErrorHandler:
    DecodeFromBase64 = "பிழை: செல்லுபடியாகாத Base64 சரம்"
End Function

' ஒரு வேலைப்பதிவில் பயன்பாடு:
' =EncodeToBase64("Hello, World!")
' =DecodeFromBase64("SGVsbG8sIFdvcmxkIQ==")
# R Base64 குறியாக்கம்/குறியாக்கம்
# 'base64enc' தொகுப்பை தேவை
# install.packages("base64enc")
library(base64enc)

encode_to_base64 <- function(text) {
  # உரையை கச்சா பைட்டுகளுக்கு மாற்றி, பின்னர் குறியாக்கம் செய்க
  text_raw <- charToRaw(text)
  base64_encoded <- base64encode(text_raw)
  return(rawToChar(base64_encoded))
}

decode_from_base64 <- function(base64_string) {
  tryCatch({
    # Base64 சரத்தை கச்சா பைட்டுகளுக்கு மாற்றி, பின்னர் குறியாக்கம் செய்க
    base64_raw <- charToRaw(base64_string)
    decoded_raw <- base64decode(base64_raw)
    return(rawToChar(decoded_raw))
  }, error = function(e) {
    stop(paste("செல்லுபடியாகாத Base64 சரம்:", e$message))
  })
}

# எடுத்துக்காட்டு பயன்பாடு
original_text <- "Hello, World!"
encoded <- encode_to_base64(original_text)
cat("குறியாக்கம்:", encoded, "\n")  # SGVsbG8sIFdvcmxkIQ==

tryCatch({
  decoded <- decode_from_base64(encoded)
  cat("குறியாக்கப்பட்டது:", decoded, "\n")  # Hello, World!
}, error = function(e) {
  cat("பிழை:", e$message, "\n")
})
% MATLAB Base64 குறியாக்கம்/குறியாக்கம்
function demo_base64()
    originalText = 'Hello, World!';
    
    % குறியாக்கம்
    encoded = encode_to_base64(originalText);
    fprintf('குறியாக்கம்: %s\n', encoded);  % SGVsbG8sIFdvcmxkIQ==
    
    % குறியாக்கம்
    try
        decoded = decode_from_base64(encoded);
        fprintf('குறியாக்கப்பட்டது: %s\n', decoded);  % Hello, World!
    catch e
        fprintf('பிழை: %s\n', e.message);
    end
end

function encoded = encode_to_base64(text)
    % உரையை uint8 வரிசையாக மாற்றி குறியாக்கம் செய்க
    bytes = uint8(text);
    encoded = base64encode(bytes);
end

function decoded = decode_from_base64(base64String)
    try
        % Base64 சரத்தை uint8 வரிசையாக குறியாக்கம் செய்க
        bytes = base64decode(base64String);
        decoded = char(bytes);
    catch
        error('செல்லுபடியாகாத Base64 சரம்');
    end
end
// C Base64 குறியாக்கம்/குறியாக்கம் OpenSSL ஐப் பயன்படுத்தி
#include <stdio.h>
#include <string.h>
#include <openssl/bio.h>
#include <openssl/evp.h>
#include <openssl/buffer.h>
#include <stdint.h>

char* encode_to_base64(const char* input) {
    BIO *bio, *b64;
    BUF_MEM *bufferPtr;
    
    b64 = BIO_new(BIO_f_base64());
    bio = BIO_new(BIO_s_mem());
    bio = BIO_push(b64, bio);
    
    BIO_set_flags(bio, BIO_FLAGS_BASE64_NO_NL);
    BIO_write(bio, input, strlen(input));
    BIO_flush(bio);
    BIO_get_mem_ptr(bio, &bufferPtr);
    
    char* result = (char*)malloc(bufferPtr->length + 1);
    memcpy(result, bufferPtr->data, bufferPtr->length);
    result[bufferPtr->length] = '\0';
    
    BIO_free_all(bio);
    
    return result;
}

char* decode_from_base64(const char* input) {
    BIO *bio, *b64;
    size_t length = strlen(input);
    char* buffer = (char*)malloc(length);
    
    b64 = BIO_new(BIO_f_base64());
    bio = BIO_new_mem_buf(input, -1);
    bio = BIO_push(b64, bio);
    
    BIO_set_flags(bio, BIO_FLAGS_BASE64_NO_NL);
    int decoded_length = BIO_read(bio, buffer, length);
    
    if (decoded_length <= 0) {
        free(buffer);
        BIO_free_all(bio);
        return NULL; // செல்லுபடியாகாத Base64 உள்ளீடு
    }
    
    buffer[decoded_length] = '\0';
    
    BIO_free_all(bio);
    
    return buffer;
}

int main() {
    const char* original_text = "Hello, World!";
    
    char* encoded = encode_to_base64(original_text);
    printf("குறியாக்கம்: %s\n", encoded);  // SGVsbG8sIFdvcmxkIQ==
    
    char* decoded = decode_from_base64(encoded);
    if (decoded) {
        printf("குறியாக்கப்பட்டது: %s\n", decoded);  // Hello, World!
        free(decoded);
    } else {
        printf("பிழை: செல்லுபடியாகாத Base64 சரம்\n");
    }
    
    free(encoded);
    
    return 0;
}
// Rust Base64 குறியாக்கம்/குறியாக்கம்
use base64::{encode, decode};
use std::str;

fn encode_to_base64(text: &str) -> String {
    encode(text)
}

fn decode_from_base64(base64_string: &str) -> Result<String, String> {
    match decode(base64_string) {
        Ok(bytes) => {
            match str::from_utf8(&bytes) {
                Ok(text) => Ok(text.to_string()),
                Err(e) => Err(format!("செல்லுபடியாகாத UTF-8 வரிசை: {}", e))
            }
        },
        Err(e) => Err(format!("செல்லுபடியாகாத Base64 சரம்: {}", e))
    }
}

fn main() {
    let original_text = "Hello, World!";
    let encoded = encode_to_base64(original_text);
    println!("குறியாக்கம்: {}", encoded);  // SGVsbG8sIFdvcmxkIQ==
    
    match decode_from_base64(&encoded) {
        Ok(decoded) => println!("குறியாக்கப்பட்டது: {}", decoded),  // Hello, World!
        Err(e) => println!("பிழை: {}", e)
    }
}

எல்லை நிகழ்வுகள் மற்றும் கருத்துக்கள்

Base64 குறியாக்கம் மற்றும் குறியாக்கத்துடன் வேலை செய்யும் போது, இந்த முக்கிய கருத்துக்களை கவனிக்கவும்:

  1. யூனிகோட் மற்றும் அச்சி எழுத்துக்கள்: அச்சி எழுத்துக்களை உள்ளடக்கிய உரையை குறியாக்கும் போது, Base64 குறியாக்கத்திற்கு முன் சரியான எழுத்து குறியாக்கத்தை (பொதுவாக UTF-8) உறுதி செய்யவும்.

  2. நிரப்புதல்: தரவின் நீளம் 4-க்கு பகுத்தால், "=" எழுத்துக்களால் நிரப்புதல் சேர்க்கப்படுகிறது. சில செயல்பாடுகள் நிரப்புதலை தவிர்க்கலாம், இது ஒத்துழைப்பு பிரச்சினைகளை உருவாக்கலாம்.

  3. வழி உடைகள்: பாரம்பரிய Base64 செயல்பாடுகள் வாசிக்கக்கூடியதற்காக (பொதுவாக 76 எழுத்துக்கள் ஒவ்வொன்றுக்கு) வழி உடைகளைச் சேர்க்கின்றன, ஆனால் நவீன பயன்பாடுகள் பொதுவாக இவற்றை தவிர்க்கின்றன.

  4. URL-பாதுகாப்பான Base64: Base64 ஐ "+" மற்றும் "/" எழுத்துக்களைப் பயன்படுத்துகிறது, இது URL இல் சிறப்பு அர்த்தங்களை கொண்டுள்ளது. URL சூழ்நிலைகளுக்காக, URL-பாதுகாப்பான Base64 ஐப் பயன்படுத்தவும்.

  5. வெள்ளை இடங்கள்: குறியாக்கத்தின் போது, சில செயல்பாடுகள் வெள்ளை இடங்களை மன்னிக்கும் போது, மற்றவை சரியான உள்ளீட்டை தேவைப்படுத்துகின்றன.

  6. அளவீட்டில் அதிகரிப்பு: Base64 குறியாக்கம் தரவின் அளவை சுமார் 33% அதிகரிக்கிறது (3 உள்ளீட்டு பைட்டுகளுக்கு 4 வெளியீட்டு பைட்டுகள்).

  7. செயல்திறன்: மிகவும் பெரிய தரவுக்கு Base64 குறியாக்கம்/குறியாக்கம் கணினி வளங்களை அதிகமாகப் பயன்படுத்தலாம். மிகவும் பெரிய கோப்புகளுக்கு ஓட்டம் முறைகளைப் பரிசீலிக்கவும்.

மேற்கோள்கள்

  1. RFC 4648 - The Base16, Base32, and Base64 Data Encodings
  2. RFC 2045 - MIME Part One: Format of Internet Message Bodies
  3. MDN Web Docs: Base64 encoding and decoding
  4. Base64 - Wikipedia
  5. MIME - Wikipedia
Feedback