Partager via


Chiffrement de données (HTML)

[ Cet article est destiné aux développeurs de Windows 8.x et Windows Phone 8.x qui créent des applications Windows Runtime. Si vous développez une application pour Windows 10, voir la Documentation ]

L’exemple suivant montre comment utiliser la méthode encrypt pour chiffrer les données.


function encryptDataBuffer(keyMaterial, stringToEncrypt, algNameString, keysize, ivBuffer) {

    // Input arguments:
    //    keyMaterial.......Buffer that contains random key material (see the GenerateRandom method)
    //    stringToEncrypt...String that contains information to be encrypted
    //    algNameString.....String that contains the name of the symmetric algrorithm to use
    //    keysize...........Requested key size
    //    ivBuffer..........Buffer that contains the initialization buffer (this can be random data or custom defined)

    var encryptedBuffer;

    try {
            
        // Convert the input string to binary.
        var inputDataBuffer = Windows.Security.Cryptography.CryptographicBuffer.convertStringToBinary(stringToEncrypt, Windows.Security.Cryptography.BinaryStringEncoding.utf8);
            
        // Open the algorithm provider for the algorithm specified on input.
        var algorithmProvider = Windows.Security.Cryptography.Core.SymmetricKeyAlgorithmProvider.openAlgorithm(algNameString);

        // Check that the requested key size specified on input does not exceed the maximum size supported by the algorithm.
        if (keysize > algorithmProvider.supportedKeyLengths.max) {
            // Handle error.
        }

        // Create a symmetric key.
        var symmetricKey = algorithmProvider.createSymmetricKey(keyMaterial);
            
        // Check the padding scheme and determine whether the data must be aligned.
        if (algorithmProvider.padding != Windows.Security.Cryptography.Core.CryptographicPadding.block) {
            // Data must be aligned by block size.
            var i = inputDataBuffer.length % algorithmProvider.blockLength;
            if (i > 0) {
               // Handle error.
            }
        }

        // Encrypt the input data.
        encryptedBuffer = Windows.Security.Cryptography.Core.CryptographicEngine.encrypt(symmetricKey, inputDataBuffer, ivBuffer);
    }
    catch (e) {
        // Handle error.
    }
        
    return encryptedBuffer;
}

Rubriques associées

Chiffrement et déchiffrement de données