लारवेल - एन्क्रिप्शन

एन्क्रिप्शन एक सादा पाठ को कुछ एल्गोरिदम का उपयोग करके संदेश में परिवर्तित करने की एक प्रक्रिया है, जिससे कोई तीसरा उपयोगकर्ता जानकारी नहीं पढ़ सकता है। यह संवेदनशील जानकारी को प्रसारित करने के लिए सहायक है क्योंकि हस्तांतरित जानकारी को लक्षित करने के लिए एक घुसपैठिए के लिए कम संभावनाएं हैं।

एन्क्रिप्शन नामक एक प्रक्रिया का उपयोग करके किया जाता है Cryptography। जिस पाठ को एन्क्रिप्ट किया जाना है, उसे ही कहा जाता हैPlain Text और एन्क्रिप्शन के बाद पाठ या संदेश प्राप्त होता है Cipher Text। सिफर टेक्स्ट को प्लेन टेक्स्ट में बदलने की प्रक्रिया को कहा जाता हैDecryption

लारवेल का उपयोग करता है AES-256 तथा AES-128एन्क्रिप्शन, जो एन्क्रिप्शन के लिए ओपन एसएसएल का उपयोग करता है। लारवेल में शामिल सभी मूल्यों पर प्रोटोकॉल का उपयोग करके हस्ताक्षर किए गए हैंMessage Authentication Code एक बार एन्क्रिप्ट किए जाने के बाद अंतर्निहित मूल्य से छेड़छाड़ नहीं की जा सकती है।

विन्यास

कमांड जनरेट करता था key लारवेल में नीचे दिखाया गया है -

php artisan key:generate

कृपया ध्यान दें कि यह कमांड PHP सिक्योर रैंडम बाइट्स जनरेटर का उपयोग करता है और आप नीचे दिए गए स्क्रीनशॉट में दिखाए अनुसार आउटपुट देख सकते हैं -

ऊपर दी गई कमांड उस कुंजी को उत्पन्न करने में मदद करती है जिसका उपयोग वेब एप्लिकेशन में किया जा सकता है। नीचे दिखाए गए स्क्रीनशॉट को ध्यान से देखें -

ध्यान दें

एन्क्रिप्शन के लिए मान ठीक से संरेखित हैं config/app.php फ़ाइल, जिसमें एन्क्रिप्शन के लिए दो पैरामीटर शामिल हैं key तथा cipher। यदि इस कुंजी का उपयोग करने वाला मान ठीक से संरेखित नहीं किया गया है, तो लारवेल में एन्क्रिप्ट किए गए सभी मान असुरक्षित होंगे।

एन्क्रिप्शन प्रक्रिया

का उपयोग करके किसी मान का एन्क्रिप्शन किया जा सकता है encrypt helperलारवेल वर्ग के नियंत्रकों में। इन मूल्यों को OpenSSL और AES-256 सिफर का उपयोग करके एन्क्रिप्ट किया गया है। एन्क्रिप्टेड स्ट्रिंग के किसी भी संशोधन के लिए जाँच करने के लिए संदेश प्रमाणीकरण कोड (मैक) के साथ सभी एन्क्रिप्टेड मूल्यों पर हस्ताक्षर किए जाते हैं।

नीचे दिखाया गया कोड एक नियंत्रक में उल्लिखित है और इसका उपयोग गुप्त या संवेदनशील संदेश को संग्रहीत करने के लिए किया जाता है।

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Controllers\Controller;

class DemoController extends Controller{
   **
      * Store a secret message for the user.
      *
      * @param Request $request
      * @param int $id
      * @return Response
   */
   
   public function storeSecret(Request $request, $id) {
      $user = User::findOrFail($id);
      $user->fill([
         'secret' => encrypt($request->secret)
      ])->save();
   }
}

डिक्रिप्शन प्रक्रिया

मूल्यों का डिक्रिप्शन के साथ किया जाता है decrypt helper। कोड की निम्नलिखित पंक्तियों को ध्यान से देखें -

use Illuminate\Contracts\Encryption\DecryptException;

// Exception for decryption thrown in facade
try {
   $decrypted = decrypt($encryptedValue);
} catch (DecryptException $e) {
   //
}

कृपया ध्यान दें कि यदि अमान्य मैक का उपयोग करने के कारण डिक्रिप्शन की प्रक्रिया सफल नहीं होती है, तो एक उपयुक्त अपवाद फेंक दिया जाता है।