FR2747815A1 - Systeme de controle d'acces a une fonction, dans lequel le chiffrement implique plusieurs variables dynamiques - Google Patents
Systeme de controle d'acces a une fonction, dans lequel le chiffrement implique plusieurs variables dynamiques Download PDFInfo
- Publication number
- FR2747815A1 FR2747815A1 FR9604798A FR9604798A FR2747815A1 FR 2747815 A1 FR2747815 A1 FR 2747815A1 FR 9604798 A FR9604798 A FR 9604798A FR 9604798 A FR9604798 A FR 9604798A FR 2747815 A1 FR2747815 A1 FR 2747815A1
- Authority
- FR
- France
- Prior art keywords
- unit
- variables
- control system
- calculation means
- encryption
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Classifications
-
- G—PHYSICS
- G07—CHECKING-DEVICES
- G07F—COIN-FREED OR LIKE APPARATUS
- G07F7/00—Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus
- G07F7/08—Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus by coded identity card or credit card or other personal identification means
- G07F7/10—Mechanisms actuated by objects other than coins to free or to actuate vending, hiring, coin or paper currency dispensing or refunding apparatus by coded identity card or credit card or other personal identification means together with a coded signal, e.g. in the form of personal identification information, like personal identification number [PIN] or biometric data
- G07F7/1008—Active credit-cards provided with means to personalise their use, e.g. with PIN-introduction/comparison system
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/30—Payment architectures, schemes or protocols characterised by the use of specific devices or networks
- G06Q20/34—Payment architectures, schemes or protocols characterised by the use of specific devices or networks using cards, e.g. integrated circuit [IC] cards or magnetic cards
- G06Q20/341—Active cards, i.e. cards including their own processing means, e.g. including an IC or chip
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/38—Payment protocols; Details thereof
- G06Q20/40—Authorisation, e.g. identification of payer or payee, verification of customer or shop credentials; Review and approval of payers, e.g. check credit lines or negative lists
- G06Q20/409—Device specific authentication in transaction processing
- G06Q20/4097—Device specific authentication in transaction processing using mutual authentication between devices and transaction partners
-
- G—PHYSICS
- G07—CHECKING-DEVICES
- G07C—TIME OR ATTENDANCE REGISTERS; REGISTERING OR INDICATING THE WORKING OF MACHINES; GENERATING RANDOM NUMBERS; VOTING OR LOTTERY APPARATUS; ARRANGEMENTS, SYSTEMS OR APPARATUS FOR CHECKING NOT PROVIDED FOR ELSEWHERE
- G07C9/00—Individual registration on entry or exit
- G07C9/20—Individual registration on entry or exit involving the use of a pass
- G07C9/21—Individual registration on entry or exit involving the use of a pass having a variable access code
-
- G—PHYSICS
- G07—CHECKING-DEVICES
- G07C—TIME OR ATTENDANCE REGISTERS; REGISTERING OR INDICATING THE WORKING OF MACHINES; GENERATING RANDOM NUMBERS; VOTING OR LOTTERY APPARATUS; ARRANGEMENTS, SYSTEMS OR APPARATUS FOR CHECKING NOT PROVIDED FOR ELSEWHERE
- G07C9/00—Individual registration on entry or exit
- G07C9/20—Individual registration on entry or exit involving the use of a pass
- G07C9/215—Individual registration on entry or exit involving the use of a pass the system having a variable access-code, e.g. varied as a function of time
Landscapes
- Business, Economics & Management (AREA)
- General Physics & Mathematics (AREA)
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Accounting & Taxation (AREA)
- Theoretical Computer Science (AREA)
- Strategic Management (AREA)
- General Business, Economics & Management (AREA)
- Computer Networks & Wireless Communication (AREA)
- Microelectronics & Electronic Packaging (AREA)
- Computer Security & Cryptography (AREA)
- Finance (AREA)
- Storage Device Security (AREA)
Abstract
Le système comprend une première unité (2) sous forme d'une carte destinée à coopérer avec une seconde unité (3) pouvant donner accès à la fonction (1) sous certaines conditions seulement. Les deux unités sont équipées pour exécuter des logiciels permettant d'engendrer des mots de passe par chiffrement de plusieurs variables dynamiques engendrées de concert mais indépendamment dans les unités. Les mots de passe ainsi engendrés doivent présenter une relation prédéterminée, telle que l'identité, pour que l'accès soit libéré. Le chiffrement est réalisé dans les deux unités (2, 3) par des algorithmes de chiffrement publiques utilisant une clé dynamique qui est modifiée à chaque demande d'accès formulée à l'aide de la carte, en fonction du nombre de demandes d'accès déjà formulées auparavant.
Description
La présente invention est relative à un système électronique de contrôle d'accès à une fonction ou d'authentification d'une personne ou d'un message, permettant notamment à un utilisateur d'obtenir conditionnellement un service ou une autre prestation devant être fourni par une unité de service spécialisé associée au système en question.
Plus particulièrement, l'invention concerne un système de contrôle d'accès à un ordinateur ou plus généralement à un réseau informatique dont l'utilisation est réservée à des personnes s'étant dûment légitimées. De tels réseaux peuvent servir par exemple pour assurer toutes sortes de services impliquant une transaction, le plus souvent à contrepartie économique, telle que le télé-achat, la télévision à péage, la banque à domicile, les jeux télévisés interactifs, ou également le fac-similé confidentiel etc.
Un exemple d'un tel système de la technique antérieure est décrit dans le brevet US NO 3 806 874. Ce brevet décrit un système d'identification ou d'authentification de personnes dans lequel un mot de passe est engendré par le chiffrement de données temporelles décimales codées binaires et de deux nombres fixes. Dans ce système, une unité d'identification (ou carte) engendre des premières et secondes séquences de données (mots de passe) en fonction d'un numéro d'identification personnel, de données secrètes et de données temporelles binaires provenant d'une première horloge. Le numéro personnel est transmis à une unité de vérification (ou serveur). L'unité de vérification engendre des premières et secondes séquences de données en chiffrant le numéro d'identification personnelle, les données secrètes et des données temporelles décimales codées binaires provenant d'une seconde horloge. Les données temporelles sont fournies indépendamment par les horloges se trouvant respectivement dans l'unité d'identification et dans l'unité de vérification.
Plus particulièrement, l'unité d'identification 10 comprend une mémoire primaire ROM 12 dans laquelle est stocké un numéro d'identification personnelle, et un circuit secret 20 qui mémorise des données secrètes dans une mémoire secrète 26 qui permet d'engendrer les premières et secondes séquences de données. Les données secrètes sont différentes pour chaque utilisateur et ne lui sont pas connues. Le circuit secret 20 comporte un circuit de chiffrement fournissant les premières et secondes séquences en chiffrant des données d'entrée composées du numéro d'identification personnelle, des données secrètes et des données temporelles décimales codées binaires engendrées par l'horloge 42.
Dans le serveur, un circuit secret 31 correspondant au circuit secret 20 de la carte comporte une mémoire secrète 33 et reçoit une entrée temporelle d'une horloge 53. Le circuit secret 31 reçoit également une entrée (le numéro d'identification personnelle) de la mémoire primaire 12 de l'unité d'identification 10. Le circuit secret 31 comporte un circuit de chiffrement produisant des première et seconde séquences de données (mots de passe) en chiffrant les données d'entrée composées du numéro d'identification personnelle, des données secrètes et des données temporelles décimales codées binaires provenant de l'horloge 53.
Les premières séquences de données sont comparées dans un comparateur 30 de la carte. Si elles sont en concordance, un signal d'acceptation est engendré. Le comparateur compare (1) la première séquence de données obtenue du serveur pendant le même intervalle de temps pendant lequel la première séquence de données a été engendrée dans l'unité de vérification avec (2) la première séquence de données engendrée pendant le même intervalle de temps dans la carte.
En d'autres termes, le comparateur 30 doit recevoir du serveur la première séquence de données pendant le même intervalle de temps pendant lequel elle a été engendrée pour que cette séquence de données reçue soit en concordance avec la première séquence de données engendrée dans l'unité de vérification pendant ce même intervalle de temps. Le même raisonnement s'applique aux secondes séquences de données comparées dans le comparateur 41.
Les circuits secrets 20 et 31 du brevet US nO 3 806 874 engendrent des mots de passe (nombres de vérification) par le chiffrement du numéro d'identification personnelle, des données secrètes et des données temporelles décimales codées binaires afin de produire les premières et secondes séquences de données. Pour que les séquences de données concordent, il faut que les données temporelles utilisées dans l'unité d'identification et dans l'unité de vérification soient identiques. Par conséquent, les horloges 42 et 53 doivent être synchrones pour qu'elles puissent engendrer à peu près en même temps les mêmes données temporelles.
Le brevet US 4 601 011 décrit un système d'authentification qui engendre un mot de passe en chiffrant un nombre fixe avec une clé formées de deux parties dont la première ne change pas et dont la seconde change chaque fois que la clé est utilisée pour le chiffrement.
Ce système comporte au moins une unité portable électronique (carte) et au moins une unité de vérification électronique (serveur) qui doit conditionnellement délivrer des autorisations d'accès à un ordinateur. Le système engendre des mots de passe qui dans une première variante sont fonction du temps et dans une seconde variante fonction du nombre de mots de passe engendrés dans l'unité portable.
Celle-ci comporte un module de chiffrement qui chiffre un mot de passe différent pour chaque transmission en utilisant une clé en deux parties. Le serveur reçoit le mot de passe de la carte et engendre un mot de passe interne par chiffrement d'un nombre fixe (correspondant au nombre fixe chiffré dans la carte) avec la première partie de la clé (stockée en mémoire) et la seconde partie de la clé (reçue de la carte). Un comparateur 50 compare le mot de passe reçu au mot de passe interne et, en fonction du résultat de la comparaison, délivre une sortie qui accorde ou refuse l'accès à l'ordinateur 56.
Les systèmes des brevets US 4 601 011 et 3 806 874 produisent tous deux des mots de passe identiques ("séquences de donnés" ou nombres de vérification chiffrés") dans la carte et dans le serveur, les deux unités calculant de façon indépendante les mots de passe en exécutant un programme de chiffrement sur des données comprenant au moins un code personnel fixe et au moins un nombre fonction du temps ou variant en fonction du nombre de fois qu'un mot de passe est engendré dans la carte.
Le brevet US 4 720 860 décrit un autre système d'authentification dans lequel, pour engendrer les mots de passe, on utilise une variable statique et une variable dynamique. Dans ce brevet, au début d'une procédure de demande d'accès, l'utilisateur doit entrer dans la carte un code fixe chaque fois qu'une transaction doit être réalisée.
Le code fixe est une variable statique. Une seconde variable est engendrée de manière à varier de façon dynamique en fonction du temps, en particulier en fonction de l'instant auquel le code fixe est introduit dans la carte par l'utilisateur. Les deux variables dont l'une est donc statique et l'autre dynamique, sont alors utilisées comme paramètres d'entrée d'un algorithme secret de chiffrement servant à engendrer un mot de passe dans la carte.
Ce mot de passe est affiché sur la carte et l'utilisateur est invité à le transférer dans le serveur. Le code fixe est également transféré au serveur qui, en utilisant le même algorithme de chiffrement et une variable dynamique ayant en principe la même valeur que celle utilisée dans la carte, calcule également le mot de passe.
Ce dernier est comparé au mot de passe transmis au serveur par l'utilisateur et s'il y a concordance, une autorisation d'accès à la fonction peut être délivrée. Ce système de contrôle d'accès emploie donc une variable statique à l'aide de laquelle l'algorithme de chiffrement calcule le mot de passe tout en utilisant également la variable dynamique.
Dans ce système, la variable statique est stockée dans une mémoire de la carte et transmise au serveur, par exemple par l'intermédiaire d'une ligne téléphonique. Ainsi, elle est susceptible d'être décelée par des pirates utilisant des procédés électroniques frauduleux.
Dans ce système, l'algorithme doit donc nécessairement être maintenu secret afin de préserver la sécurité du système. Si la sécurité de l'algorithme est percée, la sécurité de l'ensemble du système est compromise, car les variables statiques peuvent éventuellement être découvertes par des procédés électroniques frauduleux. C'est ce qui explique que, dans ce brevet, on prévoit des moyens pour détruire l'algorithme en cas de tentative de fraude sur la carte (par exemple en mémorisant l'algorithme dans une mémoire volatile).
On doit également noter que dans les deux brevet US n" 3 806 874 et 4 720 860, la seconde variable est une valeur dynamique fonction du temps. Comme cette variable doit nécessairement être produite indépendamment à la fois dans la carte et dans le serveur, les horloges des deux unités utilisées pour engendrer la variable dynamique de chaque côté doivent être synchronisées avec une précision donnée.
Pour ne pas avoir à fournir des horloges trop précises (ce qui augmenterait considérablement le coût du système), il est nécessaire d'admettre une plage de tolérance à l'intérieur de laquelle le mot de passe actuel reste valable. Plus la plage de tolérance est courte et plus la sécurité est assurée, mais également plus un défaut de synchronisation des horloges est gênant.
Compte tenu de cette plage de tolérance, le mot de passe calculé à chaque demande d'accès est encore valable pendant la durée de chaque intervalle séparant deux opérations de calcul de la variable dynamique. Un tel intervalle peut avoir une durée relativement longue (typiquement 10 minutes voire davantage, par exemple) de sorte qu'un fraudeur s'emparant subrepticement du mot de passe d'une carte au moment d'une demande d'accès, aura le temps de l'utiliser pendant tout l'intervalle précité sur le serveur et pourra ainsi facilement obtenir une autorisation d'accès.
Dans le brevet US nO 4 800 590, on décrit également un système d'authentification utilisant une clé de chiffrement dynamique fonction du temps. Plus particulièrement, ce système utilise comme paramètre d'entrée d'un algorithme de chiffrement, une clé de chiffrement utilisée comme variable dynamique que l'on fait varier en fonction du temps. Ce procédé nécessite une mise à jour périodique de la clé de chiffrement, par exemple à une fréquence donnée d'une minute. Si cette mise à jour peut facilement être mise en oeuvre dans la carte, il n'en va pas de même en ce qui concerne le serveur. En effet, le système peut avoir un très grand nombre d'utilisateurs ayant chacun une carte à laquelle est affectée une variable dynamique évidemment unique pour cette carte. Par conséquent, dans ce système connu du brevet US 4 800 590, le serveur doit périodiquement recalculer par des calculs itératifs, soit toutes les clés de chiffrement à la fois, soit mettre à jour la clé de chiffrement de la carte considérée pendant que celle-ci demande un accès. On comprend que si le système comporte un grand nombre de cartes (typiquement 100 000, par exemple), la mise à jour des clés de chiffrement devient rapidement une charge de calcul trop importante pour le serveur. Ce brevet décrit également la possibilité de mettre à jour la clé en réponse à une action de l'utilisateur sur une touche; ce mode de réalisation est désavantageux car il limite la fréquence de modification de la clé.
Le brevet US 5 060 263 décrit également un système engendrant un mot de passe dynamique. Dans ce système, un générateur de mots de passe produit chaque mot de passe par le chiffrement du mot de passe engendré auparavant utilisé comme variable. Un grand nombre de clés de chiffrement fixes est stocké dans la carte. Pour augmenter la sécurité, le serveur engendre un nombre aléatoire pour désigner l'une des clés qui sera utilisée pour générer le mot de passe. La carte doit répéter les séquences de chiffrement (au moyen d'un algorithme public du type DES) autant de fois qu'il y a de clés dans la carte, en rebouclant la sortie sur l'entrée.
Dans ce système connu, les clés ont donc des valeurs fixes malgré qu'elles soient choisies aléatoirement.
Cependant, elles peuvent être décelées frauduleusement dans la mémoire de la carte. De plus, le nombre aléatoire engendré dans le serveur doit être transmis vers la carte et il peut donc être intercepté frauduleusement pendant la transmission. Un autre problème de ce système se pose si l'utilisateur de la carte n'achève pas une demande d'accès dans le serveur. Dans ce cas, il peut y avoir de sérieux problèmes de désynchronisation, car chaque mot de passe est engendré sur la base du mot de passe précédent, de sorte que le décalage devient de plus en plus important avec le temps.
On doit alors prévoir un mécanisme permettant de rétablir la synchronisation.
L'invention a pour but de fournir un système de contrôle d'accès ou d'authentification de personnes et/ou de messages offrant une meilleure sécurité contre les fraudes.
Elle a donc pour objet un système de contrôle d'accès ou d'authentification de personnes et/ou de messages par lequel notamment, au moins un utilisateur peut être autorisé à accéder à une fonction, ce système comprenant au moins une première unité portable personnalisée pour ledit utilisateur et au moins une seconde unité de vérification commandant l'accès à la fonction ou l'authentification de l'utilisateur et/ou d'un message,
ladite première unité comprenant:
des premiers moyens générateurs pour engendrer au moins deux variables;
des premiers moyens de calcul pour engendrer un premier mot de passe à l'aide d'au moins un premier algorithme de chiffrement utilisant des paramètres d'entrée fonction des variables; et
des moyens pour transmettre ledit premier mot de passe à la seconde unité;
ladite seconde unité comprenant:
des seconds moyens générateurs pour, en réponse à une demande d'accès faite à l'aide d'une déterminée desdites premières unités, engendrer au moins deux variables assignées à cette même première unité déterminée;
des seconds moyens de calcul pour engendrer un second mot de passe à l'aide d'au moins un second algorithme de chiffrement utilisant des paramètres d'entrée fonction des variables générées dans la seconde unité;
des moyens pour comparer les premier et second mots de passe;
des moyens pour, s'il y a une cohérence prédéterminée entre les mots de passe, délivrer une autorisation d'accès à ladite fonction et/ou une authentification,
caractérisé en ce que
lesdits premiers et seconds moyens générateurs prévus respectivement dans lesdites première et seconde unités sont configurés de manière à fournir au moins deux variables dynamiques engendrées de concert, mais de façon indépendante dans lesdites première et seconde unités.
ladite première unité comprenant:
des premiers moyens générateurs pour engendrer au moins deux variables;
des premiers moyens de calcul pour engendrer un premier mot de passe à l'aide d'au moins un premier algorithme de chiffrement utilisant des paramètres d'entrée fonction des variables; et
des moyens pour transmettre ledit premier mot de passe à la seconde unité;
ladite seconde unité comprenant:
des seconds moyens générateurs pour, en réponse à une demande d'accès faite à l'aide d'une déterminée desdites premières unités, engendrer au moins deux variables assignées à cette même première unité déterminée;
des seconds moyens de calcul pour engendrer un second mot de passe à l'aide d'au moins un second algorithme de chiffrement utilisant des paramètres d'entrée fonction des variables générées dans la seconde unité;
des moyens pour comparer les premier et second mots de passe;
des moyens pour, s'il y a une cohérence prédéterminée entre les mots de passe, délivrer une autorisation d'accès à ladite fonction et/ou une authentification,
caractérisé en ce que
lesdits premiers et seconds moyens générateurs prévus respectivement dans lesdites première et seconde unités sont configurés de manière à fournir au moins deux variables dynamiques engendrées de concert, mais de façon indépendante dans lesdites première et seconde unités.
Les variables dynamiques doivent être cohérentes dans lesdites première et seconde unités; elles doivent donc présenter une relation prédéterminée, comme par exemple l'identité.
I1 résulte tout d'abord de ces caractéristiques que les premières unités du système ne contiennent dans leur mémoire pour le calcul du mot de passe aucune variable statique susceptible d'être décelée frauduleusement, par exemple par espionnage. Un autre avantage consiste en ce que l'algorithme de chiffrement n'a pas nécessairement à être secret et s'il en est ainsi, l'on peut se dispenser de moyens de destruction de cet algorithme en cas de fraude.
Il est vrai que si l'on utilise un algorithme publique, au moins l'une des variables dynamiques doit être secrète, mais en cas de découverte frauduleuse d'une telle variable (qui est propre à la carte), seule la carte concernée perd sa sécurité alors que le système lui-même la conserve entièrement.
Ainsi, suivant une autre caractéristiques de l'invention, lesdits premiers et seconds moyens générateurs comportent respectivement des troisièmes et quatrièmes moyens de calculs pour engendrer au moins une première desdites variables dynamiques selon une fonction faisant intervenir le nombre de demandes d'accès formulées par ladite première unité antérieurement à la demande d'accès en cours.
Il résulte de cette caractéristique particulièrement avantageuse que, grâce à l'invention, la mise à jour d'une première des variables dynamiques, utilisée par exemple comme clé de chiffrement, n'a pas besoin d'être effectuée périodiquement et ne nécessite dans le serveur aucun recalcul ou "rattrapage" de la valeur de la variable dynamique calculée pour une demande d'accès antérieure, par rapport à la valeur actuelle de cette variable dynamique calculée se trouvant dans la carte au moment où une demande d'accès est formulée. Le travail de calcul pour le serveur est donc réduit au minimum.
Certes, il peut se produire que le nombre de demandes d'accès comptabilisées par la carte soit supérieur à celui enregistré par le serveur du fait que l'utilisateur de la carte peut ne pas toujours achever une demande d'accès.
Cependant, dans ce cas, le serveur n' aura à rattraper au pire qu'un très faible nombre d'itérations pour recalculer la variable dynamique. En outre, on pourra, par construction, limiter d'office l'écart entre les nombres de demandes d'accès comptabilisés respectivement dans les deux unités.
On observera également que, grâce à l'invention, si un individu s'empare frauduleusement d'un mot de passe qui vient d'être obtenu par un utilisateur d'une carte donnée et est transféré légitimement au serveur par celui-ci, ce mot de passe n'aboutira pas à une autorisation d'accès. En effet, une nouvelle demande d'accès, même formulée très rapidement après, engendrera un mot de passe différent de celui qui va être calculé dans le serveur, car la variable dynamique de la carte aura alors évoluée par l'augmentation du nombre de demandes d'accès.
Dans un mode de réalisation particulier, le système de contrôle d'accès peut comprendre des seconds moyens de calcul du mot de passe qui déchiffrent le mot de passe reçu selon au moins un algorithme de déchiffrement utilisant comme clé de déchiffrement un paramètre d'entrée fonction d'une première variable dynamique produite dans ladite seconde unité pour dériver une variable dynamique qui doit correspondre à l'une des variables dynamiques produites dans la première unité. Dans ce cas, cette seconde unité comprend également des moyens comparateurs qui comparent la variable dynamique dérivée par les seconds moyens de calcul, à une seconde desdites variables dynamiques engendrées dans ladite première unité, et des moyens qui, lorsque les moyens comparateurs constatent une relation prédéterminée entre la variable dynamique dérivée par les seconds moyens de calcul et la seconde desdites variables engendrée dans la seconde unité, délivrent une autorisation d'accès à ladite fonction.
D'autres caractéristiques et avantages de l'invention apparaîtront au cours de la description qui va suivre, donnée uniquement à titre d'exemple et faite en se référant aux dessins annexés sur lesquels:
- la figure 1 est un schéma général d'un système de contrôle d'accès selon l'invention;
la figure 2 est un organigramme simplifié illustrant le principe de déroulement des opérations dans le système selon l'invention, lorsqu'une demande d'accès est traitée;
la figure 3 montre un organigramme du mode de calcul d'une clé de chiffrement utilisée pour le calcul du mot de passe.
- la figure 1 est un schéma général d'un système de contrôle d'accès selon l'invention;
la figure 2 est un organigramme simplifié illustrant le principe de déroulement des opérations dans le système selon l'invention, lorsqu'une demande d'accès est traitée;
la figure 3 montre un organigramme du mode de calcul d'une clé de chiffrement utilisée pour le calcul du mot de passe.
Sur la figure 1, on a représenté un schéma très simplifié d'un système de contrôle d'accès selon l'invention.
Le système est supposé donner un accès conditionnel à une fonction qui est symbolisée par le rectangle 1 sur la figure 1. Le terme "fonction" doit être pris dans une acception très large. Il désigne toute fonction à laquelle l'accès est conditionné par une autorisation faisant intervenir une authentification impliquant une vérification de l'outil (carte) à l'aide duquel la demande est formulée, et de préférence également une identification de la personne demandant l'accès à la fonction pour savoir si sa demande est légitime.
La fonction peut être de toute nature, par exemple une fonction d'accès à un local, à une réseau informatique ou à un ordinateur, à une transaction d'ordre pécuniaire (téléachat, banque à domicile, jeu télévisé interactif, télévision à péage) etc. Par ailleurs, des fonctions d'authentification, soit de personnes, soit de messages, tombent expressément dans la portée de la présente invention, bien que dans l'ensemble de la description on fasse plutôt référence à une procédure impliquant des demandes d'accès à une fonction.
Ceci étant, on voit sur la figure 1 que selon un mode de réalisation particulier, le système suivant l'invention peut comporter au moins une première unité 2 appelée "carte" et au moins une seconde unité 3. On notera que le système de contrôle d'accès selon l'invention peut comporter un grand nombre de premières unités et une ou plusieurs secondes unités, mais en tout cas en un nombre généralement nettement plus faible. Les nombres d'unités 2 et 3 ne sont donc nullement limitatifs de l'invention.
La première unité ou carte 2 est de préférence portable et personnalisée pour être affectée personnellement à un utilisateur donné. Elle se présente par exemple sous la forme d'une calculette ou d'une carte de crédit et elle porte un numéro d'identification publique 5 indiqué schématiquement sur la figure 1. Ce numéro peut y être inscrit en clair et y être affecté au moment de son initialisation. Il peut également être formé par le nom de l'utilisateur ou par toute autre information propre à celuici. Un autre numéro, le numéro d'identification personnelle ou PIN, est secret et normalement connu seulement de l'utilisateur autorisé de la carte. Pour utiliser la carte, le numéro PIN doit y être introduit par l'utilisateur, la carte comparant le numéro PIN introduit à une valeur qui y est mémorisée. Si le numéro PIN introduit et la valeur mémorisée concordent, l'utilisateur reçoit l'autorisation d'utiliser la carte; sinon la carte ne fonctionnera pas pour générer un mot de passe. Quant au numéro d'identification publique, il identifie la carte elle-même vis-à-vis de l'unité 3 parmi toutes les cartes avec lesquelles le système est appelé à travailler.
La carte 2 comporte un clavier 6 destiné à permettre l'introduction d'informations, telles que par exemple les numéros d'identification déjà mentionnés, ainsi que diverses touches de fonction 7. Elle comporte également un écran d'affichage 8 et est dotée d'un circuit intégré 9 comportant notamment un microcontrôleur dûment programmé ainsi que les mémoires ROM et RAM habituelles.
La carte 2 comporte également un dispositif de communication 10 permettant de communiquer avec l'unité 3, soit directement, soit par une liaison de transmission à plus ou moins longue distance. Ce dispositif peut se présenter sous de nombreux aspects par exemple une liaison téléphonique en DTMF, un dispositif de transmission de données par rayons infrarouges, un dispositif dit "en mode connecté" dans lequel la carte est insérée dans un lecteur approprié ou tout autre dispositif de transmission bien connu dans la technique.
La seconde unité 3 englobe tout d'abord des moyens d'interface permettant d'assurer la communication avec la carte 2 au moyen du dispositif de communication 10. Dans le mode de réalisation représenté sur les figures 1 et 2, ces moyens d'interface sont symbolisés par un rectangle 12; ils peuvent se présenter sous de nombreuses formes. Il peut s'agir par exemple d'un lecteur dédicacé spécialement, mais il peut également se présenter sous la forme d'un terminal d'ordinateur inséré par exemple dans un réseau, ou encore un ordinateur personnel équipé d'une interface à rayons infrarouges, etc. Leur particularité est qu'ils peuvent communiquer sous une forme appropriée avec la ou les cartes qui leur est ou sont associée(s).
Les moyens d'interface 12 peuvent comprendre un clavier 13 et un écran d'affichage 14 pour permettre à un utilisateur d'introduire des informations à communiquer à une partie 15 de la seconde unité 3, telles que par exemple des mots de passe ou des données à authentifier relatives à la fonction 1. Toutefois, l'introduction de ces données peut être réalisée d'autres manières, notamment automatiquement sans intervention manuelle de l'utilisateur, par exemple par la simple introduction de la carte dans l'interface 12 ou par l'un des boutons de fonction 7 provoquant par exemple l'émission de rayons infrarouges modulés.
L'interface 12 communique avec l'autre partie 15 de l'unité 3 appelée "serveur" dans la présente description.
Cette communication symbolisée par la connexion 16 peut se faire à courte ou à longue distance par tout moyen approprié. Les informations circulant sur cette connexion sont notamment le mot de passe à contrôler dans le serveur 15 et éventuellement des données à authentifier et à exploiter dans le serveur.
Le serveur 15 comporte en particulier un processeur 17 et une mémoire 18. Le processeur est capable de libérer conditionnellement les fonctions 1, visées par les demandes d'accès formulées par les diverses cartes, ces fonctions pouvant être assurées à l'intérieur ou à l'extérieur. A noter que le serveur coopère généralement avec un grand nombre de cartes par l'intermédiaire d'interfaces telles que l'interface 12.
La figure 2 représente un organigramme simplifié des diverses opérations qui se déroulent lorsqu'une demande d'accès à une fonction est formulée par l'utilisateur d'une carte. La figure 2 est divisée en deux parties, la partie à gauche du trait en pointillés 19 représentant les opérations exécutées dans la carte 2 et la partie à droite de ce trait montrant celles qui se déroulent dans la partie 15 ou serveur de l'unité 3.
Pour initier la procédure, le numéro d'identification publique 5 doit être communiqué au serveur 15. Cette opération peut être réalisée de diverses manières. Par exemple, il peut être communiqué directement au serveur dès lors que la carte est insérée dans l'interface 12. Il peut être directement tapé sur le clavier 13 de celui-ci par l'utilisateur lui-même, ou bien sur le clavier 6 de la carte 2 et transféré par le dispositif de communication 10. La communication peut également se faire par une liaison à distance, telle qu'une ligne téléphonique ou par voie hertzienne.
L'utilisateur doit également donner sa légitimation en tapant en 20 son code d'identification personnelle ou code
PIN stocké en mémoire de la carte. En cas de nonconcordance, la demande d'accès est d'emblée refusée en 22, l'utilisateur pouvant se voir allouer éventuellement plusieurs tentatives consécutives avant qu'un refus définitif lui soit opposé, si elles restent toutes infructueuses.
PIN stocké en mémoire de la carte. En cas de nonconcordance, la demande d'accès est d'emblée refusée en 22, l'utilisateur pouvant se voir allouer éventuellement plusieurs tentatives consécutives avant qu'un refus définitif lui soit opposé, si elles restent toutes infructueuses.
Si au contraire le code PIN introduit et le code PIN mémorisé concordent, le programme déclenche en 23 l'opération de calcul du mot de passe.
Ce calcul consiste en un chiffrement à l'aide d'un algorithme de chiffrement qui peut être secret ou publique (bloc 24). Dans ce dernier cas, il peut s'agir d'un algorithme appelé DES (Data Encryption Standard) par les spécialistes de cette technique.
Selon l'invention, l'algorithme en question utilise des paramètres d'entrée fonction de variables dynamiques qui, dans la cas représenté, sont au nombre de trois. Deux d'entre elles sont une variable Nn stockée dans un registre 25 et qui représente le nombre de demandes d'accès effectuées par la carte, et une variable T qui est constituée par la position actuelle d'un compteur 26.
Lorsque chaque carte est initialisée, ces variables peuvent être fixées à des valeurs initiales, NO et/ou TO respectivement qui ne sont pas nécessairement égales à zéro et qui peuvent être secrètes ou publiques. De même, Nn et T peuvent varier selon des fonctions faisant intervenir des paramètres tels qu'entre autres le nombres de demandes d'accès, une fonction du nombre de demandes d'accès et le temps actuel.
Chacune des deux variables Nn et Tn peuvent comporter 32 bits et préalablement être soumises à une opération de concaténation en 27 offrant ainsi un paramètre d'entrée de 64 bits au total. L'opération en 27 effectuée sur les variables Nn et Tn peut également être constituée par tout autre traitement ou combinaison comme l'entrelaçage, le hachage, une opération OU-EXCLUSIF ou ET etc. En d'autre termes, l'opération en 27 n'est pas limitée à ces diverses variantes, mais elle peut consister en toute opération exécutée dans le but de produire une sortie (sur 64 bits) par combinaison ou traitement de Nn et Tn.
La troisième variable dynamique est une clé de chiffrement Kn utilisée par l'algorithme en 24 pour chiffrer le paramètre d'entrée issu de l'opération de concaténation en 27. La clé de chiffrement Kn est mémorisée dans un registre 28 et elle est mise à jour à chaque demande d'accès, comme expliqué plus loin. Selon des variantes, l'algorithme mis en oeuvre en 24 peut calculer un mot de passe en fonction des valeurs actuelles de Nn, Tn et Kn, ou
Kn peut être chiffré selon une clé comprenant une valeur produite par la
Kn peut être chiffré selon une clé comprenant une valeur produite par la
Un exemple des opérations pouvant être effectuées pour le calcul de la nouvelle valeur de Kn est représenté sur la figure 3. Ces opérations sont effectuées de concert aussi bien dans la carte 2 que dans le serveur 15. Les valeurs
Nn+l et Kn sont soumises en 32 à une opération de combinaison logique, par exemple une combinaison OU
EXCLUSIF. La variable intermédiaire résultante Z est soumise à un chiffrement en 33 à l'aide d'un algorithme connu ou publique qui peut éventuellement être le même que celui utilisé en 24. Le chiffrement peut être effectué à l'aide d'une clé de chiffrement qui est de préférence la valeur de la variable dynamique actuelle Kn, bien qu'une autre clé secrète Q quelconque (bloc 34) puisse également être utilisée.
Nn+l et Kn sont soumises en 32 à une opération de combinaison logique, par exemple une combinaison OU
EXCLUSIF. La variable intermédiaire résultante Z est soumise à un chiffrement en 33 à l'aide d'un algorithme connu ou publique qui peut éventuellement être le même que celui utilisé en 24. Le chiffrement peut être effectué à l'aide d'une clé de chiffrement qui est de préférence la valeur de la variable dynamique actuelle Kn, bien qu'une autre clé secrète Q quelconque (bloc 34) puisse également être utilisée.
Le résultat de l'opération de chiffrement en 33 est la nouvelle valeur Kn+l de la clé de chiffrement qui va être utilisée lors de la prochaine demande d'accès. Cette valeur est mémorisée dans le registre 26.
Après obtention du mot de passe A qui est affiché sur l'écran 8 de la carte, l'utilisateur est invité à le communiquer à l'unité 3. Il est à noter que ce mot de passe peut être le résultat complet de l'opération de chiffrement en 24 (d'une longueur de 64 bits) ou bien seulement une partie de ce résultat, par exemple un mot de 32 bits. Cette communication (symbolisée par le trait en pointillées 35) peut se faire par exemple en tapant le mot sur le clavier 13 de l'interface 12. Cette communication peut également être réalisée automatiquement par le biais du dispositif de communication 10 ou par tout autre moyen de communication approprié, comme décrit ci-dessus.
Lors de l'introduction dans l'unité 3 du numéro d'identification publique 5, le programme du serveur 15 exécute, de concert avec la carte et à l'aide de variables dynamiques engendrées indépendamment par rapport à la carte 2, des opérations de calcul identiques à celles exécutées dans celle-ci. Ces opérations ont donc été indiquées sur la figure 2 par les mêmes références numériques suivies de la lettre "a", comme le sont les registres et le compteur servant à engendrer les variables dynamiques Nna , Ta et
Kna. La variable Kna est extraite de la mémoire 18 du serveur 15 en réponse à la demande d'accès, par exemple par transfert du numéro d'identification 5 vers l'interface 12.
Kna. La variable Kna est extraite de la mémoire 18 du serveur 15 en réponse à la demande d'accès, par exemple par transfert du numéro d'identification 5 vers l'interface 12.
La mémoire 18 stocke les variables Kna de toutes les cartes avec lesquelles le serveur est appelé à coopérer.
Par conséquent, le serveur 15 engendre de son côté et sans que lui soient communiquées les variables dynamiques engendrées dans la carte 2, un mot de passe Aa qui va être comparé au mot de passe A communiqué au serveur 15 par l'utilisateur. Si la carte est authentique, les mots de passe A et Aa doivent être identiques ou du moins concorder selon des règles prédéterminées. Si le test en 36 aboutit à une réponse affirmative, la fonction en 1 est libérée. Dans le cas contraire, l'accès sera refusé en 37.
On doit noter que dans un système selon l'invention, certains problèmes peuvent se poser lorsque l'une des variables est le temps ou est une fonction du temps, comme décrit ci-dessus, car la dérive des horloges utilisées tant dans la carte que dans le serveur ne peut être évitée. Une solution avantageuse de ces problèmes est décrite dans la demande de brevet déposée ce jour au nom de la demanderesse de la présente demande et intitulée "Système de contrôle d'accès à une fonction comportant un dispositif de synchronisation d' horloges".
On constate donc que, selon l'invention, le processus d'authentification de la carte conduisant à la libération de la fonction en 1 est réalisé à l'aide d'au moins deux variables dynamiques dont l'une est la clé de chiffrement Ka (Kna) et dont l'autre peut être soit le nombre Nn (Nna) de demandes d'accès déjà effectuées, soit le temps T (Ta), soit encore des nombres calculés selon une fonction prédéterminée de ces variables. Comme décrit ci-dessus, trois variables peuvent être utilisées telles que Kn (Kna), Nn (Nna) et T (Ta), les variables Nn (Nna) et T (Ta) étant combinées par exemple par une opération de concaténation.
La clé de chiffrement Kn (Kna) elle-même dérive d'une demande d'accès à l'autre et elle est dynamiquement variable en fonction de la valeur Nn (Nna) avec laquelle elle peut etre combinée logiquement , puis chiffrée pour donner lieu à la clé de chiffrement Kn+1 (Kna+l) utilisée lors de la prochaine demande d'accès.
Suivant une variante de l'invention, on peut envisager un transfert de données de la carte 2 vers l'unité 3 et le serveur 15, afin que les données puissent être traitées lors de l'accomplissement de la fonction 1 dans la mesure naturellement où l'autorisation a été donnée pour cela à la suite du test en 36.
L'utilisateur en formulant sa demande d'accès introduit en 38 les données dans la carte à l'aide de son clavier 6.
Ces données sont combinées logiquement en 39 avec la valeur concaténée des deux variables Nn et T, le résultat étant utilisé comme paramètre d'entrée de la procédure de chiffrement effectuée en 24. En variante, les données peuvent également directement être combinées avec le résultat de l'opération de chiffrement en 24. Il est essentiel que l'entrée pour l'opération 24 soit une fonction des données à transférer.
Les données sont également transférées au serveur 15 par exemple au moyen du clavier 13 de l'interface 12 ou automatiquement par l'intermédiaire des liaisons 10 et 16.
Les données ainsi reçues en 38 dans le serveur y sont traitées de la même façon que dans la carte 2. En effet, les données peuvent être combinées par une opération logique en 39a avec la valeur concaténée de Nn et de T, le résultat étant utilisé comme paramètre d'entrée pour le processus de chiffrement en 24a. En variante, les données peuvent directement être combinées avec le résultat de l'opération de chiffrement en 24a ou bien les données peuvent constituer une autre clé pour l'opération de calcul en 24a. Les données sont aussi communiquées en clair au dispositif chargé d'exécuter la fonction 1.
Ainsi, l'authenticité des données peut être vérifiée par comparaison des mots de passe A et Aa qui sont tous deux des fonctions de la valeur représentant les données. La mise en oeuvre de la fonction 1 recevra donc également un refus s'il y a non-concordance entre les données présentées des deux côtés.
Plusieurs autres modes de réalisation seront maintenant décrits, certains d'entre eux l'étant en faisant référence à des changements se produisant dans la carte 2, mais on comprendra que ces mêmes changements s'appliquent également au serveur 15, car la carte 2 et le serveur 15 doivent pouvoir engendrer des mots de passe identiques ou concordants.
L'opération 31 illustrée sur les figures 1 et 3 peut varier en fonction de T. De même, l'algorithme 33 peut être changé à chaque nouvelle dérivation de Kn, comme peut l'être l'algorithme utilisé pour le calcul en 24. Par exemple, les modules 24, 24a et 33, 33a peuvent stocker plusieurs algorithmes utilisés distinctement au cours des différentes opérations de calcul des mots de passe. Des changements synchronisés doivent alors être réalisés dans le serveur en ce qui concerne la fonction en 31a, et les algorithmes en 24a et 33a.
De plus, la fonction 32 (Figure 3) peut être différente d'une fonction OU-EXCLUSIF, telle qu'une opération ET ou toute autre opération logique. La fonction 32 n'est pas indispensable, Nn+l pouvant directement être utilisé par l'algorithme en 33 de façon à être chiffré par Kn ou Q.
D'ailleurs, Q peut être soumis avec Nn+l à une opération OU
EXCLUSIF en 32, Kn ou Q étant utilisé comme clé de chiffrement pour le chiffrement de la sortie produite par l'opération logique en 32.
EXCLUSIF en 32, Kn ou Q étant utilisé comme clé de chiffrement pour le chiffrement de la sortie produite par l'opération logique en 32.
Un autre mode de réalisation consiste à prévoir une porte ET entre les modules 29 et 30 de la figure 1, la sortie du module 29 constituant l'une des entrées de cette porte ET, l'autre entrée en étant formée par un signal provenant du serveur 15 et qui n'est engendré que si le module 29a engendre une sortie. Ce signal du serveur 15 peut être un type quelconque de signal de communication transitant par une ligne téléphonique ou en modulation sur des rayons infrarouges. De cette manière, le module 25 dans la carte 2 et le module 25a dans le serveur 15 seront incrémentés de façon synchrone. Il n'y aura alors aucune perte de synchronisation des valeurs Nn et Nna. Cependant, dans certaines applications de la présente invention, une telle communication en retour du serveur vers la carte peut ne pas être souhaitable.
Une autre variante consiste à stocker les données en 38 dans la mémoire de la carte. Par exemple, si la carte 2 est une carte bancaire, les données en 38 pourraient être la situation d'un compte bancaire, un numéro de compte etc.
La dérivation de Kn selon les fonctions 31 et 31a peut également être exécutée comme suit. Kn peut être dérivé deux fois pour chaque calcul du mot de passe. On peut le faire par exemple avant et après le calcul du mot de passe. Kn peut également être redérivé en parallèle avec le calcul du mot de passe. En d'autres termes, Kn peut être redérivé pendant le calcul du mot de passe, les sorties du module 24 et du module 24a étant alors directement utilisées comme entrées des modules 33 et 33a, respectivement.
En variante, les valeurs Nn et T peuvent être directement introduites dans le module 24. Les données peuvent être combinées logiquement directement avec Nn ou T ou encore les données peuvent être scindées en deux parties respectivement combinées avec Nn ou T.
Claims (21)
1. Système de contrôle d'accès ou d'authentification de personnes et/ou de messages par lequel notamment, au moins un utilisateur peut être autorisé à accéder à une fonction, comprenant au moins une première unité portable personnalisée (2) pour ledit utilisateur et au moins une seconde unité de vérification (3) commandant l'accès à la fonction ou l'authentification de l'utilisateur et/ou d'un message,
ladite première unité (2) comprenant
des premiers moyens générateurs (25, 26, 31) pour engendrer au moins deux variables (Nn, T)
des premiers moyens de calcul (24) pour engendrer un premier mot de passe (A) à l'aide d'au moins un premier algorithme de chiffrement utilisant des paramètres d'entrée fonction des variables ; et
des moyens (10, 12, 35) pour transmettre ledit premier mot de passe à la seconde unité (3) ;
ladite seconde unité (3) comprenant
des seconds moyens générateurs (25a, 26a, 31a) pour, en réponse à une demande d'accès faite à l'aide d'une déterminée desdites premières unités, engendrer au moins deux variables (Nna, Ta) assignées à cette même première unité déterminée ;
des seconds moyens de calcul (24a) pour engendrer un second mot de passe (Aa) à l'aide d'au moins un second algorithme de chiffrement utilisant des paramètres d'entrée fonction des variables (Nna, Ta) générées dans la seconde unité ;
des moyens (36) pour comparer les premier et second mots de passe
des moyens pour, s'il y a une cohérence prédéterminée entre les mots de passe, délivrer une autorisation d'accès à ladite fonction (1) et/ou une authentification,
caractérisé en ce que
lesdits premiers et seconds moyens générateurs prévus (25, 26, 31, 25a, 26a, 31a) respectivement dans lesdites première et seconde unités (2, 3) sont configurés de manière à fournir au moins deux variables dynamiques engendrées de concert, mais de façon indépendante dans lesdites première et seconde unités.
2. Système de contrôle suivant la revendication 1, caractérisé en ce que lesdits premiers et seconds moyens générateurs (25, 26, 31, 25a, 26a, 31a) comportent respectivement des troisièmes et quatrièmes moyens de calcul (33) pour engendrer au moins une première desdites variables (Kn, Kna) selon une fonction impliquant un nombre de demandes d'accès formulées par ladite première unité (2) avant la demande d'accès en cours.
3. Système de contrôle suivant la revendication 2, caractérisé en ce que lesdits troisièmes et quatrièmes moyens de calcul (33) engendrent respectivement une variable dynamique intermédiaire (Z) par combinaison logique dudit nombre de demandes d'accès formulées auparavant et la valeur actuelle de ladite première variable dynamique (Kn, Kna).
4. Système de contrôle suivant la revendication 3, caractérisé en ce que lesdits troisièmes et quatrièmes moyens de calcul (33) réalisent respectivement, au moyen de troisième et quatrième algorithmes, un chiffrement de ladite variable dynamique intermédiaire (Z), le résultat de ce chiffrement constituant une nouvelle valeur (Kn+l, Kna+l) de ladite première variable dynamique.
5. Système de contrôle suivant la revendications 4, caractérisé en ce que lesdits troisièmes et quatrièmes moyens de calcul (33) comprennent respectivement des moyens pour chiffrer ladite variable dynamique intermédiaire (Z) en utilisant ladite première variable (Kn, Kna) comme clé de chiffrement secrète pour lesdits troisième et quatrième algorithmes.
6. Système de contrôle suivant la revendication 4, caractérisé en ce que lesdits troisièmes et quatrièmes moyens de calcul (33) comprennent respectivement des moyens pour chiffrer ladite variables dynamique intermédiaire avec une clé de chiffrement (Q) qui diffère de ladite première variable dynamique et qui est utilisée pour lesdits troisième et quatrième algorithmes, respectivement.
7. Système de contrôle suivant la revendication 4, caractérisé en ce que lesdits troisièmes et quatrièmes moyens de calcul (33) transfèrent le résultat dudit chiffrement par lesdits troisième et quatrième algorithmes de chiffrement auxdits premiers et seconds moyens de calcul (24, 24a) respectivement, en tant que clé de chiffrement pour lesdits premier et second algorithmes.
8. Système de contrôle suivant l'une quelconque des revendications 2 à 7, caractérisé en ce que lesdits premiers et seconds moyens générateurs (25, 25a) engendrent respectivement une seconde desdites variables dynamiques en fonction dudit nombre de demandes d'accès formulées (Nn,
Nna) et transfèrent ladite seconde variable dynamique auxdits premiers et seconds moyens de calcul (24, 24a) respectivement, et en ce que lesdits premiers et seconds moyens de calcul (24, 24a) chiffrent une donnée d'entrée comprenant ladite seconde variable dynamique respectivement, à l'aide desdits premier et second algorithmes de chiffrement.
9. Système de contrôle suivant la revendication 8, caractérisé en ce que lesdits premiers et seconds moyens générateurs (26, 26a) engendrent respectivement une troisième desdites variables dynamiques en fonction du temps actuel (T, Ta) et transfèrent ladite troisième variable dynamique auxdits premiers et seconds moyens de calcul (24, 24a) respectivement, et en ce que lesdits premiers et seconds moyens de calcul (24, 24a) incorporent respectivement ladite troisième variable dynamique (T, Ta) dans ladite donnée d'entrée.
10. Système de contrôle suivant la revendication 9, caractérisé en ce que lesdits premiers et seconds moyens de calcul (24, 24a) exécutent respectivement une concaténation de ladite troisième variable et de ladite donnée d'entrée.
11. Système de contrôle suivant l'une quelconque des revendication 4 à 10, caractérisé en ce que lesdits troisième et quatrième algorithmes de chiffrement sont identiques auxdits premier et second algorithmes de chiffrement.
12. Système de contrôle suivant l'une quelconque des revendication 1 à 11, caractérisé en ce que lesdits premiers et seconds moyens générateurs (25, 25a, 26, 26a, 31, 31a) transfèrent respectivement une première desdites variables dynamiques (Kn, Kna) auxdits premiers et seconds moyens de calcul (24, 24a) en tant que clé de chiffrement pour lesdits premier et second algorithmes, engendrent une donnée d'entrée (Nn, Nna) comprenant une seconde desdites variables représentant le nombre de demandes d'accès formulées par ladite première unité avant la demande d' accès en cours, ladite donnée d'entrée étant transférée auxdits premiers et seconds moyens de calcul (24, 24a) respectivement pour y être chiffrée par ladite première variable dynamique.
13. Système de contrôle suivant la revendication 12, caractérisé en ce que lesdits premiers et seconds moyens générateurs (25, 26, 31, 25a, 26a, 31a) comprennent respectivement des troisièmes et quatrièmes moyens de calcul pour engendrer une clé de chiffrement (Kn, Kna) en fonction du nombre de demandes d'accès formulées.
14. Système de contrôle suivant la revendication 13, caractérisé en ce que lesdits troisièmes et quatrièmes moyens de calcul (33) comprennent respectivement des moyens de mémoire (28) et engendrent, à partir de la valeur actuelle (Kn, Kna) de ladite clé de chiffrement, une nouvelle valeur (Kn+l, Kna+l) de celle-ci et mémorisent ladite nouvelle valeur dans lesdits moyens de mémoire (28) à la place de ladite valeur actuelle.
15. Système de contrôle suivant l'une quelconque des revendication précédentes, caractérisé en ce que ladite première unité (2) comprend des moyens (6, 38) pour mémoriser des données destinées à être transférées à ladite seconde unité (3) afin de pouvoir être utilisées pour mettre en oeuvre ladite fonction, en ce que ladite seconde unité (3) comprend des moyens (12, 38) pour recevoir lesdites données et en ce que lesdits premiers et seconds moyens générateurs comprennent des moyens (39) pour transférer lesdites données respectivement auxdits premiers et seconds moyens de calcul (24, 24a) afin qu'elles puissent être utilisées comme une composante d'au moins l'une desdites variables dynamiques à chiffrer.
16. Système de contrôle suivant l'une quelconque des revendications précédentes, caractérisé en ce qu'il comprend des moyens de communication (10) dans lesdites première et seconde unités, lesdits moyens de communication comprenant une liaison téléphonique du type DTMF et/ou une liaison fonctionnant par rayons infrarouges.
17. Système de contrôle suivant l'une quelconque des revendications 1 à 15, caractérisé en ce qu'il comprend un lecteur de cartes prévu dans ladite seconde unité (3) et en ce que ladite première unité (2) se présente sous la forme d'une carte pouvant être lue par ledit lecteur de manière à permettre l'échange d'informations entre ladite première unité (2) et ladite seconde unité (3).
18. Système de contrôle suivant l'une quelconque des revendications 1 à 17, caractérisé en ce que ladite relation prédéterminée entre les mots de passe est l'égalité.
19. Système de contrôle suivant la revendication 9, caractérisé en ce que lesdits premiers et seconds moyens de calcul (24, 24a) assurent respectivement le traitement desdites seconde et troisième variables (Nn, T, Nna, Ta) pour engendrer ladite donnée d'entrée.
20. Système de contrôle suivant l'une quelconque des revendications 1 à 10, caractérisé en ce que lesdits premier et second algorithmes de chiffrement sont différents, mais présentent une relation prédéterminée qui se reflète dans la relation entre lesdits premier et second mots de passe (A, Aa).
21. Système de contrôle d'accès ou d'authentification de personnes et/ou de messages par lequel notamment, au moins un utilisateur peut être autorisé à accéder à une fonction, comprenant au moins une première unité portable personnalisée pour ledit utilisateur et au moins une seconde unité de vérification commandant l'accès à la fonction ou l'authentification de l'utilisateur et/ou d'un message,
ladite première unité comprenant
des premiers moyens générateurs pour engendrer au moins deux variables dynamiques ;
des premiers moyens de calcul pour engendrer un mot de passe à l'aide d'au moins un algorithme de chiffrement utilisant des paramètres d'entrée fonction des variables ; et
des moyens pour transmettre ledit mot de passe à la seconde unité
ladite seconde unité comprenant
des seconds moyens générateurs pour, en réponse à une demande d'accès faite à l'aide d'une déterminée desdites premières unités, engendrer au moins deux variables dynamiques assignées à cette même première unité déterminée ;
des seconds moyens de calcul pour déchiffrer ledit mot de passe à l'aide d'au moins un algorithme de chiffrement utilisant en tant que clé de déchiffrement un paramètre d'entrée fonction d'une première desdites variables dynamiques générées dans la seconde unité pour dériver l'une desdites variables engendrée dans ladite première unité ;
des moyens de comparaison pour comparer ladite variable dynamique dérivée par lesdits seconds moyens de calcul avec une seconde desdites variables dynamiques engendrées dans ladite seconde unité
des moyens qui, lorsque lesdits moyens de comparaison constatent qu'il existe une relation prédéterminée entre ladite variable dynamique dérivée par lesdits seconds moyens de calcul avec ladite seconde variable parmi lesdites variables dynamiques engendrées dans ladite seconde unité, délivrent une autorisation d'accès à ladite fonction
caractérisé en ce que
lesdits premiers et seconds moyens générateurs prévus respectivement dans lesdites première et seconde unités sont configurés de manière à fournir lesdites variables dynamiques de concert, mais de façon indépendante.
Priority Applications (11)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
FR9604798A FR2747815B1 (fr) | 1996-04-17 | 1996-04-17 | Systeme de controle d'acces a une fonction, dans lequel le chiffrement implique plusieurs variables dynamiques |
EP97915537A EP0891611B1 (fr) | 1996-03-22 | 1997-03-21 | Systeme de controle d'acces a une fonction, dans lequel le chiffrement implique plusieurs variables dynamiques |
DE69736283T DE69736283T2 (de) | 1996-03-22 | 1997-03-21 | Zugangskontrollsystem zu einer funktion, in der die chiffrierung mehrere dynamische veränderliche enthält |
AT97915537T ATE332548T1 (de) | 1996-03-22 | 1997-03-21 | Zugangskontrollsystem zu einer funktion, in der die chiffrierung mehreredynamische veränderliche enthält. |
AU22975/97A AU2297597A (en) | 1996-03-22 | 1997-03-21 | Function access control system with encryption using a plurality of dynamic variables |
JP9534077A JP2000508099A (ja) | 1996-03-22 | 1997-03-21 | 複数の動的暗号化変数を使用する機能へのアクセスを制御するシステム |
CA002249463A CA2249463A1 (fr) | 1996-03-22 | 1997-03-21 | Systeme de controle d'acces a une fonction, dans lequel le chiffrement implique plusieurs variables dynamiques |
PCT/FR1997/000505 WO1997036264A1 (fr) | 1996-03-22 | 1997-03-21 | Systeme de controle d'acces a une fonction, dans lequel le chiffrement implique plusieurs variables dynamiques |
ES97915537T ES2267138T3 (es) | 1996-03-22 | 1997-03-21 | Sistema de control de acceso a una funcion de encriptado utilizando una pluralidad de variables dinamicas. |
DK97915537T DK0891611T3 (da) | 1996-03-22 | 1997-03-21 | Adgangskontrolsystem til en funktion, hvori krypteringen kræver flere dynamiske variabler |
TW086103652A TW367683B (en) | 1996-03-22 | 1997-03-22 | System for controlling access to a function, using a plurality of dynamic encryption variables |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
FR9604798A FR2747815B1 (fr) | 1996-04-17 | 1996-04-17 | Systeme de controle d'acces a une fonction, dans lequel le chiffrement implique plusieurs variables dynamiques |
Publications (2)
Publication Number | Publication Date |
---|---|
FR2747815A1 true FR2747815A1 (fr) | 1997-10-24 |
FR2747815B1 FR2747815B1 (fr) | 1998-06-19 |
Family
ID=9491288
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
FR9604798A Expired - Lifetime FR2747815B1 (fr) | 1996-03-22 | 1996-04-17 | Systeme de controle d'acces a une fonction, dans lequel le chiffrement implique plusieurs variables dynamiques |
Country Status (1)
Country | Link |
---|---|
FR (1) | FR2747815B1 (fr) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP2234030A3 (fr) * | 2009-03-25 | 2011-08-17 | Bundesdruckerei GmbH | Carte à puce, système informatique, procédé d'activation d'une carte à puce et procédé de personnalisation d'une carte à puce |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP0244332A1 (fr) * | 1986-04-22 | 1987-11-04 | René Soum | Système de très haute sécurité de télécommande sans fil permettant l'ouverture ou la fermeture inviolable de relais actionnant des systèmes tels que serrures |
DE4223258A1 (de) * | 1992-07-15 | 1994-01-20 | Telefunken Microelectron | Verfahren zur verifizierbaren, entschlüsselungssicheren Übertragung von Daten |
EP0605996A1 (fr) * | 1993-01-07 | 1994-07-13 | Ford Motor Company Limited | Système de sécurité commande à distance |
EP0698706A1 (fr) * | 1994-08-26 | 1996-02-28 | TEMIC TELEFUNKEN microelectronic GmbH | Procédé d'exploitation d'un système de fermeture pour objets verrouillables |
-
1996
- 1996-04-17 FR FR9604798A patent/FR2747815B1/fr not_active Expired - Lifetime
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP0244332A1 (fr) * | 1986-04-22 | 1987-11-04 | René Soum | Système de très haute sécurité de télécommande sans fil permettant l'ouverture ou la fermeture inviolable de relais actionnant des systèmes tels que serrures |
DE4223258A1 (de) * | 1992-07-15 | 1994-01-20 | Telefunken Microelectron | Verfahren zur verifizierbaren, entschlüsselungssicheren Übertragung von Daten |
EP0605996A1 (fr) * | 1993-01-07 | 1994-07-13 | Ford Motor Company Limited | Système de sécurité commande à distance |
EP0698706A1 (fr) * | 1994-08-26 | 1996-02-28 | TEMIC TELEFUNKEN microelectronic GmbH | Procédé d'exploitation d'un système de fermeture pour objets verrouillables |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP2234030A3 (fr) * | 2009-03-25 | 2011-08-17 | Bundesdruckerei GmbH | Carte à puce, système informatique, procédé d'activation d'une carte à puce et procédé de personnalisation d'une carte à puce |
EP3671506A1 (fr) * | 2009-03-25 | 2020-06-24 | Bundesdruckerei GmbH | Carte à puce, système informatique, procédé d'activation d'une carte à puce et procédé de personnalisation d'une carte à puce |
Also Published As
Publication number | Publication date |
---|---|
FR2747815B1 (fr) | 1998-06-19 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP0941525B1 (fr) | Systeme d'authentification a carte a microcircuit | |
EP0055986B1 (fr) | Procédé et dispositif de sécurité pour communication tripartite de données confidentielles | |
EP1004100B1 (fr) | Dispositif portable electronique pour systeme de communication securisee, et procede d'initialisation de ses parametres | |
EP0891611B1 (fr) | Systeme de controle d'acces a une fonction, dans lequel le chiffrement implique plusieurs variables dynamiques | |
FR2738934A1 (fr) | Systeme de comptabilisation anonyme d'informations a des fins statistiques, notamment pour des operations de vote electronique ou de releves periodiques de consommation | |
FR2546646A1 (fr) | Systeme permettant au porteur d'une carte intelligente d'executer des transactions au moyen d'un terminal de transactions, terminal d'initialisation de cartes intelligentes et carte intelligente portative utilisables avec un tel systeme | |
EP0317400B1 (fr) | Dispositif et procédé de sécurisation d'échange de données entre un terminal vidéotex et un serveur | |
EP0547975A1 (fr) | Procédé d'authentification, par un milieu extérieur, d'un objet portatif connecté à ce milieu par l'intermédiaire d'une ligne de transmission, et système pour la mise en oeuvre | |
EP0425053A1 (fr) | Système de traitement de données comportant des moyens d'authentification d'une carte à mémoire, circuit électronique à utiliser dans ce système et procédé de mise en oeuvre de cette authentification | |
FR3092414A1 (fr) | Procédé d’authentification, serveur et dispositif électronique d’identité | |
EP1055203B1 (fr) | Protocole de controle d'acces entre une cle et une serrure electronique | |
WO2011033199A1 (fr) | Systeme de gestion securisee de serrures a commande numerique, adapte a un fonctionnement par accreditations acoustiques chiffrees | |
WO2003107587A1 (fr) | Procede et dispositif d’interface pour echanger de maniere protegee des donnees de contenu en ligne | |
FR3095371A1 (fr) | Procédé d’authentification d’un document d’identité d’un individu et éventuellement d’authentification dudit individu | |
EP0891610B1 (fr) | Systeme de controle d'acces a une fonction comportant un dispositif de synchronisation d'horloges | |
EP3262553A1 (fr) | Procede de transaction sans support physique d'un identifiant de securite et sans jeton, securise par le decouplage structurel des identifiants personnels et de services | |
WO2019102120A1 (fr) | Procédés et dispositifs pour l'enrôlement et l'authentification d'un utilisateur auprès d'un service | |
FR2747815A1 (fr) | Systeme de controle d'acces a une fonction, dans lequel le chiffrement implique plusieurs variables dynamiques | |
BE1003693A6 (fr) | Systeme de securite pour systeme informatique. | |
EP0566492B1 (fr) | Procédé d'authentification d'un ensemble informatique à partir d'une disquette informatique | |
FR2748144A1 (fr) | Procede de transmission securisee entre un emetteur et un recepteur, emetteur et recepteur pour la mise en oeuvre du procede | |
EP1262860B1 (fr) | Système et procédé d'authentification d'un utilisateur | |
EP4241190A1 (fr) | Procede d'authentification securise par le decouplage structurel des identifiants personnels et de services | |
FR2747814A1 (fr) | Systeme d'acces a une fonction comportant un dispositif de synchronisation d'horloges | |
Crossingham et al. | BASE: a Proposed Secure Biometric Authentication System |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
CA | Change of address | ||
CD | Change of name or company name |
Owner name: ACTIVIDENTITY EUROPE SA, FR Effective date: 20140221 |
|
PLFP | Fee payment |
Year of fee payment: 20 |
|
TP | Transmission of property |
Owner name: ASSA ABLOY AB, SE Effective date: 20150428 |