Miklix

CRC-32C ဟက်ရှ်ကုဒ်တွက်စက်

ထုတ်ဝေသည်- ၂၀၂၅၊ ဖေဖော်ဝါရီ ၁၇ UTC ၁၈:၄၈:၄၂
နောက်ဆုံး မွမ်းမံပြင်ဆင်သည်- ၂၀၂၆၊ ဇန်နဝါရီ ၁၂ UTC ၁၁:၃၇:၄၆

စာသားထည့်သွင်းမှု သို့မဟုတ် ဖိုင်တင်ခြင်းအပေါ် အခြေခံ၍ hash ကုဒ်ကို တွက်ချက်ရန် CRC-32C (Cyclic Redundancy Check 32 bit, C variant) hash လုပ်ဆောင်ချက်ကို အသုံးပြုသည့် Hash code ဂဏန်းတွက်စက်။

ဤစာမျက်နှာကို လူများတတ်နိုင်သမျှ ဝင်ရောက်ကြည့်ရှုနိုင်စေရန်အတွက် ဤစာမျက်နှာကို အင်္ဂလိပ်မှ စက်ဖြင့် ဘာသာပြန်ထားခြင်းဖြစ်ပါသည်။ ကံမကောင်းစွာဖြင့်၊ စက်ဘာသာပြန်ခြင်းသည် ပြီးပြည့်စုံသောနည်းပညာမဟုတ်သေးသောကြောင့် အမှားအယွင်းများဖြစ်ပေါ်လာနိုင်သည်။ သင်နှစ်သက်ပါက မူရင်းအင်္ဂလိပ်ဗားရှင်းကို ဤနေရာတွင် ကြည့်ရှုနိုင်ပါသည်။

CRC-32C Hash Code Calculator

Cyclic Redundancy Check (CRC) သည် raw data များတွင် မတော်တဆပြောင်းလဲမှုများကို ထောက်လှမ်းရန် အသုံးများသော error-detecting code တစ်ခုဖြစ်သည်။ နည်းပညာပိုင်းအရ cryptographic hash function မဟုတ်သော်လည်း၊ CRC-32 ကို variable-length input မှ fixed-size output (32 bits) ကို ထုတ်လုပ်ပေးနိုင်သောကြောင့် hash အဖြစ် မကြာခဏ ရည်ညွှန်းလေ့ရှိသည်။ ဤစာမျက်နှာတွင် တင်ပြထားသော ဗားရှင်းမှာ CRC-32C variant ဖြစ်ပြီး၊ ၎င်းသည် ခေတ်မီ CPU များတွင် hardware ဖြင့် အရှိန်မြှင့်လေ့ရှိသော (SSE 4.2 မှတစ်ဆင့်) "ပိုမိုစမတ်ကျသော" (ပိုမိုကောင်းမွန်သော error detection) ဗားရှင်းဖြစ်သည်။

ထုတ်ဖော်ချက်အပြည့်အစုံ- ဤစာမျက်နှာတွင်အသုံးပြုထားသော hash function ၏ သီးခြားအကောင်အထည်ဖော်မှုကို ကျွန်ုပ်မရေးခဲ့ပါ။ ၎င်းသည် PHP ပရိုဂရမ်းမင်းဘာသာစကားဖြင့် ပါဝင်သော စံလုပ်ဆောင်ချက်တစ်ခုဖြစ်သည်။ အဆင်ပြေစေရန် ဤနေရာတွင် လူသိရှင်ကြားရစေရန် ဝဘ်အင်တာဖေ့စ်ကိုသာ ပြုလုပ်ထားပါသည်။


Hash Code အသစ်ကို တွက်ချက်ပါ။

ပေးပို့ထားသော ဒေတာ သို့မဟုတ် ဤဖောင်မှတစ်ဆင့် အပ်လုဒ်လုပ်ထားသော ဖိုင်များသည် တောင်းဆိုထားသော hash ကုဒ်ကို ထုတ်လုပ်ရန် အချိန်ကြာသ၍ ဆာဗာတွင်သာ သိမ်းဆည်းထားမည်ဖြစ်သည်။ ရလဒ်ကို သင့်ဘရောက်ဆာသို့ ပြန်မပို့မီ ၎င်းကို ချက်ချင်း ဖျက်လိုက်ပါမည်။

ထည့်သွင်းဒေတာ-



တင်ပြထားသော စာသားသည် UTF-8 ကုဒ်လုပ်ထားသည်။ hash လုပ်ဆောင်ချက်များသည် binary data ပေါ်တွင် လုပ်ဆောင်သောကြောင့်၊ ရလဒ်သည် စာသားသည် အခြားသော encoding တွင်ရှိနေပါက ရလဒ်သည် ကွဲပြားမည်ဖြစ်သည်။ သီးခြားကုဒ်နံပါတ်တစ်ခုတွင် စာသားတစ်ခု၏ hash ကို တွက်ချက်ရန် လိုအပ်ပါက၊ ၎င်းအစား ဖိုင်တစ်ခုကို အပ်လုဒ်လုပ်သင့်သည်။



CRC-32C Hash Algorithm အကြောင်း

ကျွန်တော်က သင်္ချာပညာရှင် မဟုတ်ပေမယ့် ဒီ hash function ကို ရိုးရှင်းတဲ့ ဥပမာတစ်ခုနဲ့ ရှင်းပြပါ့မယ်။ တခြား cryptographic hash function တွေနဲ့ မတူဘဲ၊ ဒါက အထူးရှုပ်ထွေးတဲ့ algorithm မဟုတ်တဲ့အတွက် အဆင်ပြေနိုင်ပါတယ် ;-)

စာတိုက်ကနေ စာတစ်စောင်ပို့နေတယ်လို့ မြင်ယောင်ကြည့်ပါ၊ ဒါပေမယ့် လက်ခံသူဆီ မရောက်ခင် ပျက်စီးသွားမှာကို စိုးရိမ်နေမိတယ်။ စာရဲ့ အကြောင်းအရာပေါ်မူတည်ပြီး CRC-32 checksum ကို တွက်ချက်ပြီး စာအိတ်ပေါ်မှာ ရေးပါ။ လက်ခံသူက စာလက်ခံရရှိတဲ့အခါ checksum ကိုလည်း တွက်ချက်ပြီး သင်ရေးထားတာနဲ့ ကိုက်ညီမှုရှိမရှိ ကြည့်နိုင်ပါတယ်။ ကိုက်ညီတယ်ဆိုရင်တော့ စာက ပျက်စီးသွားတာ ဒါမှမဟုတ် ပြောင်းလဲသွားတာ မရှိပါဘူး။

CRC-32 က ဒီလိုလုပ်ဆောင်ပုံက အဆင့်လေးဆင့်နဲ့ လုပ်ဆောင်ပါတယ်။

အဆင့် ၁: အပိုနေရာလွတ်ထည့်ပါ (Padding)

  • CRC က မက်ဆေ့ချ်ရဲ့အဆုံးမှာ နေရာအနည်းငယ်ထပ်ထည့်ပေးပါတယ် (ဥပမာ မြေပဲတွေကို သေတ္တာထဲထည့်သလိုပါပဲ)။
  • ဒါက အမှားတွေကို ပိုမိုလွယ်ကူစွာ ရှာဖွေတွေ့ရှိနိုင်အောင် ကူညီပေးပါတယ်။

အဆင့် ၂: မှော်ရူပါရုံ (ပိုလီနိုမီရယ်)

  • CRC-32 သည် ဒေတာကိုတိုင်းတာရန် အထူး "မှော်ပေတံ" ကို အသုံးပြုသည်။ ဤပေတံကို အဖုအထစ်များနှင့် မြောင်းများ၏ ပုံစံတစ်ခုအဖြစ် သဘောထားပါ (၎င်းသည် ပိုလီနိုမီရယ်ဖြစ်သည်၊ သို့သော် ထိုစကားလုံးအတွက် စိတ်မပူပါနှင့်)။ CRC-32 အတွက် အသုံးအများဆုံး "ပေတံ" သည် ပုံသေပုံစံတစ်ခုဖြစ်သည်။

အဆင့် ၃: ပေတံကို လျှောချခြင်း (ပိုင်းခြားခြင်းလုပ်ငန်းစဉ်)

  • ယခု CRC သည် ပေတံကို မက်ဆေ့ချ်တစ်လျှောက် လျှောကျစေသည်။ နေရာတိုင်းတွင် အဖုအထစ်များနှင့် မြောင်းများ တစ်တန်းတည်းဖြစ်မဖြစ် စစ်ဆေးသည်။ ၎င်းတို့ တစ်တန်းတည်းမဖြစ်ပါက CRC သည် မှတ်စုတစ်ခုပြုလုပ်သည် (၎င်းကို ခလုတ်များကို ဖွင့်ခြင်း သို့မဟုတ် ပိတ်ခြင်းကဲ့သို့ ရိုးရှင်းသော XOR ကို အသုံးပြု၍ လုပ်ဆောင်သည်)။ ၎င်းသည် ခလုတ်များကို အဆုံးသို့မရောက်မချင်း လျှောကျပြီး လှန်လှောနေသည်။

အဆင့် ၄: နောက်ဆုံးရလဒ် (Checksum)

  • မက်ဆေ့ချ်တစ်ခုလုံးပေါ်တွင် ပေတံကို လျှောကျစေပြီးနောက်၊ မူရင်းဒေတာကို ကိုယ်စားပြုသည့် နံပါတ်ငယ်တစ်ခု (32 bits ရှည်လျားသည်) ကျန်ရှိနေမည်ဖြစ်သည်။ ဤနံပါတ်သည် မက်ဆေ့ချ်အတွက် ထူးခြားသော လက်ဗွေရာတစ်ခုကဲ့သို့ဖြစ်သည်။ ၎င်းသည် CRC-32 checksum ဖြစ်သည်။

စာမျက်နှာမှာ တင်ပြထားတဲ့ ဗားရှင်းက CRC-32C ဗားရှင်းဖြစ်ပြီး အထူးသဖြင့် hardware accelerated ရှိတဲ့ CPU (SSE 4.2 နဲ့ နောက်ပိုင်းဗားရှင်း) ကို အသုံးပြုနေပြီး တခြားဗားရှင်းတွေနဲ့ တွဲဖက်အသုံးပြုနိုင်ဖို့ မလိုအပ်ဘူးဆိုရင် ပိုသင့်တော်တဲ့ ဗားရှင်းဖြစ်သင့်ပါတယ်။

တခြားဗားရှင်းတွေအတွက်လည်း ဂဏန်းတွက်စက်တွေ ကျွန်တော်မှာရှိပါတယ်။

  • လင့်ခ်
  • လင့်ခ်

နောက်ထပ်စာဖတ်ခြင်း။

ဤပို့စ်ကို သင်နှစ်သက်ပါက၊ ဤအကြံပြုချက်များကို သင်လည်း နှစ်သက်နိုင်ပါသည်-


Bluesky တွင်မျှဝေပါ။Facebook တွင်မျှဝေပါ။LinkedIn တွင်မျှဝေပါ။Tumblr တွင်မျှဝေပါ။X တွင်မျှဝေပါ။LinkedIn တွင်မျှဝေပါ။ပင်တရက်စ်တွင် ပင်ထားပါ

Mikkel Christensen

စာရေးသူအကြောင်း

Mikkel Christensen
မိုက်ကယ် သည် miklix.com ၏ ဖန်တီးရှင်နှင့် ပိုင်ရှင်ဖြစ်သည်။ သူသည် ပရော်ဖက်ရှင်နယ် ကွန်ပြူတာ ပရိုဂရမ်မာ/ဆော့ဖ်ဝဲလ် တီထွင်သူအဖြစ် နှစ်ပေါင်း 20 ကျော် အတွေ့အကြုံရှိပြီး ဥရောပ အိုင်တီကော်ပိုရေးရှင်းကြီးတစ်ခုတွင် လက်ရှိအချိန်ပြည့် အလုပ်ခန့်ထားသည်။ ဘလော့ဂ်မရေးဖြစ်သောအခါတွင် သူသည် ၎င်း၏အားလပ်ချိန်များကို စိတ်ဝင်စားမှု၊ ဝါသနာနှင့် လှုပ်ရှားမှုများစွာတွင် ဖြုန်းတီးခဲ့ပြီး၊ ဤဝဘ်ဆိုက်တွင် ဖော်ပြထားသော အကြောင်းအရာမျိုးစုံကို အတိုင်းအတာတစ်ခုအထိ ထင်ဟပ်စေနိုင်သည်။