การแฮช
การแฮชเป็นขั้นตอนการเข้ารหัสที่สามารถใช้ตรวจสอบความถูกต้องและความสมบูรณ์ของอินพุตประเภทต่างๆ มีการใช้กันอย่างแพร่หลายในระบบการตรวจสอบสิทธิ์เพื่อป้องกันการจัดเก็บรหัสผ่านข้อความธรรมดาในฐานข้อมูล แต่ยังสามารถใช้เพื่อตรวจสอบไฟล์ เอกสาร และข้อมูลประเภทต่างๆ การใช้ฟังก์ชันแฮชไม่เพียงพออาจนำไปสู่การละเมิดข้อมูลร้ายแรง แต่การไม่ใช้การแฮชเพื่อรักษาความปลอดภัยข้อมูลที่ละเอียดอ่อนในตอนแรกนั้นไม่ดี
ฟังก์ชันการแฮชไม่สามารถย้อนกลับได้ เอาต์พุตของฟังก์ชันแฮชคือสตริงอักขระที่มีความยาวคงที่ซึ่งเรียกว่าค่าแฮช ไดเจสต์ หรือแฮชโดยตรง สิ่งเหล่านี้ไม่ได้ถูกกำหนดไว้ล่วงหน้าว่าจะเก็บเป็นความลับโดยพื้นฐานแล้วเพราะไม่สามารถแปลงกลับเป็นค่าเดิมได้
คุณลักษณะของฟังก์ชันการแฮชคือเมื่อทำการแฮช อินพุตที่ไม่ซ้ำกันควรให้ผลลัพธ์เป็นค่าแฮชที่คล้ายกันเสมอ หากอินพุตที่แตกต่างกัน 2 ค่าสามารถมีค่าแฮชที่คล้ายคลึงกัน ฟังก์ชันนี้เรียกว่าการชนกัน และฟังก์ชันแฮชจะถูกทำลายจากมุมมองด้านความปลอดภัย ขึ้นอยู่กับความง่ายในการคำนวณในการค้นพบการชนกันดังกล่าว
การเข้ารหัส
การเข้ารหัสเป็นขั้นตอนของการเข้ารหัสข้อความธรรมดาและข้อมูลอื่นๆ ที่สามารถเข้าถึงได้โดยหน่วยงานที่ได้รับอนุญาตแต่เพียงผู้เดียวหากมีคีย์ถอดรหัส มันจะปกป้องข้อมูลที่ละเอียดอ่อนจากการเข้าถึงโดยอาชญากรไซเบอร์
เป็นวิธีที่มีประสิทธิภาพมากที่สุดในการบรรลุความปลอดภัยของข้อมูลในระบบสื่อสารสมัยใหม่ เพื่อให้ผู้รับอ่านข้อความที่เข้ารหัส ควรมีรหัสผ่านหรือคีย์ความปลอดภัยที่ใช้ในการถอดรหัส ข้อมูลที่ไม่ได้รับการเข้ารหัสจะเรียกว่าข้อความธรรมดาในขณะที่การเข้ารหัสข้อมูลเรียกว่าข้อความเข้ารหัส
แนวคิดหลักของการเข้ารหัสคือการรักษาความปลอดภัยข้อมูลจากบุคคลที่ไม่ได้รับอนุญาตซึ่งจำเป็นต้องอ่านหรือรับข้อมูลจากข้อความที่ไม่ได้ถูกกำหนดไว้สำหรับพวกเขา การเข้ารหัสช่วยเพิ่มความปลอดภัยเมื่อส่งข้อความผ่านเว็บหรือผ่านเครือข่ายที่กำหนด
ให้เราดูการเปรียบเทียบระหว่างการแฮชและการเข้ารหัส
การแฮช | การเข้ารหัส |
---|---|
การแฮชเป็นฟังก์ชันทางเดียวที่สร้างไดเจสต์ข้อความ aunique จากไฟล์อินพุตหรือสตริงข้อความ ไม่ใช้กุญแจ | การเข้ารหัสเป็นฟังก์ชันสองทางที่ข้อมูลถูกเข้ารหัสโดยใช้คีย์เข้ารหัสและถอดรหัสในภายหลังโดยใช้คีย์ถอดรหัส |
การแฮชใช้เพื่อตรวจสอบความสมบูรณ์ของเนื้อหาโดยระบุการแก้ไขทั้งหมด จากนั้นจึงเปลี่ยนแปลงเอาต์พุตแฮช | การเข้ารหัสจะเข้ารหัสข้อมูลสำหรับเป้าหมายพื้นฐานของการรักษาความลับและความปลอดภัยของข้อมูล จำเป็นต้องใช้คีย์ aprivate เพื่อเปลี่ยนข้อความเข้ารหัสกลับเป็นข้อความธรรมดาได้ |
ไม่จำเป็นต้องใช้คีย์ในการแฮช | การเข้ารหัสเสร็จสิ้นด้วยการรองรับคีย์ ในกรณีของการเข้ารหัสแบบสมมาตร จะใช้เฉพาะกุญแจสาธารณะเท่านั้น ในการเข้ารหัสแบบอสมมาตร ใช้ทั้งคีย์สาธารณะและส่วนตัว |
วัตถุประสงค์ของการใช้การแฮชคือการตรวจสอบข้อมูล (เช่น ปกป้องความสมบูรณ์ของข้อมูล) | จุดประสงค์ของการเข้ารหัสคือการส่งข้อมูลอย่างปลอดภัย (เช่น ปกป้องข้อมูลที่เป็นความลับ) |