Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

MySQL में संवेदनशील डेटा स्टोर करने का सबसे अच्छा तरीका क्या है?

गंभीरता से, MySQL के aes_encrypt() का उपयोग न करें यह ब्लॉक सिफर का उपयोग करने का सबसे असुरक्षित तरीका है। यह ईसीबी मोड का उपयोग कर रहा है, और मैं एक सरल उदाहरण प्रदर्शन दे सकता हूं कि यह एक गंभीर गलती क्यों है।

सादा पाठ संदेश:

वही संदेश ईसीबी मोड के साथ एन्क्रिप्ट किया गया है (इससे कोई फर्क नहीं पड़ता कि आप किस सिफर का उपयोग करते हैं):

सीबीसी मोड का उपयोग कर एक ही संदेश (फिर से, इससे कोई फर्क नहीं पड़ता कि आप किस सिफर का उपयोग करते हैं):

और भी कारण हैं mysql के aes_encrypt का उपयोग नहीं करने के लिए, विशेष रूप से आपके द्वारा भेजी जाने वाली प्रत्येक क्वेरी में आपके द्वारा उपयोग की जाने वाली aes कुंजी भी होगी। यदि डेटाबेस से छेड़छाड़ की जाती है तो हमलावर लॉगिंग सक्षम करेगा और बस आपकी एईएस कुंजी प्राप्त करेगा और संपूर्ण डेटाबेस को डिक्रिप्ट करेगा। ।

तो क्या चाहिए आप उपयोग करते हैं? मुझे पसंद है यह वर्ग उतने समय के लिए। यह String2Key फ़ंक्शन और IV के साथ CBC मोड का उपयोग कर रहा है। आप अपने IV के रूप में प्राथमिक कुंजी का उपयोग कर सकते हैं, प्रत्येक संदेश में एक अद्वितीय IV होना चाहिए। ठीक है अगर हमलावर IV जानता है, और यदि वे अनुक्रमिक हैं, जब तक कि ब्लॉक सिफर कार्यान्वयन सुरक्षित है। IV के पुन:उपयोग से WEP बहुत कम सुरक्षित हो गया है। ।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. MySQL, NULL या खाली स्ट्रिंग डालने के लिए बेहतर है?

  2. COLLATION 'utf8_general_ci' CHARACTER SET 'latin1' के लिए मान्य नहीं है

  3. SQL:प्रत्येक डिवाइस सेट के लिए समान मान की लगातार घटना के साथ सभी रिकॉर्ड गिनें और उच्चतम गणना लौटाएं

  4. एक क्वेरी में कई से कई तालिकाओं का चयन करें

  5. MySQL एकाधिक तालिकाओं में सम्मिलित करें (संबंधपरक)