Maison Problème commun Quel est l'algorithme de signature numérique actuellement couramment utilisé ?

Quel est l'algorithme de signature numérique actuellement couramment utilisé ?

Dec 10, 2019 pm 01:51 PM
数字

Il existe de nombreuses façons de mettre en œuvre les signatures numériques. À l'heure actuelle, la technologie de cryptage à clé publique est principalement utilisée pour les signatures numériques. En 1994, l'American Institute of Standards and Technology a annoncé la norme de signature numérique, rendant la technologie de cryptage à clé publique largement utilisée.

Quel est l'algorithme de signature numérique actuellement couramment utilisé ?

Le système de chiffrement à clé publique utilise un algorithme de chiffrement asymétrique. Parmi eux, DES est un algorithme de cryptage symétrique, EDI n'est pas un algorithme de cryptage, et RSA et 13SA sont tous deux des algorithmes de cryptage asymétriques. C'est le premier algorithme qui peut être utilisé à la fois pour le cryptage des données et les signatures numériques. Il est facile à comprendre et à utiliser, offre une sécurité élevée et est assez couramment utilisé.

L'algorithme de chiffrement RSA est un algorithme de chiffrement asymétrique. RSA est largement utilisé dans le cryptage à clé publique et le commerce électronique. (Apprentissage recommandé : Tutoriel vidéo Web front-end)

RSA a été développé en 1977 par Ron Rivest, Adi Shamir et Leonard · Proposé en collaboration avec Leonard Adleman.

Ils travaillaient tous les trois au MIT à l’époque. RSA est composé des premières lettres de leurs noms de famille épelées ensemble.

En 1973, le mathématicien Clifford Cocks, travaillant au siège des communications du gouvernement britannique, a proposé un algorithme identique dans un document interne, mais sa découverte a été classifiée et n'a été publiée qu'en 1997.

La difficulté de factoriser des entiers extrêmement grands détermine la fiabilité de l'algorithme RSA. Autrement dit, plus il est difficile de factoriser un très grand entier, plus l’algorithme RSA est fiable. Si quelqu’un trouvait un algorithme de factorisation rapide, la fiabilité des informations chiffrées avec RSA chuterait considérablement.

Mais la possibilité de trouver un tel algorithme est très faible. Aujourd’hui, seules les clés RSA courtes peuvent être déchiffrées par force brute. Jusqu’à présent, il n’existe aucun moyen fiable d’attaquer l’algorithme RSA dans le monde. Tant que la longueur de la clé est suffisamment longue, les informations chiffrées avec RSA ne peuvent pas être déchiffrées.

En 1983, le MIT a déposé une demande de brevet pour l'algorithme RSA aux États-Unis. Ce brevet a expiré le 21 septembre 2000. Étant donné que l’algorithme a été publié avant le dépôt de la demande de brevet, les droits du brevet ne sont pas reconnus dans la plupart des autres régions du monde.

Cryptosystème à clé publique RSA. Le soi-disant système de cryptographie à clé publique utilise différentes clés de chiffrement et clés de déchiffrement. Il s'agit d'un système de cryptographie dont « il est impossible, informatiquement, de dériver la clé de déchiffrement à partir de la clé de chiffrement connue ».

Dans le système de cryptographie à clé publique, la clé de cryptage (c'est-à-dire la clé publique) PK est une information publique, tandis que la clé de déchiffrement (c'est-à-dire la clé secrète) SK doit rester secrète. L'algorithme de chiffrement E et l'algorithme de déchiffrement D sont également publics. Bien que la clé de déchiffrement SK soit déterminée par la clé publique PK, puisque la fonction d'Euler phi(N) pour les grands nombres n ne peut pas être calculée, SK ne peut pas être calculée sur la base de PK.

C'est sur cette théorie que le célèbre algorithme RSA est apparu en 1978. Il génère généralement d'abord une paire de clés RSA, dont l'une est une clé secrète et est enregistrée par l'utilisateur, l'autre est publique ; key , peut être rendue publique et peut même être enregistrée sur un serveur Web.

Pour améliorer la confidentialité, la clé RSA doit avoir une longueur d'au moins 500 bits, et 1024 bits sont généralement recommandés. Cela rend le chiffrement coûteux en termes de calcul. Afin de réduire la quantité de calcul, lors de la transmission d'informations, une combinaison de méthodes de cryptage traditionnelles et de méthodes de cryptage à clé publique est souvent utilisée, c'est-à-dire que les informations sont cryptées avec une clé DES ou IDEA améliorée, puis une clé RSA est utilisée. pour chiffrer la clé de conversation et le résumé des informations. Une fois que l'autre partie a reçu le message, elle le déchiffre à l'aide de différentes clés et peut vérifier le résumé du message.

L'algorithme RSA est le premier algorithme pouvant être utilisé à la fois pour le cryptage et les signatures numériques. Il est également facile à comprendre et à utiliser. RSA est l'algorithme à clé publique le plus étudié. Depuis sa proposition il y a plus de trente ans, il a subi diverses attaques et a été progressivement accepté par les gens. Depuis 2017, il est généralement considéré comme l'une des meilleures clés publiques. schémas un.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

iOS 17 : Comment changer le style d'horloge de l'iPhone en mode veille iOS 17 : Comment changer le style d'horloge de l'iPhone en mode veille Sep 10, 2023 pm 09:21 PM

La veille est un mode d'écran de verrouillage qui s'active lorsque l'iPhone est branché sur le chargeur et orienté en orientation horizontale (ou paysage). Il se compose de trois écrans différents, dont l'un affiche l'heure en plein écran. Lisez la suite pour savoir comment changer le style de votre horloge. Le troisième écran de StandBy affiche les heures et les dates dans différents thèmes que vous pouvez faire glisser verticalement. Certains thèmes affichent également des informations supplémentaires, comme la température ou la prochaine alarme. Si vous maintenez une horloge enfoncée, vous pouvez basculer entre différents thèmes, notamment numérique, analogique, mondial, solaire et flottant. Float affiche l'heure dans de grands nombres de bulles dans des couleurs personnalisables, Solar a une police plus standard avec un motif d'éruption solaire dans différentes couleurs et World affiche le monde en mettant en surbrillance

Programme C++ pour arrondir un nombre à n décimales Programme C++ pour arrondir un nombre à n décimales Sep 12, 2023 pm 05:13 PM

Représenter des nombres en sortie est une tâche intéressante et importante lors de l’écriture d’un programme dans n’importe quel langage. Pour les types entiers (données de type court, long ou moyen), il est facile de représenter des nombres en sortie. Pour les nombres à virgule flottante (de type flottant ou double), nous devons parfois les arrondir à un nombre spécifique de décimales. Par exemple, si nous voulons représenter 52,24568 sous forme de trois décimales, un prétraitement est nécessaire. Dans cet article, nous présenterons plusieurs techniques pour représenter les nombres à virgule flottante avec un nombre spécifique de décimales par arrondi. Parmi les différentes approches, il est important d'utiliser une chaîne de format de type C, d'utiliser l'argument de précision et d'utiliser la fonction round() de la bibliothèque mathématique. Regardons-les un par un. avec

Générer des nombres et des chaînes aléatoires en JavaScript Générer des nombres et des chaînes aléatoires en JavaScript Sep 02, 2023 am 08:57 AM

La possibilité de générer des nombres aléatoires ou des chaînes alphanumériques s'avère utile dans de nombreuses situations. Vous pouvez l'utiliser pour faire apparaître des ennemis ou de la nourriture à différents endroits du jeu. Vous pouvez également l'utiliser pour suggérer des mots de passe aléatoires aux utilisateurs ou créer des noms de fichiers pour enregistrer des fichiers. J'ai écrit un tutoriel sur la façon de générer des chaînes alphanumériques aléatoires en PHP. J'ai dit au début de cet article que peu d'événements sont véritablement aléatoires, et il en va de même pour la génération de nombres aléatoires ou de chaînes. Dans ce tutoriel, je vais vous montrer comment générer une chaîne alphanumérique pseudo-aléatoire en JavaScript. Générer des nombres aléatoires en JavaScript Commençons par générer des nombres aléatoires. La première méthode qui me vient à l’esprit est Math.random(), qui renvoie un float

Utilisez C++ pour écrire du code afin de trouver le Nième nombre non carré Utilisez C++ pour écrire du code afin de trouver le Nième nombre non carré Aug 30, 2023 pm 10:41 PM

Nous connaissons tous des nombres qui ne sont le carré d’aucun nombre, comme 2, 3, 5, 7, 8, etc. Il existe N nombres non carrés et il est impossible de connaître tous les nombres. Ainsi, dans cet article, nous expliquerons tout sur les nombres sans carrés ou non carrés et les moyens de trouver le Nième nombre non carré en C++. Nième nombre non carré Si un nombre est le carré d'un entier, alors ce nombre est appelé un carré parfait. Quelques exemples de nombres carrés parfaits sont -1iscarréde14iscarréde29iscarréde316iscarréde425iscarréde5 Si un nombre n'est le carré d'aucun entier, alors le nombre est appelé non carré. Par exemple, les 15 premiers nombres non carrés sont -2,3,5,6,

Vérifiez s'il s'agit d'un nombre en utilisant la fonction is_numeric() en PHP Vérifiez s'il s'agit d'un nombre en utilisant la fonction is_numeric() en PHP Jun 27, 2023 pm 05:00 PM

Dans le langage de programmation PHP, la fonction is_numeric() est une fonction très couramment utilisée, utilisée pour déterminer si une variable ou une valeur est un nombre. En programmation réelle, il est souvent nécessaire de vérifier la valeur saisie par l'utilisateur pour déterminer s'il s'agit d'un type numérique. Dans ce cas, la fonction is_numeric() peut être utilisée pour déterminer. 1. Introduction à la fonction is_numeric() La fonction is_numeric() est une fonction utilisée pour détecter si une variable ou une valeur est un nombre. Renvoie tru si la variable ou la valeur est un nombre

Rechercher des nombres qui ne sont divisibles par aucun nombre dans une plage, à l'aide de C++ Rechercher des nombres qui ne sont divisibles par aucun nombre dans une plage, à l'aide de C++ Sep 13, 2023 pm 09:21 PM

Dans cet article, nous aborderons le problème de la recherche de nombres compris entre 1 et n (donnés) qui ne sont divisibles par aucun nombre compris entre 2 et 10. Comprenons cela avec quelques exemples - Entrée : num = 14 Sortie : 3 Explication : Il y a trois nombres, 1, 11 et 13, qui ne sont pas divisibles. Entrée : num = 21 Sortie : 5 Explication : Il y a cinq nombres 1, 11, 13, 17 et 19, qui ne sont pas divisibles. Méthode simple résolue si.

Nombres en Java (avec préfixe 0 et chaînes) Nombres en Java (avec préfixe 0 et chaînes) Aug 29, 2023 pm 01:45 PM

Nombres en Java Il est important de comprendre que la classe nombre n'est pas une classe tangible mais une classe abstraite. À l’intérieur, nous avons un ensemble de classes wrapper qui définissent ses fonctionnalités. Ces classes wrapper incluent Integer, Byte, Double, Short, Float et Long. Vous remarquerez peut-être qu'il s'agit des mêmes types de données de base dont nous avons parlé plus tôt, mais ils sont représentés comme des classes distinctes avec des noms en majuscules pour se conformer à la convention de dénomination des classes. Le compilateur convertit automatiquement les types de données primitifs en objets et vice versa selon les besoins d'une fonction ou d'une portée de programme particulière, et les classes numériques font partie du package java.lang. Ce processus est appelé autoboxing et unboxing. En saisissant la nature abstraite des classes numériques et de leurs classes wrapper correspondantes, nous pouvons

Représenter un nombre comme la somme du plus grand nombre possible de nombres premiers en C++ Représenter un nombre comme la somme du plus grand nombre possible de nombres premiers en C++ Aug 31, 2023 pm 04:29 PM

Discutez d'un problème, par exemple, étant donné un nombre N, nous devons diviser le nombre en nombres premiers maximum, nous pouvons soustraire un nombre premier de N, puis vérifier la différence entre les nombres premiers. Si la différence est un nombre premier, alors on peut exprimer N comme la somme de deux nombres premiers. Mais ici, nous devons