030329315
030329315
030329315
MÉMOIRE PRÉSENTÉ À
DE LA MAÎTRISE
EN
PAR
HAYETTEBOUMERZOUG
OCTOBRE 2011
Université du Québec à Trois-Rivières
Service de la bibliothèque
Avertissement
Je tiens à remercier, tout d' abord, mon directeur de mémoire Boucif Amar Bensaber de
l' aide qu ' il m' a apporté, de son sens de minutie au travail qui m' a permis de réaliser des
articles scientifiques de qualité pour accomplir ce mémoire, son esprit critique qui m' a
permis de remettre en question ma méthode et améliorer ma méthode de travail, ce qui a
avancé et approfondi mes recherches.
Je remercie mon mari et mes frère Samir et Mohamed de leur soutien ainsi que leurs
encouragements au cours de la réalisation de ce mémoire.
Je remercie mes parents de m' avoir encadré alors que je développais mon potentiel dès le
plus jeune âge.
Enfin, j'adresse mes plus sincères remerciements à mes deux familles Boumerzoug et
Boucher, et à tous mes proches et amis, qui m'ont toujours soutenue et encouragée au
cours de la réalisation de ce mémoire.
Merci à tous et à toutes.
ii
RÉSUMÉ
Les réseaux de capteurs sans fil ont beaucoup d'applications dans les domaines militaires
et civils. Ils sont utilisés dans les activités de surveillance, de contrôle médical et de
contrôle environnemental. En fait, un réseau de capteurs sans fil WSN (Wireless Sensor
Networks) est un type spécial de réseaux ad hoc composé d'un ensemble de nœuds
déployés dans une zone géographique. Chaque capteur est en mesure de recevoir et de
transmettre des données de façon autonome à un nœud puits (Sink) qui est connecté à
l'utilisateur du réseau via Internet ou par un satellite, par exemple.
Ces réseaux sont caractérisés par un déploiement à grande échelle, d' une mobilité des
nœuds, d' une topologie dynamique et par des ressources minimes. En effet, chaque nœud
a des contraintes extrêmes en termes d'énergie, de mémoire, de vitesse de calcul et de
débit.
Nous proposons un protocole de sécurité qui offre une bonne protection en tenant compte
des caractéristiques limitées des capteurs. Le protocole est basé sur une gestion des clés
efficaces et résistantes avec un stockage minimal des clés.
Notre approche est fondée sur la combinaison et l'amélioration de deux méthodes déjà
proposées par la communauté de recherche:
Dans notre mémoire, nous avons décris les réseaux de capteurs sans fil et nous avons
expliqué et détaillé les contraintes et les capacités limitées des nœuds. Dans le troisième
chapitre, nous allons présenter les courbes elliptiques et leurs applications dans la sécurité
des communications, en particulier, la cryptographie.
iii
Après avoir présenté notre méthode, l' architecture du réseau et la méthodologie suivie,
nous développerons chacune des approches proposées.
Dans le cinquième chapitre, nous allons présenter les modèles de simulation utilisés, les
scénarios et la base de nos métriques d' évaluation.
Enfin, pour montrer l' efficacité de notre méthode, nous avons fait une comparaison avec
deux méthodes existantes dans la littérature ce qui no-Us a permis de conclure l' apport
positif de notre méthode pour les réseaux de capteur sans fil.
iv
ABSTRACT
A wireless sensor network consists of hundreds or thousands of sensor nodes that are
powered by batteries and are typically deployed randomly in environments often open.
These nodes are small, and therefore, have computational resources, storage memory,
communication and power that are very limited. These networks are of particular interest
for military, environmental, and medical applications, and for applications related to
monitoring of critical infrastructures. But not ail applications always have the same
security constraints. Data encryption is often required for sensitive applications such as
military applications and medical applications.
ln many applications, the establishment of encryption keys must be done once the sensor
nodes are deployed. This is the case when a large number of sensors are deployed
randomly, for example, from an helicopter. Each node must establish a secret key with
each of its neighbors but its neighbors are not known before the deployment. The keys
exchange should take place as soon as the deployment starts.
ln this paper; we propose a security protocol for sensor networks that provides good
protection while taking into account the limited resources of the sensors. The protocol is
based on an effective key management method with a minimum storage of keys. Our
approach is based on the combination and improvement oftwo methods already proposed
by the research community: cryptography based on elliptic curves and key management
based on an A VL tree. Compared with RECC "A Routing-Driven Elliptic Curve
Cryptography Based Key Management Scheme for Heterogeneous Sensor Networks" and
CECKM "High-Effect Key Management Associated With Secure Data Transmission
Approaches in Sensor Networks Using a Hierarchical-based Cluster Elliptic Curve Key
Agreement" two methods based on Diffie-Hellman elliptic curve cryptography method,
our approach provides a positive impact on reducing energy consumption and memory
v
storage. It saves significant time and memory and it reduces the exchanged packets
during keys installation with fewer processing operations.
vi
TABLE DES MATIÈRES
Page
1.2.3. Protocoles basés sur la connaissance antérieure du déploiement ........ .......... .............. .4
1.2.6. Protocoles basés sur la pré-distribution d' une liste partielle de clés ......................... 13
1.2.7. Protocoles basés sur les courbes elliptiques ...................... ...... .... .............................. 18
2.8. Les Attaques dans les réseaux de capteurs sans fil ............................................................ 34
2.8.1. Subversion d' un nœud ......... .............. ................ .............. ........... ............ ................... 34
2.8.4. Panne d' un nœud ... ............. ..... .... ....... ... ............................................................. ....... 35
2.8.7. Expédition sélectif .............................................. ....... ,.. ... ...... ...... .. .... ........................ 35
2.9. La cryptographie dans les réseaux de capteurs sans fil ........................ ...... .............. ......... 36
2.10. Conclusion .. .... ... .. ... ... ... ... .... ................................... .............. .... ............. ....... ................. 37
AVL
3.1. Introduction ............................... ..... ..... ...... .. .... .. .... ... .. .......... .......... ......... .................... ...... 38
3.2. La cryptographie ..................... .............................................. ... ..................... .... ........ .... ..... 38
3.5. La cryptographie basée sur les courbes elliptiques ECC. ...... ..... ... ...................... .............. 40
3.6. Les Courbes Elliptiques ......... ... ...... .. .. ..... ........ .... .. ... ... ........... .......... .... ............ .. .............. . 41
3.6.4. Courbes elliptiques sur GF(2n) .... .. .. .......... .. ........... .. .............. ....................... .. ... ....... 43
3.6.5. Courbes elliptiques dans R2 ......... ........... ........ ... ............ .... ....................................... 43
3.6.6. L' addition de deux points ..... .... .......................................... .. ... .. .... ... ......................... 43
3.6.7. La multiplication ............................................... ................ .. ... ...... ... ........ .. ........ .. .. ... . 44
3.7. Les arbres A VL ................ .................. .. .. ......................... .. .. ...... .... ... ................................. 46
3.7.1. Pourquoi lesarbresAVL? ...................... ...... .......................... .. ..... .. ...... ... ..... .... ...... 47
3.7.2. Équilibrage d' un arbre binaire A VL. .......... ... ...... .... ..... .......................... .............. ..... 47
3.8. Conclusion ....... ....................................................................... .... ..... ........ .. ..... .. ......... ... ..... 47
4. LA MÉTHODE PROPOSÉ
4.1. Introduction .. ...................... .. ....................... ........... .. ..... .............. ... ............... .. .. ............. ... 49
4.2. Les réseaux de capteurs homogènes et hétérogènes ...... .. ...... ........................ .. .. ............ .... 50
4.3. Gestion des clés .............. ............ .. .... ............. ............. .................... ........................ .. ..... .. .. 51
4.4. La méthode proposée ...... ..... ............................. ... ................ ..... .... .. ....................... .. .......... 53
4.5. Le scénario .............. .... .......... ... .... ..................................... ...... .... .. ........ ........................... .. 56
4.5.3. L' établissement des clés distribués A VL-Leaders .. .... ............ .. .................................... 58
4.5.4. L' établissement des clés centralisées A VL-KDC .... ........ .. ........................................ 61
4.6. Conclusions .................... .. .......................................................... ..... .... .... ... .. .... ................ . 64
5. SIMULATION
5.2.3. Fidélité .......................... ... ...................................... ... ..... ........ .................... ............. ... 67
5.5. Les Métriques ....... .. ............ .... ........................... ..... ...... .... ........... ... .................. ............... .. 69
6. RÉSULTATS
6.1. Introduction .... ..... ... ................................................................... ..... ..................... ...... .. .. .... 73
6.3. Les Métriques .... ....... ................... .... ...................... .. ..... .......... .... .. ........ ... ............... ........... 74
6.4.1. Comparaison des paquets échangés .... ....... .. ....... ...... ... ... .... ... ... ........ ..... ... ... .... .......... 76
6.4.2. Comparaison de l' énergie dépensée ......................................... ...... .. ...... .. .. ...... ......... 77
6.4.4. Comparaison de l' espace mémoire RAM exploité .... ... .. ..... .. ................... ... ... ... ........ 83
6.6. L'ajout d' un nouveau nœud .. ....... .. ....... ...... .... ..... .. ... ........ ... ......... ......... ........... ................. 88
6.7. Analyse de sécurité ......... ......... .. ................... .... ......... ........ ....... ....... ................................. . 89
6.8. Conclusion ....................... .................. ......... ............ ...... ..... .... ....... .... .. ................. .............. 90
7. CONCLUSION ....... ... .................. ..... ... .... .. .... ....... ... ............. .. ............................................... 92
FIGURE 4.2. LA STRUCTURE DE L'ARBRE A VL DES CLÉS ECC ET LA LISTE DES NŒUDS....... 54
FIGURE 4.3. LES CLÉS DE CHIFFREMENT UTILISÉES PAR LES NŒUDS ....................................... 55
FIGURE 6.1. NOMBRE DE PAQUETS ÉCHANGÉS LORS DE L'INSTALLATION DES CLÉS ............... 76
FIGURE 6.7. UTILISATION DE LA MÉMOIRE RAM POUR CALCULER UNE CLÉ PARTAGÉ ENTRE
FIGURE 6.8. UTILISATION DE LA MÉMOIRE RAM POUR CALCULER UNE CLÉ PARTAGÉ ENTRE
FIGURE 6.9. LA CONSOMMATION D'ÉNERGIE LORS DE LA MISE À JOUR DES CLÉS .................. 87
FIGURE 6.10. NOMBRE DE PAQUETS ÉCHANGÉS LORS DE L'INSTALLATION DES CLÉS ............. 89
TABLE DES TABLEAUX
Tableau 3.1. Comparaison de la taille des clés entre RSA et ECC ..................................•....•..41
Tableau 5.1. le nombre de clés ECC stockées dans la méthode Routing-Driven courbe
elliptique•...•.•..•...........................•.•.•.......•.•.•....•..•.•.....•.........•.............................................•.. 71
Tableau 5.2. le nombre de clés ECC stockées dans la méthode Routing-Driven courbe
elliptique .•...•.•...•.•..•.•.•.................................................................•.•.•.....•.••.•..•.•...•.•....•.......... 71
1.1. Introduction
Un réseau de capteurs sans fil est composé de centaines voire de milliers de nœuds de
capteurs qui sont alimentés par des piles et qui sont typiquement déployés de façon
aléatoire dans des environnements souvent ouverts. Ces nœuds sont petits, et par
conséquent, ont des ressources de calcul, de stockage, de communication et d'énergie très
limitées. Ces réseaux, ont un intérêt particulier pour les applications militaires,
environnementales, médicales, et les applications liées à la surveillance des
infrastructures dites critiques. Ces applications ont souvent besoin d'un niveau de sécurité
élevé.
Mais toutes les applications n' ont pas toujours les mêmes contraintes de sécurité. Le
chiffrement des données est souvent requis pour des applications sensibles telles que les
applications militaires ou les applications médicales.
Dans beaucoup d'applications, l'établissement des clés doit se faire une fois que les nœuds
capteurs sont déployés. C'est le cas par exemple, lorsqu'un grand nombre de capteurs sont
déployés de façon aléatoire, par exemple, à partir d'un hélicoptère. Chaque nœud doit
établir une clé secrète avec chacun de ses voisins. Ses voisins ne sont pas connus avant le
déploiement. Les échanges de clés doivent avoir lieu sur le terrain.
1.2. Les approches de gestion de clés
Divers solutions ont été présentées dans la littérature. Souvent, elles utilisent des
méthodes dynamiques recommandant la mise à jour des clés pour offrir une résistance
contre les attaques pour une longue période.
Dans ce paragraphe, je vais exposer les différentes approches de gestion des clés de
cryptage pour les réseaux de capteurs en spécifiant leurs avantages et leurs inconvénients.
Eschenauer et Gligor [1] ont proposé, en 2002, un protocole probabiliste. Ce protocole est
relativement simple et il opère comme suit :
Dans ce protocole, il est toujours possible qu'un nœud, autre que A et B possède
également les clés partagées entre A et B, alors, ce nœud pourra calculer le secret que B
et A viennent d'établir. Cependant Eschenauer et Gligor ont montré que cette probabilité
peut être faible si les paramètres L et m sont choisis avec précaution.
Les méthodes définies dans [2],[3], [4], [5], [6] améliorent le protocole probabiliste [1].
Elles proposent la pré-distribution des clés de façon aléatoire, ce qui implique la création
d'une grande liste de clés par un administrateur du réseau, et avant le déploiement, un
sous-ensemble de cette liste choisi aléatoirement est distribué à chaque nœud.
·2
Pour établir une clé de liaison entre deux nœuds, il est possible que ces nœuds possèdent
des clés communes dans leurs sous-ensembles de clés, alors ils utilisent les clés
communes.
Le choix des sous-ensembles est basé sur la probabilité d'Eschenauer et G1igor [1]. Un
des inconvénients de ces approches est le nombre de clés qui peut êtres est très grand.
L'idée principale du protocole RoK est de limiter la durée de vie des clés secrètes dans le
tableau et de faire évoluer les clés du système en fonction du temps.
Une solution naïve et simple serait, que le système change les clés dans le tableau à
chaque période. À une période donnée T, un nœud pourrait échanger des secrets avec ses
voisins et ensuite effacer les clés de configuration de sa mémoire. Par conséquent, si ce
nœud est compromis plus tard, ses clés ne pourront pas être utilisées.
Pour qu'un nœud déployé à la période T + 1, RoK a attribué à chaque nœud (w * m) clés,
ou west la durée de vie moyenne d'un capteur.
3
Si un nœud est déployé à la période T, il sera configuré avec m clés de la période T, m
clés de la période T + l , ... , et m clés de la période T + w.
Ainsi ce nœud pourra échanger un secret avec des nœuds de sa génération, mais aussi des
nœuds des générations T + 1, T + 2, , T +w.
Un des inconvénients de cette approche est qu'elle augmente le nombre de clés que
chaque nœud doit stocker par un facteur w. Pour résoudre ce problème, une nouvelle
construction est développée en utilisant une chaine de haschs doublement chaînée. Elle
permet de réduire le coût mémoire de (w * m) à (2 *m), c'est à dire à un coût constant.
Afin que les nœuds de capteurs puissent avoir une meilleure probabilité et pour identifier
l'ordre arrangé au préalable des nœuds voisins, Du et autres [2] ont proposé la
connaissance antérieure du déploiement où les nœuds sont arrangés du préalable dans un
ordre avant le déploiement.
Si les nœuds voisins sont connus, la pré-distribution des clés devient insignifiante; il
suffit juste de produire une clé partagée entre chaque deux nœuds voisins. Ceci garantit
que chaque nœud peut établir un canal bien fixé avec chacun de ses voisins après le
déploiement.
4
1.2.4. Protocoles basés sur les clés aléatoires
Dans [Il], E.Munivel et autres ont proposé la méthode MICRO PKI (Micro public Key
Infrastructure).
Dans cette approche, seulement la station de base est authentifiée par les nœuds utilisant
une clé publique. Cette clé est utilisée aussi pour décrypter quelques données envoyées
par les nœuds. La station de base utilise une clé privée.
Le réseau est composé d'un ensemble de nœuds de capteur sans fil connectés l'un à
l'autre.
Quand un nœud aura besoin d' établir une liaison garantie avec la station de base :
5
2-Quand la station de base reçoit le message, elle le décrypte avec sa clé privée et
elle stocke la clé reçue dans une table associée à chaque nœud.
Après la phase d"établissement des clés entre chaque nœud et la station de base; alors si
deux nœuds ont besoin d' établir un canal sécurisé entre eux, ils exécutent les étapes
suivantes:
1-Un des deux nœuds envoie une demande à la station de base pour établir un lien
sécurisé avec l'autre nœud . Cette demande contient l'identificateur de l'autre
nœud.
2-En recevant cette demande, la station de base produit une clé aléatoire et elle
envoie à chacun une copie chiffrée avec la clé correspondante.
3-En recevant la nouvelle clé, les deux capteurs commencent à l'utiliser pour
crypter les échanges entre eux.
Quand un nœud arrive à une certaine période (paramètre relié à la longueur des clés et la
complexité de l'algorithme utilisé) il lance une nouvelle installation; qui est réellement
une mise à jour des clés.
6
1.2.4.4. Ajout d'un nouveau nœud
Si un nouveau nœud veut joindre le réseau, l'administrateur du réseau doit charger la clé
publique de la station de base dans ce nœud, après le déploiement, le nouveau nœud peut
automatiquement établir une liaison avec la station de base et les nœuds voisins comme
décrit auparavant.
Dans [8], A.S.Poornima et autres ont proposé une méthode basée sur l' arbre M-ary. Dans
ce cas-ci, les capteurs d' un c1uster sont organisés sous forme d' un arbre équilibré comme
indiqué dans la figure 1.1. Cet arbre est maintenu par un leader, qui est désigné par 'H-
nœud.
7
Les feuilles sO, s2, ... , s8 représentent les nœuds dans le cluster.
Chaque nœud partage avec le leader sa clé privée utilisée pour communiquer avec le
leader.
Les clés kO-2, k3-5 , k6-8 représentent les clés qui sont partagées par un certain sous-
ensemble de nœuds (dites des clés intermédiaires).
CK est la clé de groupe qui est partagé par t~us les nœuds dans le cluster.
Chaque capteur stockera toutes les clés le long du chemin de la feuille à la racine de
l'arbre.
Tous les nœuds leaders dans le réseau forment un autre arbre qui est géré par la station de
base. La clé partagée par tous les leaders est la tête du cluster dite CCHK. Les leaders
utilisent CCHK pour communiquer entre eux.
Initialement:
• Chaque capteur est pré chargé d'une clé privée avec laquelle il échange avec le
leader avant le déploiement.
• Tous les leaders sont pré chargés de toutes les clés qui sont assignées aux nœuds.
Après le déploiement:
Aussitôt qu'un nœud est compromis, le leader changera toutes les clés le long du chemin
allant de la position du nœud compromis à la racine de l' arbre.
Les clés changées sont distribuées de façon sécuritaire aux autres nœuds en utilisant les
clés intermédiaires.
• Un nouveau nœud est pré-chargé d'une clé privé qu'il partage avec le leader. La
station de base chiffre cette clé privée en utilisant la clé CCHK, et l' envoie à tous
les leaders.
• En recevant le message, chaque leader à toute l'information concernant le nouveau
nœud.
• Chaque leader envoie le message « Hello » pour ajouter le nouveau nœud de
capteur.
9
• Le nouveau nœud choisit son leader LD dont le message « Hello» à la meilleure
proportion de bruit du signal
• Le leader sélectionne une position pour le nouveau nœud dans l'arbre et l'arbre est
mis à jour (c'est-à-dire, toutes les clés le long du chemin incluant la clé du c1uster
CK sont changées).
• Le leader distribue la nouvelle clé du c1uster à tous les nœuds sauf le nouveau
nœud, le message est chiffré en utilisant l'ancienne clé CH.
• Le restant des clés changées sont chiffrées en utilisant la vieille clé intermédiaire
respective, puis ces clés seront distribuées à tous les autres nœuds du cluster.
• Pour distribuer toutes les clés changées au nouveau nœud, le leader les chiffre
avec la clé privée du nouveau nœud.
La clé du c1uster CK est changée à CK ' par les leaders, et elle est distribuée en la
chiffrant avec l' ancienne clé CK.
De la même façon la station de base changera CCHK à CCHK ' et la distribue à tous les
leaders solidement en chiffrant CCHK' avec CCHK.
Comme ont peut le remarquer dans cette méthode, chaque sous-ensemble de nœuds a une
seule clé partagée et elle est utilisée pour la communication avec les nœuds; alors si un
seul nœud est compromis, un adversaire peut écouter tous les messages entre tous les
nœuds du sous-ensemble.
10
1.2.5.2. Gestion des clés dynamique utilisant un arbre AVL
Le réseau de capteurs sans fil est hiérarchique et les nœuds sont organisés dans des
clusters par les leaders LDs (le leader est celui qui a le plus d' énergie). Le leader
rassemblent les messages des nœuds non leaders dans les clusters, et les font suivre à la
station de base BS.
Les clés sont établies sur deux niveaux AVL [10], le premier présente les nœuds du
cluster et l' arbre est maintenu par le leader; le deuxième niveau présente les leaders du
réseau et l' arbre est maintenu par la station de base.
Les processus de deux niveaux d' établissement de l'arbre des clés sont semblables.
Pour créer les clusters, chaque leader diffuse un message de chiffrage avec son ID et une
clé aléatoire KH pour informer tout le réseau.
Quand un nœud Nu non leader reçoit le message, il utilise une fonction de hachage F et
la clé KH pour produire la clé secrète temporaire KU,H et il envoie cette clé avec son
identificateur pour joindre le cluster.
Après un certain temps, chaque leader reçoit des messages d' ajout des nœuds, puis il
rassemble tous les identificateurs et les clés des nœuds de son cluster et il produit
l' ensemble des clés en se basant sur un arbre A VL en utilisant les données duelles (la clé
Il
secrète temporaire et l' identificateur de chacun des nœuds) selon le sort des valeurs des
clés.
Une fois que l' ensemble des clés est produit, le leader ré-envoie à chaque nœud dans le
cluster un message « «ajout-réponse » contenant la position de l' identificateur du nœud
dans l'arbre A VL.
Le leader utilise la position de chaque nœud Nu dans l' arbre A VL pour produire la clé
du nœud Nu en utilisant la fonction d' hachage F.
Maintenant, les nœuds du cluster choisi un autre leader (celui qui a plus d' énergie), et ils
envoient un message d' ajout à ce nœud.
Avant le déploiement, chaque nœud est pré-chargé avec une clé aléatoire initiale, cette
clé est partielle.
Après un temps, chaque voisin Nv répond avec son identificateur et sa clé Kv, puis
chaque paire de nœuds voisins Nu et Nv calculent leur clé partagée.
12
Chaque nœud peut être authentifié par ses nœuds immédiats. S'il y a quelques nœuds
malveillants, ils peuvent être distingués avec cette approche.
Après l' établissement des arbres A VL, la tâche des nœuds se déplace à l'étape stable
(steady stage) et le réseau fonctionne de façon régulière.
Une fois que, les comportements non-normaux d'un nœud (comme des fausses clés de
communication) sont détectés par un leader, il informe tous les nœuds de son groupe pour
mettre à jour la vieille clé et reconfigurer l'arbre A VL, ainsi la nouvelle clé du cluster
remplace l' ancienne clé.
En outre, dans le cas où la station reçoit un certain nombre de messages, elle doit
informer tous les leaders de faire une mise à jour des clés.
Dans le cas où un leader CH reçoit un certain nombre de messages, il doit informer tous
les nœuds dans le cluster de faire une mise àjour des clés.
L' inconvénient dans ce protocole est que chaque cluster, à un certain temps, doit changer
son leader (choisir celui qui a le plus d' énergie) et cette opération présente une grande
communication entre les nœuds dans le cluster pour établir les clés à chaque session.
13
Dans SecCOSEN on utilise l' appellation chaîne au lieu de cluster, ces chaînes sont
composées d' un nombre fixe de capteur qui sont les membres dans la chaîne et un nœud
leader qui est le leader du niveau inferieur. Dans chaque chaîne, les données agrégées par
les capteurs sont acheminées le long des chaînes vers le leader de la chaîne, et ce dernier
rassemble les données agrégées et les transmet à la station de base.
Les chaînes du niveau inférieur sont formées de tous les nœuds dans le réseau et chaque
chaîne choisi un leader, le choi est basé sur quelques critères. Ces leaders de niveau
inférieur forment à leur tour une chaîne de niveau plus haut dont un leader seul appelé le
leader de niveau plus haut, ce leader est choisi (selon quelques paramètres) pour
transmettre les données à la station de base.
La transmission des données collectées au niveau inférieur à la station de base passe par
la chaîne du nœud se trouvant avant le leader, puis par la chaîne des leaders se trouvant
avant la station de Base, comme indiqué dans la figure 1.2.
14
données. Le nœud à une fin de la chaîne envoie ses données vers le nœud leader
par des nœuds intermédiaires.
1.2.6.3. Initialisation
• Le protocole de gestion des clés SecCOSEN est basé sur la pré-distribution des
clés et la cryptographie symétrique.
• Chaque nœud garde un sous ensemble de clés plutôt que tout l'ensemble des clés.
• Chaque deux nœuds correspondants utilisent toujours une nouvelle clé secrète
pour le cryptage / décryptage des données à chaque tours.
• Deux nœuds voisins établissent leur clé de cryptage / décryptage par la
concaténation de leurs clés.
fl : Un message simple
15
E-I k (~')= ~ : est le décryptage du message chiffré.
ID : Identifiant du nœud.
NK : la clé du réseau.
• Une association des clés est produite à la station de base avant le déploiement des
nœuds.
• Chaque nœud doit consommer toutes ces clés (Après la première phase de
formation des chaînes, le nœud peut supprimer toutes les clés partielles
supplémentaires)
o Note: en utilisant n clés, chaque deux nœuds voisins peuvent établir
jusqu'à 2n2 clés secrètes.
• A vant le déploiement chaque nœud est pré- chargé de l'association des clés S, de
la liste des identificateurs des clés L, d'une seule clé du réseau NK, et d'un
identificateur unique ID.
• Après le déploiement et la création des chaînes, tous les membres de chaque
chaîne envoient leur IDS (chiffré par la clé du réseau) au leader de la chaîne.
• Après la réception de tout les IDs, chaque leader local envoie tout les IDs reçus
avec son propre ID à la station de base pour l'authentification.
16
1.2.6.5. L'utilisation des clés partagées
Le problème est qu ' à l' arrivée d' un nouveau nœud, les nœuds voisins dans la chaîne ne
peuvent pas établir des clés avec le nouveau nœud car ils ont déjà supprimé le reste des
clés.
17
1.2.7. Protocoles basés sur les courbes elliptiques
Dans le but d ' avoir une gestion de clé efficace et réaliser une économie de stockage
significative, [13] et [14] ont présenté une Cryptographie de Courbe Elliptique.
Cette approche [14] suppose qu ' on divise le réseau en plusieurs clusters à l'aide d'un
algorithme approprié pour le déploiement. Cette approche consiste en 5 phases.
Soit:
X : le numéro du cluster.
Le réseau utilise la fonction l=x3+ax+b comme une courbe elliptique, et tous les nœuds
dans le réseau (normaux ou station de base) partagent les coefficients a et b et P une
valeur publique qui est un point sur la courbe elliptique.
18
Les étapes de cette approche sont les suivantes:
1.2.7.1.1. La phase 1
Une station de base BSx est déployée comme un contrôleur de la clé de cryptage intra-
c1uster, qui est utilisée pour les membres du c1uster Mxi, où x dénote l'identité du c1uster
et n le nombre des clusters, avec 1<x<n, et i et la quantité de nœuds dans le c1uster.
1.2.7.1.2. La phase 2
Le système déploie une station de base RBS qui est la plus puissante et plus sécurisée
comme le contrôleur des clés du réseau entier et coopère avec les autres stations de base
BSx (1 <X<n) pour produire les clés du système entier.
1.2.7.1.3. La phase 3
Le processus de cette phase est détaillé dans trois étapes présentées dans la figure 1.3, ces
étapes sont les suivantes:
19
Étapel
Tout d'abord, dans un cluster c, chaque nœud membre dans le cluster MCj produit ces clés
privées KMc j et KMcjP utilisant la méthode Échange de clés Diffie-Hellman ECDH
(voire chapitre 4) et émet ensuite la clé KMcjP à tous les autres nœuds dans le cluster c.
Après un temps, chaque nœud reçoit toutes les clés privées des autres nœuds, il calcule la
multiplication de sa clé privée KMc x et par les autres clés privées reçus.
Étape 2
Chaque nœud dans le cluster MCj extrait sa propre clé privée KMci du produit
KM12KM13 ... KMIN-IP, et transmet KMc2KMc3..KMcj_lKMcj+ l.. KMcn- lP à son leader
qui est la station de base BSc.
Étape 3
La station de base BSc reçoit le KMc2KMc3.. KMcj_lKMcj+ l.. KMcn_lP du nœud MCj,
puis il génère la clé privée du nœud MCj qui est la multiplication de la clé privée de la
station de base KMcn par la clé reçue, C.-à-d. le produit KMc2KMc3.. KMcj_lKMcj+l ..
KMcn_l PKMcn.
20
De même façon, chaque nœud peut avoir finalement la clé du c1uster, cette clé est
/1
toujours égale à Il KMc; x P .Pour chaque station de base BSx cette clé est défini
1= 1
comme KCxP.
1.2.7.1.4. La phase 4
Comme il est présenté dans la figure lA, cette étape déroule comme le suivant:
La station de base BS2 calcule KC 1KC2P, et elle envoi le résultat à la station de base
suivant BS3.
De même façons, chaque station de base BSx multiplie sa propre clé privée KC x avec le
reçu de la station de base BS x_1 précédente KC 1KC 2... KCx-1P et ensuite elle envoie le
résultat à la station de base BS x+ 1suivante.
N
Par conséquence, la clé calculée par la station de base BSN- I sera Il KC; x P .
;=1
N
Figure 1.4. Le calcul de la clé Il KC; x P •
;= 1
21
1.2.7.1.5. La phase 5
La station de base BSN-l diffuse sa clé privée à tous les autres leaders (BS 1, BS2,
BS 3, ... , BS N-2).
1.2.7.1.6. La phase 6
;=1
KC; x P , elle extrait sa propre clé du
produit, puis elle envoie le résultat KC1KC2... KC x- 1 KC x+l .. KC N-IP à RBS la station de
base choisie par le système comme un contrôleur.
1.2.7.1.7. La phase 7
Finalement, Quand le RBS obtient la clé d ' une station de base BSx, il multiplie sa propre
clés KCN par le résultat envoyé par BSx. Puis il envoie le dernier résultat à la station de
base BSx.
Quand une station de base BSx recroit le message du RBS qui contient la clé rr
N
;=1
KC; x P
{ itx, x€[l ,N]}, elle multiplie la clé envoyé par sa propre clé KCx.
Par conséquence, toute les stations de base peuvent avoir la même clé sera rrN
;=1
KC; x P .
Comme on a pu le constater à travers les différentes phases et étapes, cette méthode exige
énormément d' échange entre les nœuds pour établir les clés partagées.
22
1.2.7.2. Une Cryptographie de Courbe Elliptique basée sur le Protocol de
routage pour Réseaux de Capteurs Hétérogènes
La méthode [13] est basée sur le Protocol de routage pour Réseaux de Capteurs
Hétérogènes.
Le réseau HSN est un réseau hiérarchique formé d ' un sink et de deux types de capteurs.
Un petit nombre de capteurs puissants servent de leaders et un grand nombre de capteurs
normaux forment les c1usters. Tous les leaders forment la colonne vertébrale de la
communication dans le réseau. Ils accumulent les données délivrées par les nœuds
normaux et ils les font suivre ensuite les données au Sink.
Cette méthode comprend deux approches, l'une est basée sur l'établissement centralisé
des clés et l' autre sur l' établissement des clés distribué.
Avant le déploiement
23
• Après un certain temps, le leader devrait recevoir des messages « Keyrequest » de
tous les nœuds dans son c1uster et ensuite il utilise l' algorithme de l'arborescence
de communication optimale (SPT) [36] pour déterminer l'arborescence dans le
groupe.
• Ensuite, le leader produit les c1és- partagés pour chaque noeud et ses voisins
directs. Pour un nœud Nu et son voisin Nv, le leader produit une nouvelle clé
(Ku,v)
• Le leader chiffre le message contenant la clé (Ku,v) en utilisant la clé publique de
Nu et ensuite il envoie le message au nœud Nu.
• Le nœud Nu décrypte le message et obtient la clé partagée entre lui et son voisin
le nœud Nv.
• Après que tous les noeuds obtiennent les clés partagées, ils peuvent communiquer
avec leurs voisins de façon sécuritaire.
Avant le déploiement
• Chaque nœud normal est pré-chargé avec une paire de clés privée / publique ECC.
• Chaque nœud leader est pré-chargé avec la même paire de clés privée / publique
ECC, et une clé spécialement pour l' ajout d' un nouveau nœud.
24
• Quand le leader reçoit le message, il peut vérifier le MAC et authentifier ensuite
l' identifient de Nu, en utilisant la clé publique de Nu. Alors le leader produit un
certificat pour la clé publique de Nu en utilisant sa clé privée.
o Un certificat clé public prouve l'authenticité d'une clé publique et prouve
plus loin l'identité d'un capteur à un autre capteur.
• Après la détermination de l'arborescence du cheminement dans un c1uster, le
leader dissémine l'arborescence et le certificat clé public correspondant à chaque
nœud. Les certificats des clés publics sont signés par la clé privée du leader et
peuvent être vérifiés par chaque nœud.
• Si deux nœuds sont le parent et l'enfant dans l'arbre de cheminement, alors ils
sont des voisins l'un de l'autre et ils fonderont une clé partagée pour eux.
• Pour chaque paire de voisins, le nœud avec le plus petit ID introduit le processus
d'établissement des clés.
o Par exemple, soit les nœuds Nu et Nv voisins directs et Nu a un ID plus
petit que Nv, le processus est présenté ci-dessous:
• Nu envoie sa clé publique à Nv.
• Nv envoie sa clé publique à Nu.
• Nu produit la clé partagée en multipliant sa clé privée avec la clé
publique de Nv.
• Simultanément Nv produit la clé partagé.
Quand un nœud compromis est détecté selon un certain protocole, il est annoncé au
leader du c1uster, le leader diffuse un message de révocation contenant l'identité du nœud
compromis. En recevant le message de révocation, chaque nœud dans le c1uster vérifie
25
s'il communique avec le nœud compromis. Si tel est le cas, alors il révoque les clés
partagées avec ce dernier.
Les messages d' échange des clés publiques entre les voisins ne sont pas chiffrés, cela
n' empêche pas un adversaire d' écouter ces messages. Aussi une fois, un nœud
compromis, les nœuds voisins qui ont une liaison avec lui, révoquent seulement sa clé de
leur mémoire et il n y ' a pas un processus de mise àjour des clés.
1.3. Conclusion
Les réseaux de capteurs sans fil ont beaucoup d'applications informatiques civiles ou
militaires, qui nécessitent un niveau de sécurité très élevé. En effet, la sécurité est basée
sur la gestion des clés, qui est difficiles à implanter à cause de la nature des réseaux de
capteurs sans fil et surtout quand les capteurs sont mobiles.
Dans ce chapitre nous avons présenté différentes approches de gestion des clés de
cryptage pour les réseaux de capteur sans fil. Nous avons répartie ces approches en
plusieurs catégories et nous avons présenté les avantages et les inconvénients de chacune.
Nous avons pu constater que les approches basées sur le protocole probabiliste sont
relativement simple, mais elles demandent une grande mémoire de stockage pour les clés
et elles sont moins résistantes. L'approche basée sur l' arbre M-arry n' est pas robuste
mais le nombre de messages échangé pour installer les clés est d' ordre logarithmique.
Aussi dans l' approche basée sur l' arbre AVL le nombre de messages échangé pour
installer les clés est d' ordre logarithmique, mais comme l' approche Micro public Key,
elle exige un grand nombre de mises à jour. Avec l' approche SecCOSEN, il n' est pas
possible d' établir des liens sécurisés à l' ajout de nouveaux nœuds dans le réseau. Enfin,
26
les approches basées sur les courbes elliptiques offrent un niveau de sécurité plus élevé,
mais elles demandent plus de calculs et d'échanges des paquets entre les nœuds.
Alors quelle est la meilleure façon de réaliser une communication sure entre les nœuds en
respectant les conditions suivantes?
• Les clés basées sur une Cryptographie de Courbe Elliptique réalisent une
économie de stockage significative et un niveau de sécurité plus élevé.
• Dans les réseaux de capteurs sans fil hétérogènes, l'énergie consommée est
moindre que l'énergie consommée dans le réseau de capteurs homogène et le
taux de livraison dans les réseaux hétérogènes est meilleur que celui dans les
réseaux homogènes.
• Les gestions de clés basées sur un arbre sont plus avantageuses dans la
distribution des clés, et le nombre de messages échangé est d'ordre logarithmique.
• En utilisant serveur KDC comme dans [13], pour calculer les clés basé sur les
courbes elliptique, le réseau gagne plus de temps et conserve plus d'énergie.
27
Notre but essentiel est d' atteindre des résultats fiables à travers des simulations utilisant
une approche qui combine les avantages des méthodes précédentes, et faire des scénarios
proches de la réalité.
Dans le chapitre 5, nous allons décrire notre méthode qui comprend deux approches,
approches basées sur la combinaison et l' amélioration de deux méthodes déjà proposées
par la communauté scientifique, ces méthodes sont: l-une gestion de clés basé sur un
arbre binaire de recherche A VL, 2- une cryptographie basé sur les courbes elliptiques.
Le but de notre travaille est de trouver une méthode moins coûteuse, au niveau de la
consommation d ' énergie et au niveau du stockage de clés, et au même temps offrir une
sécurité plus élevé.
Pour montrer l' efficacité de notre méthode, nous avons choisi deux méthodes plus
récentes pour faire la comparaison, notre méthode et ces deux méthodes partagent la
même configuration du réseau et le même système de cryptage (cryptographie basée sur
les courbes elliptiques).
Mais avant d' entrer dans les détails de notre méthode, dans le chapitre 4, nous allons
présenter les courbes elliptiques et leurs applications dans la sécurité des
communications, en particulier, la cryptographie, et nous allons aussi parIer de l' arbre
binaire de recherche A VL.
Dans le chapitre suivant nous allons faire une présentation du réseau de capteurs sans fil ,
leurs applications et leurs contraintes, et les problématiques liées à ces contraintes et ces
applications.
28
CHAPITRE 2
LE RÉSEAU DE CAPTEURS SANS FIL
2.1. Introduction
Avec l' évolution de la technologie, il est devenue important observer et contrôler des
phénomènes physiques (tels que la température, la pression .. ) pour de nombreuses
applications industrielles et scientifiques, ce besoin permette d' assurer la liaison homme
- machine - environnement.
Les capteurs sont des composants qui permettent de capter et de prélever les informations
et les données d' entourage et de mesurer les effets des phénomènes de toutes natures qui
agissent sur l'environnement de l' homme.
Il n'y a pas si longtemps, la seule solution pour acheminer les données des capteurs
jusqu 'au contrôleur central était le câblage qui avait comme principaux défauts d' être
coûteux et encombrant.
Mais ces derniers années, et grâce aux récents progrès des technologies sans fil, les
infrastructures ne sont plus reliées par des câbles. Les supports de transmission sont
généralement des ondes (radios, infra rouges, ... ).
2.2. Description
Les réseaux Ad Hoc sont des réseaux sans fil capables de s' organiser sans infrastructure
définie préalablement.
29
Le réseau est composé d'un ensemble de nœuds capteurs. Les nœuds comportent un grand
nombre de micro-capteurs.
Le champ de captage est une zone géographique où les nœuds sont dispersés.
Les données captées sont transférées à un nœud puits (sink) par un routage multi-sauts.
Le sink est connecté à l'utilisateur du réseau via une connexion Internet ou satellitaire.
2.3. Applications
Les réseaux de capteurs sans fil sont utilisés par plusieurs applications dans différents
domaine dont:
Si un ou plusieurs capteurs ont des problèmes, ces derniers ne doivent pas affecter le reste
du réseau. Le réseau doit capable de fonctionner en cas de problème.
30
2.4.2. L'échelle
Les capteurs déployés peuvent atteindre un nombre très important. Le puits "sink" doit
être équipé d'une grande capacité de mémoire pour stocker les informations reçues.
2.4.3. Le coût
Le prix d' un capteur ne dépasse pas 1$. Par contre le prix d' un capteur Bluetooth revient
à environ 10$.
2.4.4. L'environnement
Les capteurs peuvent être déployés en masse dans n' importe quel endroit.
4. Les médias de transmission: dans les réseaux de capteurs sans fils les
supports de transmission généralement sont des ondes radio, infrarouge,
bluetooth et des communications radio ZigBee.
31
5. L'importance d'énergie: Il y a des cas ou le changement de la batterie
d'un capteur est impossible, alors la durée de vie de ces capteurs est
reliée à la durée de vie de celle-ci.
C'est pour cette raison que les recherches se concentrent sur les méthodes pour diminuer
cette consommation.
2.5. La Communication
Le nœud peut seulement communiquer avec les voisins directs dans le réseau.
Si un nœud a besoin de communiquer avec les nœuds qui se trouvent au-delà portée radio
du nœud, il doit transmettre les données à travers les nœuds intermédiaires.
Les nœuds sont toujours sous l'influence de l'impact de l'environnement (les montagnes,
les constructions, les tempêtes, les obstacles de terrain).
32
Fréquemment, les nœuds sont débranchés, alors il y a d'échec de la communication, et
cela cause la perte des données. Ce qui faut que, le logiciel et le matériel des nœuds
doivent être robustes.
2.6. L'auto-organisation
Avant l'installation du réseau de capteurs sans fil , les nœuds n' ont pas une connaissance
antérieure de leurs positions dans le réseau. Après le déploiement, et avec une
collaboration, les nœuds peuvent s' ajuster, exécuter et distribuer l'algorithme de
déploiement. Ils peuvent rapidement et automatiquement former le réseau, sans le besoin
d' un centre de contrôle. Chaque nœud a un statut identique.
2.7. La sécurité
But: Assurer l'authenticité des données, ainsi que la protection contre la contrefaçon ou
l' usurpation d' identité et empêcher l'injection de faux messages.
33
Il est nécessaire que la communication entre le sink et les nœuds soit privée et que le
récepteur prévu des données l'assurance que les données ne sont pas modifiées pendant la
transmission.
Exige que les messages soient courants, et ne pas reproduire les messages transmis
précédemment.
La capture d'un nœud peut divulguer ses informations comprenant les clés
cryptographiques, ce qui compromettrait le réseau entier.
L'addition d'un nœud malveillant par un adversaire pour injecter des données
malveillantes, le faux nœud peut envoyer ces données à travers les nœuds réseau, et aussi
il peut recevoir les messages envoyés par les nœuds du réseau .
34
2.8.3. Défaut de fonctionnement d'un nœud
Que se produit-il quand un nœud leader cesse de fonctionner? Les protocoles du réseau
devraient être assez robustes pour atténuer les effets des pannes des nœuds en fournissant
un itinéraire alternatif.
Quand le contenu d'un message est modifié par un attaquant, il compromet l'intégrité du
message.
L'expédition sélective est une manière d'influencer le trafic du réseau en faisant croire
que tous les nœuds participants dans le réseau sont fiables pour expédier le message.
Dans l'attaque d'expédition sélective, les nœuds malveillants laissent tomber certains
messages au lieu de les expédier, et ils réduisent la latence et trompent les nœuds voisins
qui sont sur un chemin plus court.
35
2.9. La cryptographie dans les réseaux de capteurs sans fil
Pour réaliser la sécurité dans n'importe quel modèle de communication, il est important
de chiffrer les messages transmis aux nœuds selon un arrangement de gestion de clés
convenues.
Dans les réseaux traditionnels, les méthodes employées dans la gestion des clés sont
complexes. Cependant, fournir une gestion des clés sures dans des réseaux de capteurs est
difficile dues à la topologie et aux limitations du réseau de capteurs sans fil et à la
dynamique des ressources.
Le problème principal est la distribution des clés secrètes entre les parties communicantes
pour fournir des propriétés de sécurité telle que le secret et l'authentification.
Pour amorcer la sécurité dans des réseaux de capteurs sans fil , les nœuds doivent pouvoir
établir une communication de nœud-à-nœud comme suit:
• Les nœuds légitimes additionnels déployés plus tard devraient pouvoir former un
raccordement assuré avec des nœuds déjà-déployés.
• Les nœuds non autorisés ne devraient pas pouvoir gagner l'entrée du réseau, par
l'injection de paquet ou par usurpation d' identité en tant que nœud légitime.
• L'approche doit fonctionner sans connaissance antérieure de la topologie du
réseau, c.-à-d. les nœuds ne peuvent pas savoir leurs positions et leurs voisins
qu'après le déploiement.
• Le stockage des clés devrait être bas et la méthode devrait être robuste pour
contrer les attaques externes.
36
2.10. Conclusion
Les réseaux de capteurs sans fil deviennent plus en plus un choix plus intéressant à cause
de la facilité du déploiement et la mobilité des capteurs, la simultanéité de l'information
et le coût réduit d'installation.
Mais malheureusement, les capteurs sont assez fragiles et vulnérables à diverses formes
de défaillances (faible énergie, panne, attaque d' adversaire, ... etc.), ce qui rend le réseau
entier vulnérable et fragile.
Le but général d'un réseau de capteurs sans fil est la collecte d'un ensemble de données
environnementales (telles que la température, la pression .. ), afin de les acheminer vers
des centres de traitement.
Dans le chapitre suivant nous allons présenter la cryptographie basée sur les courbes
elliptique, puis nous allons parler des arbres binaires de recherche AVL, qui sera utilisé
dans notre approche de gestion de clés.
37
CHAPITRE 3
LA CRYPTOGRAPHIE BASÉE SUR LES COURBES
ELLIPTIQUES ET LES ARBRES AVL
3.1. Introduction
On a constaté que les systèmes de cryptage basé sur les courbes elliptique offre un
niveau de sécurité plus élevé et au même temps un stockage de clés plus significatif.
Et, on a remarqué que les gestions de clés basées sur un arbre sont plus avantageuses dans
la distribution des clés, et le nombre de messages échangés est d' ordre logarithmique.
Pour le but de mieux comprendre notre méthode, et avant d' entrer dans les détails de
notre méthode, nous avons présenté et expliqué les deux piliers de notre méthode, qui
sont l'arbre AVL et la cryptographie basé sur les courbes elliptique.
3.2. La cryptographie
L'origine du mot cryptographie provient du grec krypt6s (cache) et grâfein (écrire) [28].
On peut définir la cryptographie comme l'ensemble des techniques permettant de
protéger une communication et assurer que l' information contenue ·dans un message ne
soit révélée qu'au seul destinataire de ce message.
Pour des raisons pratiques, ces fonctions sont décomposées en algorithmes paramétrés
par une clé. Le fonctionnement de ces algorithmes est public et seule la valeur de la clé
est tenue secrète.
La cryptographie consiste à mettre au point des systèmes cryptographiques afin d' assurer
la confidentialité, l' authentification et l'intégrité.
• La cryptographie symétrique.
• La cryptographie asymétrique.
Un sous-groupe repose sur le fait que deux entités partagent un même secret, ce qui leur
permettra une communication sécuritaire.
En cryptographie, les courbes elliptiques sont des objets mathématiques, elles peuvent
être utilisées pour des opérations asymétriques comme des échanges de clés sur un canal
non-sécurisé ou un chiffrement asymétrique.
Les clés employées pour un chiffrement par courbe elliptique sont plus courtes qu'avec
un système fondé sur le problème de la factorisation comme La cryptographie à clé
publique du RSA [37]. Cela signifie des calculs plus rapides et une consommation
d'énergie plus faible ainsi que des économies de mémoire et de bande passante. De plus,
l'ECC procure un niveau de sécurité équivalent ou supérieur aux autres méthodes. Un
autre attrait de l'ECC est qu'un opérateur bilinéaire peut être défini entre les groupes. Les
opérateurs bilinéaires se sont, récemment, vus appliquer de nombreuses façons en
cryptographie, par exemple pour le chiffrement basé sur l'identité.
La résistance d'un système fondé sur les courbes elliptiques repose sur le problème
du logarithme discret dans le groupe correspondant à la courbe elliptique. Les
développements théoriques sur les courbes étant relativement récents, la cryptographie
avec courbe elliptique n'est pas très connue et souffre d'un grand nombre de brevets qui
empêchent son développement. [32]
Dernièrement, ECC a attiré beaucoup d'attention comme une solution de sécurité pour les
réseaux de capteurs sans fil en raison de la petite taille de la clé ECC, par exemple une clé
ECC de 160 bits offre une sécurité comparable à une clé RSA de 1024 bits.
Dans [26], les auteurs ont pu démontrer que tous les protocoles cryptographiques
classiques existants peuvent être adaptés sur les courbes elliptiques.
Le tableau 3.1 présente une comparaison de la taille des clés entre RSA et ECC en
assurant le même niveau de sécurité.
40
Niveau-Sécurité 1 2 3 4 5 6
Dans ce qui suit, nous présentons une brève introduction de la théorie des courbes elliptiques.
Soit (G,+) un groupe fini de cardinal N et dont l' unité pour l'addition est O.
La plus petite valeur pour laquelle vk=O s' appelle l' ordre de x.
41
Un élément de cet ensemble est représenté comme un n-uplet de p éléments de
Cet ensemble est muni d' une addition et d ' une multiplication. En fait, c 'est un corps: tout
élément non nul est inversible.
L ' addition est simple: c 'est l' addition composantes à composantes dans Z/pZ.
La multiplication est plus compliquée, mais plus simple qu ' une multiplication modulo un
nombre de la taille de pn.
Le plan projectifP2(K) est l' ensemble des points P (a, b, c) of (0, 0, O)E K 3 .
Une courbe elliptique est une cubique irréductible non singulière de P2(K), qui possède
un point 0 l' élément neutre.
Une courbe elliptique est une courbe birationnellement équivalente aux points de
l' équation de Weierstrass:
(1)
Les courbes elliptiques ECC comptent sur la difficulté du problème de logarithme discret,
c'est-à-dire, étant donné les points Pet Q, il est difficile de trouver un nombre K tel que Q
= KP.
42
3.6.4. Courbes elliptiques sur GF(2n)
Soit les paramètres a et b dans GF(2n) avec b non nul ( GF corps de Galoi) . La courbe
elliptique E associée est l' ensemble des points (x,y) dans (GF(2n))2 tels que
l+xy=x3+ax+b auquel on adjoint un point spécial 0 appelé point à l' infini.
(2)
La figure 3.1 présente le graphe d' une courbe elliptique dans R2.
43
La somme de deux points P et Q d' une courbe elliptique (comme dans la figure 3.1) est
(p" P2) régie les propriétés suivantes:
Avec
et r =pz - ÀPt
Si q,=p, et si q2= Pr a,p ,-a3, alors R= 0 , l'élément neutre pour l' opération addition.
On remarque que l' opération "+" possède toutes les propriétés de l'addition des nombres,
on peut faire tous les calculs de type addition, soustraction et division.
3.6.7. La multiplication
y2+xy=x3+ax+b. (4)
44
Si on choisit aléatoirement a et b, pour choisir un point sur E, il faut résoudre une
équation du troisième degré sur GF(2n). C ' est un problème difficile.
Si on doit choisir plusieurs points aléatoirement sur la courbe, on calculera N(xO,yO) avec
n très grand nombre aléatoire. En fait N» 2n. [33]
Ils se mettent aussi d'accord (toujours publiquement) sur un point P situé sur la courbe.
Chacun de leur côté, ils sont capables de calculer dA(dBP) = (dAdB)P qui est un point de
la courbe, et qui constitue leur clé secrète commune.
C'est ce que l'on appelle résoudre le logarithme discret sur une courbe elliptique.
45
3.7. Les arbres AVL
L'Arbre AVL est un arbre de recherche binaire équilibré. Pour chaque nœud de l'arbre, la
différence de hauteur de ses sous-arbres est au maximum égale à 1 [34].
L' intérêt d' un arbre AVL se situe dans la recherche. En effet, puisque l' arbre est
équilibré, on évite d'avoir des situations où la recherche est spécialement longue.
Pour insérer un nœud dans un arbre A VL, l' opération prend à la plupart une rotation
(rotation simple ou double) pour rééquilibrer l'arbre.
Pour supprimer un nœud, l' opération prend à la plupart le log(n) des rotations pour
rééquilibrer l'arbre.
Pour chercher dans un arbre équilibré, il faut conserver l' équilibre lors des ajouts et/ou
des suppressions.
La figure 3.2 montre à gauche un arbre non équilibré et à droite le même arbre après un
équilibrage.
,........,
50 1
.;.",;;/
TI ~72
~.
..;;.;,,;
' ",.-..., ",.-..., . ...........
...........
g 3 ~ ~
,.-..... -,........
9
"-'"
14
......."
~ 'fJ
'-/
46
3.7.1. Pourquoi les arbres AVL?
Les Arbres Binaires de recherche permettent d' effectuer des opérations d' insertion, de
suppression et de recherche en un temps proportionnel à la hauteur de l' arbre qui, lui-
même, si on fait attention, est presque proportionnel à log(n).
Dans [25], l' auteur a démontré que l'utilisation d'une opération globale réduit le nombre
de mises à jour des clés.
Depuis, pour chaque changement d'adhésion, les clés qui sont le long du chemin du
membre affecté à la racine doivent être changées, si plusieurs demandes sont traitées
ensemble, certains des chemins peuvent partiellement se chevaucher, les clés appartenant
à la partie du chevauchement doivent être mise à jour seulement une fois dans chaque
opération globale.
Quand tous les membres dans un sous-arbre exigent le ré-verrouillage dans une opération
globale, les clés le long du chemin de la racine de ce sous-arbre à la racine de l'arbre des
clés doivent être changées.
Suite à un ajout d'un nœud, on remonte du nouveau nœud jusqu' à la racine de l' arbre en
calculant la différence de profondeur des sous-arbres de chacun des nœuds rencontrés. Si
cette différence est égale à deux ou moins deux, on rééquilibre avec la bonne rotation.
47
3.7.3. Conclusion
Les courbes elliptiques peuvent être vues comme un sous-ensemble d ' un corps fini . Les
calculs dans ce sous ensemble étant plus complexes que sur le corps fini lui-même, un
meilleur niveau de sécurité est plus rapidement atteint (en terme de taille de clé).
Un arbre A VL, est un arbre binaire de recherche qui offre une meilleure garantie sur le
temps d'insertion, de suppression et de recherche dans les cas défavorables. Ceci permet
l' utiliser dans des applications en temps réel.
L' utilisation de l' approche de gestion de clé basée sur un arbre AVL nous permet de
réduire énormément la quantité de clés stockées ainsi limite les envois des clés à ceux qui
en ont besoin, soit environ 2 log(n) clés.
Dans le chapitre suivant, nous décrivons notre méthode de gestion de la sécurité dans les
réseaux de capteurs sans fil , l' architecture du réseau et la méthodologie suivie, et la
gestion des clés procurées.
48
CHAPITRE 4
LA MÉTHODE PROPOSÉE
4.1. Introduction
Comme nous avons vue dans le deuxième chapitre, dans [12], la méthode CECKM a
implanté les clés basées sur les courbes elliptiques, ce qui assure un niveau de sécurité
très élevé mais l' inconvénient est que le nombre de messages échangés est énorme ainsi
le nombre de clés stockées, et dans cette méthode chaque nœud dois générer sa paire de
clés ECC, et cette opération demande beaucoup de calculs, et par conséquence plus
d ' énergie consommée.
Pour éviter le calcule des clés ECC, dans [13], la méthode utilise un serveur KDC, et les
clés ECC sont pré-chargées dans les nœuds leaders, et pour réduire le nombre de clés
stockés, chaque nœud ne stocke que les clés utilisés pour la communication avec ces
voisins, alors pour cela il faut calculer l' arbre de routage avant l' installation des clés, et
cela demande un grand nombre d' échange de paquets, et toutes ces échanges ne sont pas
protégés, ce qui met le réseau en péril.
Une autre méthode qui nous a attiré l' attention est Gestion des clés dynamique utilisant
un arbre A VL [9], les gestions basées sur des arbres binaires échangent moins de paquets
pour installer les clés, mais dans cette approche les clés n' étaient pas robustes.
Notre but est de tirer et d' exploiter et de combiner les avantages de ces méthodes, en
ajoutant des améliorations et des modifications qui permettent une gestion de clés
efficace et moi couteuse.
49
• Des clés ECC qui sont légères et résistantes.
• Une gestion basée sur un arbre binaire A VL, qui permet un nombre de messages
échangé d' ordre logarithmique.
• Un réseau de capteurs sans fil hétérogène, qui consomme moins d'énergie, et
assure un taux de livraison plus élevé.
Dans ce chapitre nous allons enter dans les détails de notre méthode, mais d'abord nous
allons décrire en bref les deux différentes architectures des réseaux de capteur sans fil , et
nous allons aussi expliquer en bref la gestion des clés.
Il est évident que les nœuds leaders des clusters sont surchargés avec des taches
supplémentaires et nécessaires, comme l'agrégation des données et la coordination du
protocole de routage, par conséquent, leur durée de vie expire avant celle de ses autres
nœuds.
La première solution est de faire tourner le rôle du leader du cluster périodiquement sur
tous les nœuds du cluster tel que proposé dans l' approche Leach (Low Energy Adaptive
Clustering Hierarchy) [24]. Mais les ressources des nœuds sont limités, ils n' ont pas de
matériel assez puissant et également le réseau homogène peut souffre des mauvaises
performances.
Pour améliorer les performances du réseau, il est mieux de former un réseau avec un petit
nombre de nœuds de haute capacité et une transmission à longue portée et d' un grand
nombre de capteurs de basse capacité [6] .
50
P. Samundiswary et autres [18], ont implémenté un réseau de capteurs sans fil
hétérogènes et ils ont comparé avec d' autres réseaux de capteurs sans fil homogène. Ces
réseaux de capteurs hétérogènes ont moins de sauts, pour atteindre le nœud Sink et ils
impliquent moins de multi-sauts que les réseaux homogènes.
Aussi, également, le taux de livraison dans les réseaux hétérogènes est meilleur que celui
dans les réseaux homogènes.
La gestion des clés est une procédure pour stocker et distribuer des clés cryptographiques
d'une façon sûre; la génération et de la distribution des clés aux destinataires autorisés
doit être aussi assurée et sécurisée.
Après le déploiement, les capteurs ont besoin d' établir des clés cryptographiques avec
leurs voisins pour assurer des services de sécurité.
La gestion de clé doit fournir un établissement de clés entre tous les nœuds, et elle doit
fonctionner même si la topologie du réseau n' est pas prédéfinie. Et, les nœuds non
autorisés ne peuvent pas effectuer des communications avec les nœuds du réseau.
La sécurité du réseau est un défi sérieux; la gestion statique des clés n'est pas appropriée
particulièrement après une longue période. Alors, nous proposons une gestion basée sur
le système d'arbre A VL, parce que dans le cas de changement d'un nœud (dans l'arbre
A VL), il peut causer un changement d' un sous-arbre, et les clés seront aussi changées en
même temps.
51
Figure 4.1. Arbre A VL de clés.
Dans la figure 4.1, les capteurs sont représentés par des carrés, et les clés sont
représentées par des cercles.
Dans l'arbre A VL, comme la figure 4-1 le démontre, chaque à H clés, où H dénote la
hauteur de l'arbre AVL, chaque feuille doit posséder toutes les clés correspondantes aux
nœuds de l' arbre AVL. Les feuilles ne connaissent pas les clés dont elles n'ont pas
besoin.
Le facteur d'équilibrage est -1 , c.-à-d. la différence entre la hauteur d' un sous-arbre droit
et un sous-arbre gauche égale à -1.
Lorsque des messages doivent être envoyés à tous les nœuds, on utilise la clé racine de
l' arbre AVL car cette clé est connue de tous.
Si le message s' adresse d' un contrôleur à une feuille, la clé qui se trouve dans le niveau H
et la position horizontale de la feuille peuvent être utilisées.
Si le message s'adresse d' une feuille à une feuille, la première clé commune et la plus
proche aux feuilles, et les positions horizontales des feuilles peuvent être utilisée.
52
4.3.1. L'algorithme de clé commune
L'algorithme de clé commune est utilisé pour trouver la clé partagée entre deux nœuds, à
condition qu ' elle soit la première clé commune plus proche des feuilles, l' algorithme est
le suivant:
Nous avons choisi un réseau hétérogène [29] qui contient un petit nombre de capteurs de
haute gamme qui agissent comme leaders. Ces capteurs sont puissants et équipés de
matériel résistants [12]. Le réseau contient ainsi un grand nombre de nœuds capteurs de
bas de gamme qui forment des groupes autour des leaders.
Les capteurs qui sont de haute gamme reçoivent les messages des nœuds de bas gamme
dans le cluster, et les font suivre à la station de base. Dans ce qui suit, on appellera un
nœud bas de gamme un nœud normal.
La méthode de gestion de clés choisie est basée sur la cryptographie des courbes
elliptique, ou un serveur est utilisé pour produire les clés publiques ECC.
53
A vant le déploiement, chaque leader LD est pré-chargé par la même clé du réseau CR et
une clé unique CLR est utilisée pour la communication entre les leaders, et chaque nœud
normal ND est pré-chargé seulement avec la clé unique du réseau CR.
Après la sélection des groupes, chaque leader construit une liste de membres
(liste_Membre) se qui présente la liste des nœuds dans le c1uster. En fonction du nombre
de membres, il construit un arbre A VL formé des clés publiques, puis il remplace la clé
du réseau par la clé racine dans l' arbre AVL et il la diffuse. Le leader envoie à chaque
nœud dans le c1uster un message (chiffré avec la nouvelle clé) contenant la position du
nœud dans la liste des membres, puis un message contenant l' ensemble des clés qui se
trouvent le long du chemin du nœud à la racine de l'arbre A VL.
La figure 4.2, présente la structure de la gestion des clés basée sur l' arbre AVL.
... Hste_Membre
1 2 3 4 5 6 - -.-.. pOSitions des noeuds dans
la liste des noeuds du cluster
- - - - Noeuds
Figure 4.2. La structure de l'arbre AVL des clés ECC et la liste des nœuds.
54
Si deux nœuds veulent établir une liaison, ils s'échangent leur position dans la liste de
membres, et il calcule la clé secrète qui est composée de leur position et de la clé
commune qui a le niveau le plus loin de la racine dans l' arbre AVL.
Si un nœud veut établir une communication avec son leader, il utili se une clé composée
de la clé racine avec sa position dans la liste des membres.
Pour les leaders, puisqu ' ils sont équipés de matériels résistants, ils utilisent toujours la
même clé pré-chargée avant le déploiement.
La figure 4.3 montre des exemples de calcule des clés secrètes pour établir les liaisons
entre les différents nœuds.
E][eaap1e:
55
Quand un nouveau nœud demande son ajout dans le cluster, le leader le met dans la liste
des membres et il rafraîchit les clés correspondantes à sa position dans la liste de l' arbre
A VL, puis il renvoie à ce nœud sa position dans la liste des membres et son ensemble de
clés. Aussi, il envoie un message de rafraîchissement de clés à tous les nœuds dans le
cluster.
Si un nœud quitte le cluster, ou une fois que le leader détecte un nœud compromis, alors
il fait la mise àjour des clés publiques qui se trouvent le long du chemin de ce nœud à la
racine de l'arbre AVL et reconfigure l' arbre A VL.
4.5. Le scénario
Dans les pages suivantes, nous présentons les deux approches de notre méthode, les deux
approches utilisent un serveur KDC pour générer les clés ECC. Ces approches sont
appelées AVL_KDC et AVL_Leaders, dans AVL_KDC de control qui distribue les clés
est la station de base, et dans AVL_Leaders l'unité de control et le leader du cluster.
Le but d'avoir ces deux approches est réaliser deux scénarios qui peuvent se trouver dans
la réalité, et aussi on veut savoir après les expériences et les testes de la simulation,
laquelle de ces approches est plus avantageuse selon les données initiales et les besoins.
Comme dans [13], c' est un réseau hétérogène qui contient un petit nombre de nœuds
capteurs de haute gamme qui agissent comme leaders. Ces capteurs sont puissants et
équipés de matériel résistants [12]. Le réseau contient aussi un grand nombre de nœuds
capteurs de bas de gamme qui forment des groupes autour des leaders, comme c' est
présenté dans la figure 4.4.
56
Les capteurs de haute gamme reçoivent les messages des nœuds de bas gamme dans le
cluster, et les font suivre à la station de base.
Dans la suite du document, on appellera les nœuds de bas de gamme, des nœuds
normaux.
LD: Leader.
P : Clé publique.
CRL : Une paire de clés publique/privée, utilisée par les leaders pour communiquer entre
eux.
57
CR: Une paire de clés publique/privée, appelée clé du réseau, utilisée pour la
communication entre les capteurs normaux et les leaders.
CC : La clé du c1uster.
Ensemble_clés: Ensemble des clés publiques qui se trouvent le long du chemin allant du
nœud à la racine de l'arbre A VL.
Dans notre méthode de gestion des clés, la station de base est équipée d'un serveur KDC,
qui est utilisé pour produire les clés publiques ECC et les paires de clés CRL et CR.
Dans l'établissement des clés distribués A VL-leaders, l' unité de control qui maintient
l' arbre AVL est le leader du c1uster, le leader du c1uster prend la charge de gérer et de
stocker les clés ECC dans l'arbre AVL, il associe chaque nœud dans le cluster avec sa
position dans l' arbre AVL, et il prend la charge aussi de la distribution des clés ECC .
58
4.5.3.1. L'installation des Clés
• Chaque leader est pré-chargé par la même paire de clés publique/privée du réseau
CR et une clé unique CRL utilisée pour la communication entre les leaders dans le
réseau.
• Chaque leader LD est pré-chargé avec un ensemble de clés publiques.
• Chaque Nœud ND est pré-chargé de la même clé CR, et un identificateur unique
IDu. Ces informations sont utilisées pour l' authentification des émissions et
l' identification des messages échangés entre les capteurs.
• Chaque leader LD émet un message « join » crypté avec la clé du réseau CR,
pour créer son c1uster.
• Quand un nœud ND reçoit le premier message « join », il le décrypte avec la clé
CR, puis il renvoie au LD un message « joined » crypté avec CR utilisant son
ID.
• Après un certain temps, quand LD reçoit un message « joined » d' un nœud ND, il
le décrypte avec la clé CR.
• Ensuite, chaque LD produit une « Liste_Membre » contenant les ID des membres
dans le c1uster.
L' opération d' échange de clés entre chaque paire de nœuds NO u, NOv dans le cluster se
fait comme suit:
• Les nœuds NO u et NOv cherchent le point Puv qui est la clé publique commune,
qui se trouve au niveau le plus haut dans l' arbre AVL ( la plus proche des
feuilles).
• Les nœuds NDu et NOv calculent Xu(XvP uv) = XvCXuP uv ) qui constitue leur clé
secrète commune.
60
4.5.3.3. Ajoût d'un nouveau nœud
A vant le déploiement, chaque nouveau nœud est pré-chargé par son identification ID.
Après l'e déploiement d' un nouveau nœud, il demande son ajout dans le cluster, et il
fournit son ID.
Le leader LD met l' ID du nouveau nœud dans la liste des nœuds «Liste_Membre », et il
rafraîchit les clés correspondant à sa position dans l' arbre A VL, puis il renvoie à ce nœud
sa position dans la liste-Membre et son ensemble de clés. Aussi, il envoie un message de
rafraîchissement des clés à tous les nœuds du cluster.
Comme dans [9], l' opération de rafraîchissement des clés est la suivante:
Si une opération d' ajout d' un nouveau nœud est réussite, le leader envoie un message de
rafraîchissement des clés à tous les membres du groupe.
Une fois que les comportements anormaux d'un nœud sont détectés par le leader, ou une
fois qu' un nœud quitte le cluster, le leader fait la mise à jour des clés publiques et
reconfigure l' arbre AVL. Dans cette mise à jour les clés publiques qui se trouvent le long
du chemin du nœud (qui a quitté le cluster) à la racine de l'arbre AVL sont changées
(Comme dans [7]).
Dans cette approche, l' unité de contrôle est la station de base, qui est équipée d' un
serveur KDC, dans ce cas la station de base génère les clés ECC, elle gère l' arbre A VL
61
qui stocke toutes les clés du réseau, elle associe tous les nœuds normaux dans le réseau
avec leur position dans l' arbre AVL.
CR.
• Les nœuds NO u et NOv cherchent le point Puv qui est la clé publique commune,
qui se trouve au niveau le plus haut dans l' arbre AVL.
62
• Le nœud ND u envoie au noeud NOv la valeur X u et NDv envoie à ND u la valeur
Xv.
• ND u et ND v calculent Xu(XvPuv) = Xv(XuP uv ) qui constitue leur clé secrète
commune.
Avant d ' ajouter un nouveau nœud dans le réseau, le serveur KDC met l'ID du nouveau
nœud dans la liste des nœuds, et il rafraichit les clés correspondantes à sa position dans
l' arbre A VL.
Le nouveau nœud NOn est pré-chargé de son «Ensemble_clés », son identificateur IOn, et
de sa position MyX n.
Le serveur envoie à tous les leaders l' identificateur IOn du nouveau nœud et un message
de rafraichissement des clés.
Quand le nouveau nœud demande son ajout dans un c1uster, il envoie au leader du
c1uster son identificateur IOn et sa position MyX n.
Une fois les comportements anormaux d'un nœud sont détectés par un leader, ou une
fois qu ' un nœud quitte le réseau, le serveur fait la mise à jour des clés publiques qui se
trouvent le long du chemin du nœud (qui a quitté le c1uster) à la racine de l'arbre AVL et
il reconfigure l' arbre AVL. Ensuite, il envoie un message de mises à jour à tous les
leaders, et à son tour, chaque leader diffuse le message à tous les nœuds dans son c1uster.
63
4.5.5. Établissement d'une communication
Si deux nœuds veulent établir une liaison, ils échangent leurs positions dans la liste
« Liste_Membre», comme indiqué précédemment, puis pour crypter et décrypter les
messages échangés entre eux, ils utilisent la clé composée de la multiplication de la clé
partagée dans l'arbre AVL avec leurs positions dans la liste« Liste_Membre ».
Si un nœud NDu veut établir une communication avec son leader, ils cryptent et
décryptent les messages échangés utilisant une clé composée de la multiplication de la clé
racine dans l'arbre AVL avec MyX u la position du nœud NDu dans la liste
«Liste Membre».
Comme nous avons indiqué précédemment, tous les leaders sont équipés de matériels
résistants, et avant le déploiement du réseau, chaque leader est pré-chargé par la même
paire de clés CRL. Alors ils utilisent toujours la clé CRL publique pour crypter les
messages et la clé CLR privée pour décrypter les messages échangés.
4.6. Conclusions
Quand on étudie une méthode de gestion des clés, il est nécessaire de prendre en compte
la notion de robustesse de la méthode, de la consommation d'énergie et de la taille de la
mémoire utilisé.
64
• La robustesse est liée à la nature des clés de cryptage et la façon de distribution
des clés.
• La consommation d' énergie est lié au nombre de messages échangés durant
l' installation des clés, et le coût des opérations de calcul des clés secrètes
partagés.
• La taille de mémoire utilisée est liée à la taille de la clé et le nombre de clés
stockées.
La méthode que nous avons proposée vise à assurer une communication sûre, et réduire
le nombre de transmissions entre les nœuds durant l' installation des clés.
L' utilisation d'un système basée sur les courbes elliptiques assure robustesse avec une
utilisation de mémoire réduite.
En utilisant l' arbre AVL, la quantité de messages transmis entre l' unité de contrôle et les
nœuds est réduite. Et en utilisant cette technique, les nœuds voisins connaissent les clés
partagés, alors ils peuvent calculer leurs clés secrètes sans le besoin d' échanger ces clés
partagées, et par conséquence, cela réduit le nombre d' échanges.
65
CHAPITRE 5
LA SIMULATION
5.1. Introduction
En général, la simulation peut fournir une façon d'étudier des choix de conception de
système dans un environnement contrôlé, elle nous offre l' exploration des configurations
de système qui sont presque impossibles à construire physiquement et elle nous permet
l'observation des interactions qui sont difficiles dans le réel.
On a choisi le système Tinyos pour réaliser notre simulation. Tinyos est un système
d' exploitation open-source fonctionnant sous Unix. Il est adapté aux capteurs. Il supporte
de nombreuses plates-formes et il fournit des concepts très importants pour réaliser les
simulations.
5.2.1. Adaptabilité
Le simulateur doit être en mesure de manipuler les grands réseaux formés de milliers de
nœuds dans une large portée.
5.2.2. Perfection
66
5.2.3. Fidélité
Le simulateur doit révéler les interactions imprévues, non seulement ceux qu ' un
développeur suspecte.
Le simulateur doit remplir le fossé entre l'algorithme et la mise en œuvre, permettant aux
développeurs de tester et vérifier le code qui fonctionnera sur le matériel réel.
TOSSIM fonctionne sur un PC, cela permet aux utilisateurs de déboguer, tester et
analyser des algorithmes dans un environnement contrôlé et répétable.
L' objectif principal de TOSSIM est de fournir une simulation d'application Tinyos
fidèle. Pour cette raison, il simule l'ensemble des applications Tinyos plutôt que de
simuler le monde réel.
Comme tout simulateur, TOSSIM n'est pas toujours la solution de simulation parfaite, il
est utilisée pour comprendre les causes des comportements observés dans le
monde réel, mais il ne saisit pas tout, alors il ne doit pas être utilisé pour des
évaluations absolues.
TOSSIM ne modélise pas le temps d'exécution du CPU, aussi il ne peut pas fournir
facilement les informations précises pour calculer la consommation d'énergie du
processeur; alors cette tâche sera effectuer manuellement à partir du nombre de paquets
échangés durant l' installation des clés.
TOSSIM est une bibliothèque, pour cela il faut écrire un programme qui configure la
simulation et l'exécute. TOSSIM prend en charge deux interfaces de programmation:
67
Python et C + +, le langage Python permet d'interagir avec une simulation en cours, de
façon dynamique.
Le modèle de la radio de TOSSIM par défaut est une cellule unique sans erreur, tous les
nœuds écoutent parfaitement.
TOSSIM utilise la plate-forme MicaZ[21], c' est un appareil avec une faible puissance,
il se caractérise par:
Programmation NESC.
Nous nous intéressons dans notre simulation à la taille de la mémoire utilisée par un
nœud car c' est une contrainte principale nous nous intéressons aussi à la consommation
d'énergie par un nœud, vu que ce paramètre est relié à la durée de vie d' un nœud. En
effet, moins les nœuds dépensent l' énergie plus la durée de vie du nœud est longue. De
plus, nous portons une attention sur intéresse le nombre de paquets échangés entre les
nœuds pour établir les clés, plus la communication est grande plus la possibilité qu ' un
adversaire puisse modifier une clé pendant son parcours, est grande.
68
5.4. Les Paramètres
Pour nos simulations, nous avons utilisé un réseau qui est formé de 600 à 1000 nœuds de
type MicaZ. Parmi ces nœuds, 20 nœuds sont des nœuds leaders. Les nœuds sont répartis
uniformément et aléatoirement dans une zone de 1000 x 1000 m. La portée de
transmission d' un capteur est de 60 m, la taille d' un paquet est de 32 Octets, et le taux
d'erreur de transmission est zéro.
Le nombre moyen de voisins est calculé comme dans [13] par la formule suivante :
Pour évaluer la performance de notre méthode, nous nous intéressons aux métriques
suivantes:
• Le nombre total des paquets échangés dans le réseau durant l' installation des clés.
• La consommation d' énergie moyenne par un nœud normal et un nœud leader
• Le nombre de clés ECC stockées dans un nœud normal et un nœud leader.
69
La consommation d' énergie ne comprend que les énergies utilisées pour établir les clés
de cryptage, mais ne comprend pas les énergies dépensées pour les autres
communications de données, ainsi ne comprend pas l' énergie pour générer les clés dans
la méthode CECKM [28].
Comme nous avons vue dans le deuxième chapitre, Mohsen Guizani et des al. [13], ont
proposé une méthode basée sur le protocole du routage GPSR [35] avant l' installation les
clés ECC.
Ils ont implémenté les deux façons suivantes pour réaliser leur approche, l'une centralisée
RECC-CENT et l' autre distribuer RECC-DIST.
Dans les tableaux 5.1 et 5.2 nous avons calculé le nombre de clés stockées par chaque
leader et chaque nœud normal, dans toutes les deux approches de la méthode [13].
Soit:
Les tableaux 5.1 et 5.2 présentent le nombre de clés ECC stockées dans chaque type de
nœuds.
70
Nœud RECC-CENT RECC-DIST
Une clé ECC sous python à une taille de 40 bytes et la taille d'un paquet sous TOSSIM
est 28 bytes, alors pour transmettre une clé publique ECC, il faut diviser le message en 2
paquets. Une évaluation du nombre de paquets transmis et reçus dans le réseau, est
présentée dans le tableau 5.2 :
71
5.7. Conclusion
Dans ce chapitre nous avons présenté le simulateur utilisé dans notre recherche, et les
avantages qu ' il nous apporte, comme la modélisation de notre application dans un
environnement virtuel.
Nous avons donné les détails des paramètres de notre réseau et les métriques pour évaluer
la performance de notre méthode.
Dans le chapitre suivant nous allons présenter les différents résultats de notre simulation,
et la comparaison entre notre méthode et les méthodes CECKM et les deux approches de
la méthode RECC en détail.
72
CHAPITRE 6
RÉSULTATS
6.1. Introduction
Dans ce chapitre, nous présentons les résultats obtenus avec les simulations effectuées.
Au vue des données obtenus à partir du système de sortie de débogage de Tossim, nous
avons classé ces données dans des tableaux selon les types des nœuds et cela nous a
permis de calculer la consommation moyenne d' énergie par les nœuds et tracer les
courbes relatives à nos métriques, en fonction du nombre total de nœuds dans le réseau.
20 20 20 20 20
29 34 39 44 49
7 8 9 10 Il
73
Les paramètres du contexte de la simulation sont présentés dans le tableau 6.2:
Portée 60m
Type du paquet AM
Dans les opérations radio, la tension nécessaire est 3V [22]. À partir de cette information,
nous avons calculé l' énergie dépensée comme ce qui suit:
Les équations 1 à 5 montrent les méthodes utilisées pour calculer nos métriques:
74
• L'énergie consommée dans le réseau est:
o Nœud leader:
(~~~1 (NbTpackllt
~- .
.
R9C9lV9
d X 59,1) + (NbTpackiltsent X 52,2))
Le tableau 6.3 présente la hauteur de l'arbre AVL en fonction du nombre de nœuds dans
le cluster (dans le réseau pour l' approche AVL-KOC).
70
60
50
...ni
~ 40 -<>- AVL- Leaders
QI
' QI
~ AV L K DC
E
0 30
VI
C
...... CECKM
0
u
QI 20 -*"" RECC-CENT
'00
Qi ...... RECC-DIST
c la
' UJ
0 • • • • •
600 700 800 900 1000
Ta ille du réseau
77
La figure 6.2 montre la consommation d' énergie par un leader dans le réseau durant
l' installation des clés en fonction de la taille du réseau.
On remarque qu ' il est bien clair que dans la méthode RECC-CENT, le leader consomme
plus d ' énergie qu ' un leader dans les deux approches de notre méthode (AVL-KDC,
A VL-Leaders) et on observe aussi qu ' il y a un grand écart entre AVL-KDC et les autres
approches. Cette grande différence est dû au fait qu ' un leader dans AVL-KDC transmet
moins de paquets à tous les nœuds de son cluster, et dans l' approche AVL-Leaders, un
leader doit transmettre les clés publiques à tous les nœuds de son cluster, mais le nombre
de paquets transmis est moindre que dans la méthode RECC-DIST à partir du point 900,
car dans l' approche RECC-DIST, le nombre de transmissions de messages est relié à la
taille du cluster et du réseau et dans l' approche AVL-Leader, ce nombre est relié à la
hauteur de l'arbre AVL qui reste plus stable, même si la taille du cluster augmente.
On remarque aussi que dans l'approche CECKM, un leader consomme moins d' énergie
que dans AVL-Leaders, mais on a compté seulement l' énergie de la communication et on
n' a pas pris en compte l' énergie de calcule des clés ECC, et dans l'approche CECKM, un
leader à une échelle de calcul des clés ECC très grande par rapport à notre approche.
Cela montre que pour les nœuds leaders, notre approche AVL-KDC à une meilleure
efficacité énergétique que les autres approches. Ce rendement assure aux nœuds leaders
une durée de vie plus longue.
78
16.00
14.00
:::12.00
(Il ~ A VL-Leaders
~
,~10 . 00 _ AVLKO C
E _ CECKM
o
lË 8 .00 _ RE CC-CENT
8 ........ RE CC-OIST
.!!1 6 .00
~
C1l
c:
' .... 4 .00
2 .00
0 .00
600 700 800 900 1000
Taille du réseau
La figure 6.3 montre la consommation d' énergie par un nœud normal en fonction de la
taille du réseau.
Les courbes montrent qu ' un nœud dans la méthode CECKM dépense une quantité
énorme d ' énergie, comparativement avec les autres approches; et on observe aussi que
les nœuds normaux dans les deux approches RECC consomment plus d ' énergie que dans
notre méthode, cette différence est du au fait que dans notre méthode, les nœuds normaux
échangent moins de paquets que dans les autres méthodes.
On conclut donc, que nos deux approches garantissent à un nœud normal une vie plus
longue comparativement aux autres méthodes.
79
6.4.3 Comparaisons du nombre de clés stockées
Les nœuds de capteurs sans fil se caractérisent par une taille de mémoire très limitée, par
exemple, les nœuds MicaZ ont une mémoire RAM 4kOctets et une mémoire flash de
taille 512 Kbits, c' est une contrainte très importante et chaque clé ECC à une taille de 40
Octets.
Pour cela, nous nous intéressons au nombre de clés ECC stockées dans chaque type de
nœud, car la taille d' espace mémoire de stockage exploité est fortement reliée au nombre
de clés stockées .
40000
3 5000
~
'-'
3 0000
0
~ 25000
'0
Q.
as 20000
~
'0
0
600 700 800 900 1000
Taille du r éseau
La figure 6-4 montre la taille de la mémoire exploitée pour stocker les clés par un nœud
leader en fonction de la taille du réseau.
80
Il est bien clair que dans l' approche RECC-CENT, pour stocker les clés, un leader utilise
un espace mémoire très grand (plus que 23280 Octets), parce que le leader est pré-chargé
avec toutes les clés publiques de tous les nœuds du réseau. Les approches AVL-Leaders
et CECKM et RECC-DlST utilisent moins d' espace mémoire. L' espace utilisé varie entre
1280 et 2560 octets. L' approche AVL-KDC exploite un espace mémoire très limité, du
fait que le leader n' est pas chargé avec les clés des nœuds dans le cluster. C' est le serveur
KDC qui est le responsable de l' arbre AVL, ce qui offre au leader une économie de
mémoire de stockage.
On constate que dans notre approche un leader effectue une économie de stockage
comparée aux autres approches.
2500 . - - - - - - - - - - - - - - - - - - -
• AVL Leaders
• AVL-KD C
~ 2000 + - - - - - - - - - - - - - - --0-- . CECKM
o'" • RECC-CENT
~
'0 1500 • RECC-OIST
Q.
15
~
'0
E 1000 + -- r II--- --1 .-I--- --\:.,t-- -__.I--- -&_-
' <IJ
E
~
~ 500
o
600 700 800 900 1000
Taille du résea u
La figure 6.5 montre la taille de la mémoire exploitée pour stocker les clés par un nœud
normal en fonction de la taille du réseau.
81
On peut voir que dans CECKM, pour stocker les clés, un nœud normal utilise le plus
d' espace mémoire (plus que lKOctets), et un nœud dans l' approche AVL-Leaders utilise
le moins d' espace mémoire (moins que 250 octets). Dans la méthode RECC, le nombre
de clés stockées est relié au nombre de voisins et à la taille du réseau et c'est la raison
pour laquelle on remarque qu'à partir d' une taille de 700 nœuds et plus, les approches
RECC utilisent plus d' espace mémoire que dans l' approche AVL-KDC.
L' approche AVL-Leaders proposée offre des économies de stockage comparé aux autres
approches et notre approche AVL-KDC économise plus d' espace que les deux approches
RECC dans les réseaux de grande taille. Du fait que le nombre des clés stockées est relié
à la hauteur de l' arbre AVL comme il est présenté dans la figure 6.6, cette hauteur est
plus petite dans l' approche AVL-Leaders que dans l' approche AVL-KDC. Cependant,
dans la méthode RECC, le nombre des clés stockées est relié au nombre de voisins et
dans la méthode CECKM, le nombre des clés stockées est relié au nombre de nœuds du
cluster.
11
10
9 .
.... 8
> 7
'l!!"
.Q
"-
6
....
IV
QI
5 • AVL Leaders
"0 4
..2
• AVL·KOC
3
'"
IV
:%:
2 -
~ 1
0
600 700 800 900 1000
Taille du réseau
Il est clair que la hauteur de l' arbre AVL dans l' approche AVL-Leaders est plus petite
que la taille de l' arbre AVL dans l' approche AVL-KDC, parce que cette hauteur est reliée
au nombre des identificateurs des nœuds dans la liste « Liste_Membre », et cette hauteur
est presque proportionnel à log(NbrNouedCluster) dans l' approche AVL-KDC et à
log(NbrNouedN) dans l' approche AVL-Leaders.
Une multiplication de deux clés ECC prend 282 octets de mémoire [19] et dans [20] selon
la méthode Row-Wise, la taille de mémoire utilisée pour faire une multiplication d' un
2
entier avec un entier de taille n, les mots prennent n +3n octets de mémoire.
Pour calculer la clé secrète entre deux nœuds normaux avec la méthode CECKM et la
méthode RECC-DIST, les nœuds calculent la multiplication de leurs clés échangées. Une
telle opération demande 282 Octets de RAM [30], mais avec notre méthode, les nœuds
calculent la multiplication de leurs positions avec la clé partagée dans l' arbre AVL. Ces
opérations nécessitent un maximum de 43 Octets de RAM [16].
Dans l' approche RECC-CENT, le leader calcule les clés secrètes de chaque nœud. Si un
nœud à 7 voisins, il utilise 7*282 octets soit 1974 Octets de RAM, qui est une taille très
importante. Si on utilise un nœud TELOSB [20] qui a une RAM de 10 KOctets
(TELOSB est le plus puissant), la mémoire nécessaire pour calculer les clés secrets est au
83
minimum 19% de la taille total de la RAM . Mais, notre méthode utilise seulement 0,4%
de la taille de la RAM .
3000
......
<li
u
2500
0
:E
~ 2000
~
.5
E
-<li 1500
E
<li
u
'"
Q. 1000
'"
UJ
500
0
600 700 800 900 1000
Taill e du réseau
Figure 6.7. Utilisation de la mémoire RAM pour calculer une clé partagé entre deux
nœuds normaux.
La figure 6.7 présente la taille de la mémoire utilisée pour calculer une clé partagée entre
deux nœuds normaux en fonction de la taille du réseau.
Avec notre méthode, pour calculer la clé secrète entre un leader et un nœud normal du
cluster, la clé secrète est égale à la multiplication de la position du nœud dans la
84
« liste Membre » avec la clé racine de l' arbre AVL. Cette opération demande au
maximum 18 octets de RAM, alors que dans la méthode CECKM un nœud normal doit
faire l'opération de multiplication de toutes les clés publiques de tous les autres nœuds
dans le cluster. Pour un nœud MicaZ, avec une RAM de 4 KOctets, il est impossible de
faire une telle opération, car avec 4 octets, on peut supporter au maximum 14
multiplications de clés. Ainsi, pour un leader, si on utilise TELOSB qui a une RAM de
IOKoctets, il ne peut pas calculer la clé secrète si la taille du c1uster dépasse 32 nœuds.
La figure 6.8 présente la taille de la mémoire utilisée pour calculer une clé partagée entre
un nœud normal et un leader en fonction de la taille du réseau.
13818
• 18 • 18 • 18 • 18 • 18
600 700 800 900 1000
Taill e du réseau
Figure 6.8. Utilisation de la mémoire RAM pour calculer une clé partagé entre un nœud
et un leader
85
Notre méthode prouve que quelque soit la taille du réseau, soit pour un nœud normal ou
un nœud leader, il est toujours possible de calculer les clés secrets et cette opération est
légère et ne cause aucun problème contrairement aux autres méthodes.
Dans notre méthode, quand un nœud normal quitte le réseau, les clés publiques qui se
trouvent le long du chemin du nœud vers la racine de l'arbre A VL seront changées et
propagées aux nœuds dans le c1uster.
Dans la méthode RECC, quand un nœud normal quitte le réseau, le leader du c1uster
dissémine un message de révocation des clés contenant l'identité du nœud compromis. En
recevant le message de révocation, un nœud normal vérifie s'il communique avec le nœud
compromis, s'il en est, le nœud normal révoque la clé partagée entre eux.
Dans l'approche RECC-DIST, il n'y a pas de méthode pour la mise à jour, alors, si un
nœud est compromis, l'adversaire peut calculer les clés secrètes de tous les voisins car le
nœud compromis stocke toutes les clés des ces voisin. D' un autre point de vue, comme
cette méthode est basée sur l'arbre du routage, quand un nœud normal quitte le réseau, il
cause une modification dans l' arbre de cheminement. Cette dernière exige la rediffusion
de l'arborescence de cheminement et le recalcul des clés secrètes. La complexité de cette
tache est reliée à l' importance de la position du nœud dans le réseau.
Dans la méthode CECKM, il n y a pas une méthode pour la mise à jour, mais on suppose
qu'il faut faire une nouvelle installation des clés au niveau du c1uster, car le nœud
compromet toutes les clés publiques de tous les nœuds dans le c1uster.
86
7000
6000
....
....ro 5000
~
Q)
' Q)
4000
E ~ A V L-Lea d e rs
0
<.Il
C
3000 _ AVL-KDC
0
U
Q)
2000 ...... CECKM
'00
....
Q)
c
'W 1000
0
600 700 800 900 1000
Tai lle du résea u
La figure 6.9 présente la consommation d' énergie durant la mise à jour des clés de
cryptage pour chaque méthode.
Les courbes montrent que notre approche A VL-Leaders échange moins de paquets.
Cependant la méthode CECKM utilise un nombre de paquets très grand, soit 6 fois plus
qu 'A VL-KDC et plus 10 foi s plus qu 'A VL-Leaders.
Notre méthode présente une communication plus petite dû au fait qu ' elle échangent
moins de paquets. Elles demandent une transmission plus courte que la méthode
CECKM. Ceci garantie un temps de mise à jour des clés plus court, par conséquent,
moins d' énergie consommée.
87
6.6. L'ajout d'un nouveau nœud
Dans la méthode RECC-CENT, les nœuds leaders ne sont pas pré-chargés par des clés
supplémentaires pour autoriser l'ajout d'un nouveau nœud, et dans RECC-DIST, un
nœud leader n' a le moyen d'ajouter qu ' un seul nouveau nœud; mais la procédure
d'ajouter un nouveau nœud n' existe pas, aussi il n'y a pas de rafraîchissement des clés.
S' il y a lieu d'ajouter un nouveau nœud dans le réseau, cela causera une modification
dans l' arbre de routage et le recalcul des clés secrètes.
Aussi, dans la méthode CECKM, il n'y a pas une méthode pour ajouter un nouveau
nœud. Mais on suppose que cela demande un échange de clés publiques entre le nouveau
nœud et les autres nœuds du cluster et chaque nœud doit recalculer la clé partagée avec le
leader et cela demande plus de communication et plus d'énergie.
Dans notre méthode à l' ajout d' un nouveau nœud, le leader envoie un message de
rafraîchissement des clés à tous les nœuds du cluster.
La figure 6.10 présente le nombre de paquets échangés durant l' ajout d'un nouveau
nœud pour chaque méthode.
Les courbes montrent que notre approche AVL-KDC échange moins de paquets.
Cependant la méthode CECKM utilise un nombre de paquets très grand. Toutefois notre
approche A VL-Leaders échange un nombre de paquets plus grand que AVL-KDC mais
beaucoup moins que l'approche CECKM.
Cela montre encore que notre méthode présente moins d' échanges pour ajouter un
nouveau nœud dans le réseau, et elles demandent une transmission plus courte que la
méthode CECKM.
88
160
140
CI)
-<1) 120
..
C)
c:
ca
.s:::.
0
-<1)
-CI)
Q)
:::1
80 +
Ta ille du réseau
Dans les deux approches RECC, après le déploiement, les nœuds dans le réseau évaluent
leur position dans le réseau et calculent la table de routage. Toutes ces applications
demandent beaucoup de communications entre les nœuds et plus de temps avant
d' installer les clés de cryptage, et cela met le réseau en péril, car un adversaire peut
s' introduire dans le réseau comme un nœud normal.
Aussi, dans la méthode CECKM, les clés échangées entre les nœuds et les leaders ne sont
pas chiffrées, ce qui permet à l' adversaire de capter une clé et la modifier.
89
Par contre, dans notre méthode, avant le déploiement, tous les nœuds sont pré-chargés
avec une clé du réseau, et après la création des c1usters, chaque c1uster à sa propre clé, et
toutes les communications à partir du déploiement sont chiffrées. Cela ne donne aucune
chance à un adversaire pour changer les clés.
Dans la méthode RECC-DIST, quand un nœud est compromis, les nœuds révoquent
seulement la clé partagée. L' adversaire peut obtenir les clés publiques des voisins et
calculer les clés secrètes. Dans ce cas, il peut jouer le rôle des autres nœuds qui ont
partagé les clés secrètes calculées par l' adversaire.
Dans notre approche, chaque nœud stocke un ensemble de clés publiques, et si un nœud
est compromis, alors toutes les clés partagées avec les autres nœuds seront changées, et
dans cette façon l' adversaire ne pourra pas échanger avec les autres nœuds.
Notre méthode assure et garantie une sécurité plus importante qui couvre tout le réseau,
une fois que, les nœuds sont déployés.
6.8. Conclusion
Dans ce chapitre, nous avons présenté les résultats obtenus avec les simulations
effectuées. Le système d' exploitation utilisé est Tynios , et la plate-forme est Tossim.
Nous avons constaté que notre approche génère moins de paquets ce qui fait que le
réseau consomme moins d' énergie, et nous avons observé que notre approche est plus
légère car elle utilise moins d' espace mémoire que les autres méthodes.
90
Dans le chapitre suivant, nous allons présenter la conclusion de la recherche que nous
avons amorcée dans le cadre de ce travail.
91
CHAPITRE 7
CONCLUSION
Dans ce mémoire, nous avons proposé un protocole de sécurité les réseaux de capteurs
qui offre une bonne protection, en prenant en compte les caractéristiques limitées des
capteurs qui influencent directement la performance globale du réseau, en particulier la
sécurité et la durée de vie.
Le protocole de gestion des clés est conçu pour les réseaux de capteurs sans fil
hétérogènes avec un déploiement à grande échelle.
L' approche nécessite un serveur qui génère les clés de courbes elliptiques ECC, et un
arbre AVL pour stocker les clés du réseau .
Les clés utilisées sont des clés de 160 bits, ces clés assurent le même niveau de sécurité
des clés RSA de 1024 bits.
La gestion de clés se fait soit au niveau global du réseau, et dans ce cas, le serveur
construit l' arbre AVL et stocke toutes les clés du réseau, ou au niveau régional où chaque
leader prend la charge de l' arbre A VL et stocke les clés de son cluster.
Chaque nœud est associé à une feuille de l' arbre, et il stocke seulement les clés se
trouvant le long du chemin du nœud à la racine de l'arbre AVL. Cela permet une
réduction significative du stockage et réduit énormément la communication et le calcul,
ce qui offre une meilleure sécurité.
Nous avons aussi développé une simulation qui réalise l' implémentation de notre
méthode; et afin de démontrer l' efficacité de cette méthode nous avons fait quelques tests
et nous les avons comparés avec RECC "A Routing-Driven Elliptic Curve Cryptography
Based Key Management Scheme for Heterogeneous Sensor Networks" et CECKM
92
"High-Effect Key Management Associated With Secure Data Transmission Approaches
in Sensor Networks Using a Hierarchical-based Cluster Elliptic Curve Key Agreement",
deux méthodes basées sur la méthode de Cryptographie de Courbe Elliptique Diffie-
Hellman.
Pour conclure, nous pourrons dire que notre approche permet un gain significatif de la
mémoire de stockage et une réduction énorme des paquets échangés lors de l' installation
des clés avec un moins de calculs, tout en garantissant une meilleure sécurité.
93
PERSEPECTIVE
Malgré que l' apprentissage du simulateur Tossim m' a pris un grand temps, je le
recommande aux futurs développeurs de simulations sur les réseaux de capteurs sans fil,
car il est possible ajouter facilement des modèles, et il nous permet de changer les
paramètres de configuration du réseau, ce qui le rend plus intéressants à utiliser.
Le présent travail peut être enrichi par l' ajout de la fonctionnalité de «La signature
numérique».
Cet aspect est très important pour la sécurité dans les réseaux de capteurs sans fil, sa mise
en place devrait se faire durant le déploiement, la création des groupes et l' installation
des clés, car dans tout ce temps les nœuds dans le réseau échangent les messages utilisant
des clés publiques pour crypter les messages.
L' idée est donc, d' implémenter une méthode qui permet le calcule d' une signature d' un
message à l' aide des clés ECC utilisées dans notre méthode.
Comme notre protocole est conçu dans le but de réduire la consommation de l'énergie,
alléger la taille du stockage, minimiser le calcul et tout en maximisant les performances
de la sécurité; la méthode de la signature doit être gérée du même comportement pour
assurer au réseau de capteur sans fil une longue vie avec une meilleur sécurité.
Dans notre méthode proposée, la façon de supprimer ou d' ajouter un nœud dans le réseau
était simple, on n' a pas inclue le facteur de la mobilité du réseau, et on n' a pas étudié les
94
effets de la vitesse de cette mobilité sur le nombre d' échanges des messages et par
conséquence la consommation d' énergie.
Alors la méthode de mise à jour clé peut être encore améliorée, avec une étude plus
poussées sur des techniques d' encryptions et de mise à jour clé, ces techniques doivent
réduire la quantité de clés transmises lors du départ d' un nœud, tout en garantissant une
meilleure sécurité.
95
BIBLIOGRAPHIE
[1] Laurent Eschenauer, Virgil D. G1igor, " A Key-Management Scheme for Distributed
Sensor Networks", CCS '02 Proceedings ofthe 9th ACM conference on Computer
and communications security, ACM New York, NY, USA , 2002.
[2] W. Du, 1. Deng, Y. S. Han, S. Chen et P. K. Varshney, "A key management scheme
for wireless sensor networks using deployment knowledge", 23rd Annual Joint
Conference ofthe IEEE Computer and Communications Societies (INFOCOM 2004)
Atlanta, GA, USA, ISBN 0-7803-8355-9, November 2004 .
[3] C.Castelluccia and Angelo Spognardi, " RoK: A robust key pre-distribution protocol
for multi-stage Wireless Sensor Networks", IEEE Securecomm, Nice, France,
September 2007.
[4] Donggang Liu, Peng Ning, "Establishing Pairwise Keys in Distributed Sensor
Networks", Journal of ACM, October 27-31 , 2003 , Washington, DC, USA.
[5] R. Di Pietro, L. V. Mancini et A. Mei, "Efficient and Resilient Key Discovery Based
on Pseudo-Random Key Pre-Deployment, " in 18th International Parallel and
Distributed Processing Symposium (IPDPS'04), p. 217, 2004.
[6] P.Samundiswary, Padma priyadarshini et P. Dananjayan, " Performance Evaluation of
Heterogeneous Sensor Networks", International Conference on Future Computer and
Communication, ISBN 978-0-7695-3591-3 , ICFCC, 2009.
[7] Quazi Ehsanul Kabir Mamun, et Sita Ramakrishnan, " SecCOSEn - A Key
Management Scheme for Securing Chain Oriented Sensor Networks ",
Communication Networks and Services Research Conference (CNSR 2008), ISBN
978-0-7695-3135-9, May 2008 .
[8] A.S.Poornima, B.B.Amberker, "Tree-based Key Management Scheme for
Heterogeneous Sensor Networks", 16th IEEE International Conference, ICON 2008,
ISBN 978-1-4244-3805-1 , NewDelhi, 2008 .
96
[9] Yi-Ying Zhang, Wen-Çheng Yang, Kee-Bum Kim, Myong-Soon Park, "An AVL
Tree-Based Dynamic Key Management in Hierarchical Wireless Sensor Network ",
International Conference on Intelligent Information Hiding and Multimedia Signal
Processing, ISBN 978-0-7695-3278-3 , August 2008.
[10] A VL Tree in : Dictionnaires et Encyclopédies sur Academic,
http://fr.academic.ru/dic.nsf/frwiki/ 124260.
[11] E.Munivel, Dr G M Ajit, " Efficient Public Key Infrastructure Implementation in
Wireless Sensor Networks ", International conference on Wireless Communication
and Sensor Computing, ISBN 978-1-4244-5136-4, February 2010.
[12] O.Arazil, H.Qi, D.Rosel , "A Public Key Cryptographic Method for Deniai of
Service Mitigation in Wireless Sensor Networks ", 4th Annual IEEE Communications
Society, Conference on Sensor, Mesh and Ad Hoc Communications and Networks,
ISBN 1-4244-1268-4 , San Diego, CA , August 2007 .
[13] Xiaojiang Du, Mohsen Guizani, Yang Xiao, and Hsiao-Hwa Chen, "A Routing-
Driven Elliptic Curve Cryptography Based Key Management Scheme for
Heterogeneous Sensor Networks", IEEE International Conference
on Communications, ICC 2007, ISBN 1-4244-0353-7 , Glasgow, August 2007 .
[14] Hua-Yi Lin, " High-Effect Key Management Associated With Secure Data
Transmission Approaches in Sensor Networks Using a Hierarchical-based Cluster
Elliptic Curve Key Agreement", ncm, pp.308-314, Fifth International Joint
Conference on !NC, IMS and IDC, ISBN 978-0-7695-3769-6, Seoul, Korea, 2009.
[15] Marc Joye, " Introduction élémentaire à la théorie des courbes elliptiques, UCL
Crypto Group Technical Report Series ", book in : http://www.dice.ucl.ac.be/crypto/.
GC-19951l , pages (17) (73) (29-52).
[16] A.Boukerche, H.A.B.F.Oliver,E.F.Nakamura and A.A.F.Loureiro.A Voronoi , "
Vehuculer ad-hoc networks-A new callenge for localization" ,Elsevier Computer
Communications, 2008.
97
[17] Implementing A VL Trees in:
http: //www.lri.fr/~fiorenzirreaching/Cours_Ing2000/arbravl_7.pdf.
[18] M.1. Handy, M. Haase, D. Timmermann, " Low Energy Adaptive Clustering
Hierarchy with Deterministic Cluster-Head Selection", Fourth IEEE Conference on
Mobile and Wireless Communications Networks, Stockholm, erschienen in
Proceedings, S. 368-372, ISBN 0-7803-7606-4, World Scientific Publishing Co. Pte.
Ltd., September 2002.
[19] Arvinderpa.S.W, Nils Gura, Hans Eberl, Vipul Gupta, Sheuuling Chang Shantz, "
Energy analyses of public key cryptography for wireless sensor networks ", Third
IEEE International Conference on Pervasive Computing and Communications,
(PerCom'05), ISBN 0-7695-2299-8m, Kauai Island, Hawaii, 2005, page (5).
[20] Nils Gura, Arun Patel, Arvinderpal Wander, Hans Eberle, Sheueling Chang
Shantz, " Comparing Elliptic Curve Cryptography and RSA on 8-bit CPUs ", in the
book" Cryptographie Hardware and Embedded Systems - CHES 2004, 6th
International Workshop Cambridge, MA, USA, August 11-13, 2004 ", ISBN 978-3-
540-22666-6, Chaptre(4), page (8), Springer Berlin / Heidelberg, July 08, 2004.
[21] TELOSB mote platform in: http://www.memsic.com/products/wireless-sensor-
networks/wireless-modules.html.
[22] Garci , a, E.M., Bermu , dez, A., Casado, R. , " Range-free localization for air-
dropped WSNs by filtering node estimation improvements ", 6th International
Conference on Wireless and Mobile Computing, Networking and Communications
(WiMob), 2010 IEEE , E-ISBN : 978-1-4244-7741-8 , November 2010.
[23] Mikhaylov, Konstantin Tervonen," Wireless Pervasive Computing (ISWPC)",
5th IEEE International Symposium, E-ISBN: 978-1-4244-6857-7, June 2010.
[24] Yong-Min, LiuXin-Hua Jiang, "A Protocol Model for Wireless Sensor Network",
Proceedings of the 2009 International Conference on Networks Security, Wireless
Communications and Trusted Computing, ISBN: 978-0-7695-3610-1 , 2009.
98
[25] S. Duquesne, " Cryptographie sur les courbes elliptiques ", avril 2005, dans:
http://www.lirmm.fr/~eic2005 /EJC PDF /notes.pdf
[26] Claude Castelluccia et Aurélien Francillon, "Protéger les réseaux de capteurs sans
fil", 2008, dans:
http://actes.sstic.org/SSTIC08/Proteger_Reseaux_Capteurs_Sans_Fi I/SSTIC08-
article-Castelluccia_Francillon-Proteger_Reseaux_Capteurs_Sans_Fil.pdf.
[27] Chung Kei Wong, M.Gouda, S. Lam, "Secure Group Communication Using key
Graphs", IEEE/ACM Transactions on Networking, ISSN: 1063-6692, Feb 2000.
[28] Christophe Giraud, "Attaques de crypto systèmes embarques et contre-mesures
associées", THESE présentée et soutenue publiquement le 26 octobre 2007, A l' Ecole
Normale Supérieure, Université de Versailles Saint-Quentin, Paris, dans:
http://www.prism.uvsq.fr/fi leadm in/CR YPTOlTheseCG-new .pd f
[29] Geng Hao, N. V. Vinodchandran, Byrav Ramamurthy, "A Balanced Key Tree
Approach for Dynamic Secure Group Communication", Proceedings 14th
International Conference on Computer Communications and Networks, ISBN: 0-
7803-9428-3, 2005.
[30] N.Bulusu, J.Heideman,D.Estrin et T.Tran, "Self-configuring localisation
system :Design and experimental evaluation", Journal: ACM Transactions on
Embedded Computing Systems (TECS), Volume 3 Issue 1, February 2004.
[31] Haowen Chan, Adrian Perrig , et Dawn Song, " Random Key Predistribution
Schemes for Sensor Networks", SP '03 Proceedings of the 2003 IEEE Symposium on
Security and Privacy, ISBN:0-7695-1940-7, 2003.
[32] Cryptographie sur les courbes elliptiques dans:
http://fr.wikipedia.org/wiki/Cryptographie sur les courbes elliptiques.
[33] Les courbes elliptiques dans : public.enst-bretagne.fr/~saouter/Elliptique.ppt.
[34] Les arbres A VL dans :
http://www.seg.etsmtl.ca/FHenrilinfl45/Suppléments/arbres%20AVL.htm.
99
[35] Brad Karp , H. T. Kung, " GPSR: Greedy Perimeter Stateless Routing for
Wireless Networks", Proceeding MobiCom '00 Proceedings of the 6th annual
international conference on Mobile computing and networking, ISBN :1-581 13-197-6,
2000.
[36] R. Cristescu et B. Beferull-Lozano, "Lossy network correlated data gathering with
high-resolution coding," in Proc. IEEE IPSN 2005 .
[37] P. Szczechowiak, L. B. Oliveira, M. Scott, M. Collier, et R.Dahab, "NanoECC:
Testing the Limits ofElliptic Curve Cryptography in Sensor Networks", European
conference on Wireless Sensor Networks, LNCS, vol. 4913 . pp. 305-320, Feb.2008.
[38] lean-Paul Quelen," Petit théorème de Fermat et codage RSA ", dans:
http://jpq.pagesperso-orange. fr/d ivers/rsa/rsa.pdf
100
ANNEXE 1: PROJET DE SIMULATION
Le projet utilisé pour les simulations se trouve dans le répertoire PROJET sur le DVD.
ANNEXE 2: COMMUNICATION
ANNEXE 3: PUBLICATION
101
• Les réseaux de capteur sans fil sont composés de
centaines ou de milliers de petits nœuds de capteurs
déployés dans une zone géographique.
• Les nœuds ont des ressources de calcul, de
stockage, de communication et d'énergie très
limitées.
• Ces réseaux ont beaucoup d'applications dans les
domaines militaire et civil, ces applications ont
souvent besoin d'un niveau de sécurité élevé.
Objectif
• Notre travail consiste à définir un protocole de
sécurité qui permet d'assurer une bonne protection
des données en prenant en compte les
caractéristigues limitées des ca(?teu_
rs~.~__
Communication
Satellite ......
--
. iJ Slalloo de"...
--- BASE
STATION
Observation Surveillance Control d'infrastructure Réseau du transport Industrie intelligente Surveillance méd/cala,
environnemental des bata/Iles
• Notre méthode comprend deux approches AVl-
leaders et AVl-KDC.
• Les deux approches sont basées sur la combinaison
et l'amélioration de deux méthodes déjà proposées
par la communauté scientifique:
1Dn1 ListeJMembres
\
1 2 3 4 5 8 ••• •••
l
Chaque nœud est pré-chargé de sa position dans
",.
~.' . .
.J>.
'. J
la liste Uste_Membres et les clés se trouvant le long la même paire de clés publique/privée
du chemin du nœud è la racine de rarbre AVL. et la clé la racine de l'arbre AVL
Création des Clusters
.;... ,'-.-
..
~;;i. _ )
. -.
J (((MyXn
Durant la création des clusters, les nœuds et les leaders cryptent
et décryptent les messages échangés avec la clé r:acine de l'arbre AVL.
.;
~:
.. Ii
- ....
... • ..~
--.'
Chaque noeud dans le cluster envoie à son
leader sa position dans la liste Liste_Membres.
Il.1.b. L'approche AVL-Leaders
Chaque leader est pré-chargé d'un ensemble de clés
Un serveur KDC est utilisé pour ~t:===~... et de la même paire de clés publique/privée
et la même clé du réseau _
J
produire les clés d'ECC. ;' . i • ,"
.; ..
~~- --. ,
, ...-
-~
J
.; . ' . ~_.
j
';;"-- '
Avant le . -- -
déploiement Chaque nœud de capteur est pré-chargé
de la même clé du réseau.
Leader
~ ~
G
-- nlm.
~J-w,;; T n;~~;--l u/~~~ ln~~~~ r n/~~~ ~L.is}e_
1 2 3 4 5 6 ...
-- - - Après la creation
Le leader envoie à chaque nœud dans le cluster sa position des clusters
dans la liste liste_Membres et les clés se trouvant
le long du chemin du nœud à la racine de l'arbre AVL.
Les clés de chiffrement utilisées pour protéger
les messages échangés sont les suivantes:
Entre les leaders . . , 1Entre un noeud et son leader
»)) )
((<
Les messages échangés entre les leaders
La clé secrète est la multiplication de la clé
sont cryptés avec la clé publique
racine de l'arbre AVL et sa position dans
et décryptés avec la clé privée. la liste Liste_membres.
100
j
8: 80 ~
• AVL-Leaders
~
~
• AVL-KI:X:
~
!60 RECCCENT
~ ~
• RECC-DIST
40
... -~- 1-. CECKM
20
-- . ....
o
r : .;. · ·
600 700 800 900 1000 Noeuds
Taille du réseau
1~ ~
~
~
~ ~
~
0
~~
9
~
+ f + ]
ec §,...
c
::s
ca
... ~
CD
~
Si
~-ëI
,..
.9
ca ~
~
Q
~
fi)
R
â
u
~
co \C ~
li 2000 TI- - - - - - - - - - - - . - . - - - - -
8 • AVL-Leadem
.G 1500 AVL-KDC
j CECKM
~ 1000 .....----1 RECC-CENT
~ • RECC-DIST
5oo40I-~
o
600 700 800 900 1000 noeuds
Taille du réseau
~
j 8C'f'\
1
:.1
u ~
~
Q
1
s .JI
1...
.~
.sa
~ ~
'0
1 ~
~ -8
~
1:1
~
~
.; 8 ~
i """-
1
t
~
~
• Les courbes montrent que les deux approches de
notre méthode génèrent moins de paquets et utilisent
moins de mémoire que les autres méthodes. Ce qui
fait que les nœuds consomment moins d'énergie.
Cela garanti à un nœud une vie plus longue.
• On observe que notre ·proposition est plus légère,
elle utilise moins de clés partagées et économise
l'espace de stockage des clés.
Analyse de sécurité
• Dans la méthode CECKM, les clés échangées entre
les nœuds et les leaders ne sont pas chiffrées, ce qui
permet à un adversaire de capter une clé et la modifier.
• La méthode RE CC exige le calcul de l'arbre du routage
avant l'installation des clés, cela demandent beaucoup
de communications non chiffrées, qui met en péril le
,
reseau.
• Par contre, notre méthode assure et garantie une
sécurité plus importante qui couvre le réseau une fois
que les nœuds sont déployés.
• Nous avons présenté un protocole de gestion des clés
efficace pour les réseaux de capteur sans fil
hétérogènes avec un déploiement à grande échelle.
• Notre proposition nécessite un serveur qui génère les
clés ECC, et un arbre AVL pour stocker les clés du
,
reseau.
• Chaque nœud est associé à une feuille de l'arbre, et il
stocke seulement les clés se trouvant le long du
chemin du nœud à la racine de l'arbre AVL. Cela
permet une réduction significative du stockage et réduit
énormément la communication et le calcul en offrant
en même temps une meilleure sécurité.
Remerciement.
-À mon directeur Boucif Amar Bensaber pour son suivi et son encadrement, au professeur Alain Goupil pour son aide et aux
deux chargés de projets Guy Therrien et Daniel Saint Yves pour leurs soutiens techniques.
RéAlTenee.
1. S. Duquesne, Ecole Jeunes Cherceurs, Cryptographie sur les courbes elliptiques, 5 avril 2005,
http://www.lirmm.fr/-eic2005/EJC PDF/notes.pdf
2. http://www.seg.etsmtl.ca/FHenri/inf145/Suppléments/arbres%20AVL.html
3. Xiaojiang Du, Mohsen Guizani, Yang Xiao, and Hsiao-Hwa Chen, A Routing-Driven Elliptic Curve Cryptography Based Key
Management Scheme for Heterogeneous Sensor Networks, IEEE 2009.
4. Hua-Yi Lin, High-Effect Key Management Associated With Secure Data Transmission Approaches in Sensor Networks Using
a Hierarchical-based Cluster Elliptic Curve Key Agreement, Department of Information Management, China University of
Technology, Taiwan, R.O.C.
A keys management method based on an AVL tree and
ECC cryptography for wireless sensor networks
Hayette Boumerzoug Boucif Amar Ben Sa ber Ismail Biskri
Laboratoire de Mathématiques et Laboratoire de Mathématiques et Laboratoire de Mathématiques et
Informatique appliquées LAMIA Informatique appliquées LAMIA Informatique appliquées LAMIA
Department of Mathematics and Department of Mathematics and Department of Mathematics and
Computer Science Computer Science Computer Science
University of Quebec at Trois-Rivières, University of Quebec at Trois-Rivières, University of Quebec at Trois-Rivières,
Canada Canada Canada
3351 Bd des Forges, C.P 500 3351 Bd des Forges, C.P 500 3351 Bd des Forges, C.P 500
[email protected] [email protected] Ismail. [email protected]
ABSTRACT applications.
ln this paper; we propose a security protocol for sensor networks ln many applications, the establishment of encryption keys must
that provides good protection while taking into account the be done once the sensor nodes are deployed. This is the case when
limited resources of the sensors. The protocol is based on an a large number of sensors are deployed randomly, for example,
effective key management method with a minimum storage of from a helicopter. Each node must establish a secret key with each
keys. Our approach is based on the combination and improvement of its neighbors but its neighbors are not known before the
of two methods already proposed by the research community: deployment. The keys exchange should take place as soon as the
cryptography based on elliptic curves and key management based deployment starts.
on an AVL tree. Compared with RECC "A Rouling-Driven
Elliptic Curve Cryptography Based Key Management Scheme for 2. STATEOFTHEART
Heterogeneous Sensor Networks" and CECKM "High-Effect Key Various solutions have been presented in the literature. Often,
Management Associated With Secure Data Transmission they use dynamic methods recommending the updaling of the
Approaches in Sensor Networks Using a Hierarchical-based keys to provide resistance against attacks for an extended period.
Cluster Elliplic Curve Key Agreement" two methods based on
Diffie-Hellman elliptic curve cryptography method, our approach ln 2002, Eschenauer and Gligor proposed a probabilistic protocol
provides a positive impact on reducing energy consumption and [1], in this protocol the network administrator creates a table of L
memory storage. It saves significant time and memory and it random keys, and each node is pre-Ioaded with a subset ofM keys
reduces the exchanged packets during keys installation with fewer randomly chosen from the created keys before. When two nodes,
processing operations. A and B want to establish a secret key, they exchange their keys'
indexes, and then they use their common keys to generate a secret.
General Terms ln this protocol, it is always possible that anode other than A and
Security B knows the shared keys between A and B, and then he can
compute the secret that A and B have just established. However,
Keywords Eschenauer and Gligor showed that this probability may be low if
Keys management, sensor networks, elliptic curve cryptography, the parameters L and M are chosen carefully.
AVL tree.
Methods [2, 3, 4, 5, 6] improve the probabilistic protocol [1].
1. INTRODUCTION They provide a random pre-distribution of keys that involves
creating a large list ofkeys by a network administrator, and before
A wireless sensor network consists of hundreds or thousands of
deployment, a subset of this list randomly chosen is distributed to
sensor nodes that are powered by batteries and are typicall y
each node. It is possible that two nodes have common keys in
deployed randomly in environments often open. These nodes are
their subsets ofkeys, so they use common keys to establish a link
small, and therefore, have computational resources, storage
key between them. The choice of subsets is based on the
memory, communication and power very limited. These networks
probability of Eschenauer and Gligor [1]. One drawback of these
are of particular interest for military, environmental, and medical
approaches is that the number of keys is very large.
applications, and for applications related to monitoring of critical
infrastructures. But not ail applications al ways have the same COSEN method [7] is based on a partial key pre-distribution and
security constraints. Data encryption is often required for sensitive a symmetric cryptography. Before deployment, a partial list of
applications such as military applications and medical keys is generated at the base station. Each node is preloaded with
a partial list of keys. Once anode knows which keys it will use
with its neighbors, it removes the remaining keys. The problem is
that it is impossible to add a node or to update the keys with this
method.
ln [8], the authors proposed a method based on m-ary tree. Each
subset of nodes has a single shared key used for communication
between nodes. If anode is compromised, an adversary can listen
to ail messages between ail nodes in the subset.
In [9], the proposed method is based on random pre-distribution
ofkeys based on the AVL tree [10]. Alter deployment, each node
generates its master key, and then sends it to its direct neighbors
with its identity. Alter, each pair of nodes produce their shared
key. This method generates a lot of exchange and also in each
period, the cluster has to change its leader (he chose the node that
has more energy).
ln [II], the proposed method is called "Micro Public Key
Infrastructure". Only the base station is authenticated by the
nodes, using the public key. First, each node produces a random
key, and then sends it to the base station, so that it is used as the
shared secret key. Alterwards, if two nodes need to establish a
secure channel, one of them, sends a request to the base station,
and then, the base station produces a random key and sends it to
each of them. Periodically, each node starts an update, whi ch is
actually a new installation related to the key length and to the Figure 1: The A VL tree of keys
complexity of the algorithm used, so that the network consumes
much energy. 4.1 The network structure
It is a heterogeneous network [18] which contains a small number
[12] and [13] present a cryptography based on elliptic curves.
of high-quality sensor nodes that act as leaders. These sensors are
Thus, in the method [1 2], a certification authority calculates and
equipped with powerful and durable materials [1 3]. The network
delivers to each node a pair of private / public keys, and if two
thus contains a large number of low-quality sensor nodes that
nodes want to establish a connection, they produce an ephemeral
form groups around leaders. The high-quality sensors receive
common key for each session requiring many calculations. The
messages from low -quality nodes in the cluster, and then
method [13] is based on the routing protocol for heterogeneous
followed them to the base station.
sensor networks. The main idea is that anode can only
communicate with few neighbors. Before installing the keys, the Here are sorne defmitions of acronyms used in the rest of the
protocol calculates the routing tree by using a service to evaluate document:
the locations of the nodes, and this requires a lot of exchange of
messages between nodes. Of course, ail these communications are KDC: keys Distributor Center.
not protected, allowing an attacker to capture and change these LD: Leader.
messages. AIso, the protocol does not have the option of adding a
new node, or indeed, do an update of the keys. P: Public Key.
ND: Normal sensor node.
3. CRYPTOGRAPHY BASED ON
ELLIPTIC CURVES (EEC) CRL: A pair of public private keys, used by leaders to
ln recent years, ECC has attracted much attention as the security communicate.
solution for wireless networks, due to the fact that ECC keys are CR: A pair of public / private keys, called a network key used for
smaller compared to the RSA keys, for example, 160 bits ECC communication between normal nodes and leaders.
key offers the same level of protection as of 1024 bits RSA key
[14]. CC: Key ofa cluster.
An elliptic curve is a very simple object but which has properties Member_List: List ofnodes IDs in the network.
quite surprising. They have in most cases the form (y2 = x3 + ax +
Set_PublicKeys: Ail public keys those are located along the path
b) [15]. ECC is a key point P, located on the curve, P = (x, y).
from the node to the root of the AVL tree.
There are mainly two kinds of cryptosystems [15]. Asymmetric
MyX: Position of the node in the Member_List.
crypto systems where a key known to everyone is used to encode
the message but it cannot deduce the key to decrypt the message. UlD: Unique identifier that is send to each node.
In the Symmetric crypto-systems, the two correspondents agree
on a shared secret key that only they know. ln our approach we 4.2 Keys generation
will use the symmetric crypto-systems. With our key management method, the base station is equipped
with a KDC server that produces the ECC public keys and the
4. THE PROPOSED METHOD (CRL,CR) keys pair.
It is based on a secure control unit [16] (leader node or KDC
server) that stores the ECC keys in an AVL tree. Each node is 4.3 Keys establishment at the base station:
associated with a leaf of the tree, and ail keys located along the AVL-KDC
path from the leafto the root of the AVL tree belong to that node. ln the AVL-KDC method, the keys are generated at the base
The AVL tree [17] is a balanced binary search tree. For each node station.
of the tree, the height difference ofits sub trees is at most equal to
4.3.1 Before deployment
1. The binary search trees used to make operations su ch as
Depending on the number of regular nodes, the server constructs
insertion, deletion and search in a time proportional to the height
the AVL tree formed by the public keys and the "Member_List".
of the tree, which is nearly proportional to log(n).
Each leader LD is pre-Ioaded with the same key CRL and the "Set_PublicKeys", its identifier IDN, and its position MyXN. The
same key of network CR which is the key at the root of the A VL server sends to ail the leaders the new node identifier IDN and a
tree. Thus, each node ND is pre-Ioaded with his refresh keys message.
"Set]ublicKeys", its unique identifier UID, and its position MyX
in the "Member_List". These informations are used for When the new node NDN requests its adding to the cluster, it
identification and authentication when exchanging. provides its identifier IDN and its position MyXN. The leader LD
adds the parameters IDN and MyXN of the new node in its list
4.3.2 Creating clusters "Member_List", and then it sends a message to refresh the keys to
After deployment (as in [7]), each leader sends a message "join" ail nodes in the cluster.
encrypted with the network key CR. When a node ND receives ln the AVL-Leaders approach, when a new node NDN requests its
the ftrst message "join", it decrypts it with the key CR, and then it adding to the cluster, it provides its identifier IDN and the leader
returns to the Leader LD a message "joined" containing its ID adds it in the list "Member_List", and it refreshes the keys
encrypted with network key CR. With ail the IDs of nodes in the corresponding to its position in the A VL tree. Then, it retums to
cluster, the leader LD produces the "Member_List" list. this node its position MyXN in the list "Member_List" and its set
4.3.3 Ca/cu/ation ofshared keys of keys "Set_PublicKeys". Finally, the leader sends a message to
refresh the keys to ail nodes in the cluster.
Ifa node NDU wants to establish a communication with its leader,
it sends him a message containing its position MyXU. The leader 4.6 Updated Keys
associates the position MyXU with its node ID in its
ln the KOC-AVL approach, once an abnormal behavior of anode
"Member_List" list. Then the leader and the node compute their
is detected by a leader, or once anode leaves the network, the
secret key (MyXU x CR).
server initiates the update of the public keys that are along the
If two neighboring nodes in the cluster (NDU,NDV) want to path of the node (which has left the cluster) to the root of the A VL
establish a connection, they exchange their positions (MyXU, tree and reconfigures the A VL tree. Then, it sends a message of
MyXV), and then they determine the PUY point that is the update to ail the leaders, and finally, each leader broadcasts the
common public key, which is at the highest level in the A VL tree message to ail nodes in its cluster.
(closest to the leaves). Then, nodes NOU and NDV calculate
ln the A VL-Leaders approach, the Leader initiates the update of
MyXU(MyXYPUY)=MyXV(MyXUPUY) to be their common
the public keys that are along the path of the node that has left up
secret key.
to the root of the AVL tree and reconfigures the A VL tree.
As leaders are equipped with durable materials, so for their Finally, it broadcasts the message to ail nodes in the cluster.
exchange, they will always use the same key CRL pre-Ioaded
before deployment. 5. SIMULATION
ln our simulations, we used a network that consists of 600 to 1000
4.4 Keys establishment at levelleaders: AVL- nodes MicaZ type. Among these nodes, 20 nodes are leaders '
Leaders nodes. The nodes are distributed uniformly and randomly in an
area of 1000 x 1000 m. The transmission range of a sensor is 60
4.4.1 Before dep/oyment m, the size of a packet is 32 bytes, and the error rate of
Before deployment each leader is pre-Ioaded by the same pair of transmission is zero.
public / private network key RC, a unique key CRL used for The average number of neighbors is calculated as in [13] by the
communication between the leaders, and a set of public keys. following formula:
AIso, each node is normally pre-Ioaded with only the same pair of
network key RC. NbrNodesN x II x 602 / (1000 x 1000) (1)
sends it to ail nodes in the cluster. After that, he sends to each 120000
node in the cluster NDU a message (encrypted with the new key "2 __ ~ AVt· leilder 5
CC) containing his position MyXU in the "Member_List", and : 100000 ;-1- - -
-
AVL·KIlC
_ _ CECKM
RECC·CENT
~ 60000 _ RECC·DlST
16,00 !l SOO
14,00
~ 12.00
'" -1
600 700 800 900
1 1000
C N.mbuorDOdH
g 10.00
a. _ CECKM
Figure 5: the use of memory space.
~ 8,00
_ RECC·CENT
8= 6,00 - RECC-DtST
~
c
4,00
'" 2,00
Figure 5 shows the size of rnemory used to store the keys of a
normal node according to network size.
0,00
600 700 800 900 1000 We can see that with CECKM method, to store keys, a normal
Numbtroraodts node uses more memory (more than IKbytes), and a node in the
Figure 3: the energy consumption per normal node. AVL-Leaders method uses less memory (less than 250 bytes).
With the RECC method, the number of stored keys is related to
the number of neighbors and to the size of the network. This is
why; we can see that from 700 nodes, RECC approaches use more
memory than AVL-KDC approach .
So we conclude that our two approaches ensure to a normal node The AVL-Leaders approach proposed offers storage savings
a longer live compared to other methods. compared to other approaches and our approach AVL-KDC saves
more space than the two RECC approaches in large networks.
5.3 Comparison of the number of stored keys Due to the fact that the number of stored keys is connected to the
height of the AVL tree, the height in AVL-Leaders is smaller than
Figure 4 shows the size of memory used by a leader to store in AVL KDC. In the RECC method, the number of stored keys is
the keys according to the network size. related to the number of neighbors and in the CECKM method,
the number of stored keys is related to the number of nodes in the
cluster.
• AVlle.dOf. . AVl·KOC . CEC KM RECC-CENT . RECC-OIST
45000 ~--------------
5.4 Comparison the memory space use
To calculate the secret key between two normal nodes with the
CECKM method and the RECC-dist method, nodes compute the
35000 multiplication of their exchanged keys. This operation requires
B" 30000 282 bytes ofRAM [19], but with our method, the nodes calculate
!' multiplication of their positions with the shared key in the AVL
~ 25000
o tree, these operations require a maximum of 43 bytes of RAM
E lOOOO [20].
Ë
:: 15000 -
;;;
10000 ~- ..-----<
5000
o --- .
600 700 800 900 1000
•
:-Iamb.. ohodts
1
2000
-1 during this time in the network as a normal node.
!
..
~
1500 +-
1000 +
-i! Aiso in the CECKM method, keys exchanged between nodes and
the leaders are not encrypted, allowing the intruder to capture a
key and change it. ln our method, prior to the deployment, ail
;JI
nodes are preloaded with a network key, and alter the creation of
the clusters, each cluster has its own key, and then, ail
communications are encrypted wh en deployment is started. This
gives no chance for an intruder to change the keys.
600 700 800 900 1000
N umber ofoodes ln the RECC-DIST method, when anode is compromised, the
nodes only revoke the shared key. The intruder can obtain public
Figure 6: The size ofRAM required to calculate the keys from neighbors and calculate the secret keys. In this case, it
secret key between two normal nodes. can play the role of other nodes that have shared secret keys with
him.
ln the RECC-CENT approach, the leader computes the secret keys
of each node. If anode has 7 neighbors, it uses 7 * 282 bytes or ln our approach, each node stores a set of public keys, and if a
1974 bytes ofRAM, which is too much. Ifusing a TELOSB node node is compromised, then ail shared keys with other nodes will
[21] that has a 10 Kbytes of RAM (TELOSB is the powerful be changed, and the intruder cannot interact with the other nodes.
sensor) the memory required to calculate the secret key is at least
19% of the RAM. However, our method uses only 0.4% of the Our method ensures and guarantees greater security, which covers
RAM. the entire network, once the nodes are deployed.
6. CONCLUSION
_ Nolr•• pproche _ CECKM ln this paper, we presented an efficient key management protocol
for wireless sensor networks with a heterogeneous large-scale
~ deployment. It is based on cryptography using elliptic curves
13818
ê (ECC) and the AVL tree. The approach requires a KDC server
~ that generates the ECC keys, and an AVL tree for storing the
~
....0 keys. Each node is associated with a leaf of the tree, and it stores
.. only the keys located along the path to the root node of the AVL
tree. Our approach saves significant memory and reduces the
~
number of packets exchanged during installation keys with fewer
computing operations, while guaranteeing a better security.
~.~lM8~--~.~1~8----~.~1&8----••~18~---.~ 18 7. ACKNOWLEDGMŒNTS
600 700 800 900 1000 This work was completed with the support of the Natural Sciences
Numbtr ofaodtS
and Engineering Research Council of Canada (NSERC).
Figure 7: The size ofRAM required to calculate the
secret key between a node and his leader 8. REFERENCES
With our method, to calculate the secret key between a leader and [1] Laurent Eschenauer, Virgil D. Gligor, " A Key-Management
a normal node in the c1uster, the secret key is equal to the Scheme for Distributed Sensor Networks", CCS
multiplication of the position of the node in the "Member_List" '02 Proceedings of the 9th ACM conference on Computer
list with the root key of the AVL tree. This operation requires a and communications security, ACM New York, NY, USA ,
maximum of 18 bytes of the RAM, whereas in the CECKM 2002.
method, a node must compute the multiplication operation of ail [2] W. Du, J. Deng, Y. S. Han, S. Chen, and P. K. Varshney, "A
public keys of ail other nodes in the c1uster. For a MicaZ node key management scheme for wireless sensor networks using
with 4 Kbytes of RAM, it is impossible to do such an operation, deployment knowledge", 23rd Annual Joint Conference of
because with 4 bytes, we can hold a maximum of 14 keys the IEEE Computer and Communications Societies
multiplications. Thus, for a leader, if we use that TELOSB 10 (lNFOCOM 2004) Atlanta, GA, USA, ISBN 0-7803-8355-9,
Kbytes of RAM, it cannot compute the secret key if the c1uster November 2004 .
size exceeds 32 nodes. [3] C.Castelluccia and Angelo Spognardi, " RoK: A robust key
Our method proves that whatever the size of the network, either pre-distribution protocol for multi-stage Wireless Sensor
for a normal node or a leader node, it is always possible to Networks", IEEE Securecomm, Nice, France, September
compute the secret keys and this transaction is a Iightweight 2007.
operation and causes no problem unlike the other methods. [4] Donggang Liu, Peng Ning, "Establishing Pairwise Keys in
Distributed Sensor Networks", Journal of AC M, October 27-
3 1, 2003, Wash ington, DC, USA.
[5] R. Di Pietro, L. V. Mancini, and A. Mei, "Efficient and [15] Marc Joye, " Introduction élémentaire à la théorie des
Resilient Key Discovery Based on Pseudo-Random Key Pre- courbes elliptiques, UCL Crypto Group Technical Report
Deployment, " in 18th International Parallel and Distributed Series ", book in : http://www.dice.ucl.ac.be/crypto/. GC-
Processing Symposium (lPDPS'04), p. 217, 2004. 1995/ 1, pages (17) (73) (29-52).
[6] P.Samundiswary, Padma priyadarshini and P. Dananjayan, " [16] A.Boukerche et al, "Vehicular ad-hoc networks: A new
Performance Evaluation of Heterogeneous Sensor challenge for localization-Based System", Elsevier Computer
Networks", International Conference on Future Computer Communications, 2007.
and Communication, ISBN 978-0-7695-3591-3, ICFCC, [17] Implementing A VL Trees in :
2009. http://www.lri.fr/-fiorenzilTeachingiCours_Ing2000/arbravl_
[7] Quazi Ehsanul Kabir Mamun and Sita Ramalcrishnan, " 7.pdf.
SecCOSEn - A Key Management Scheme for Securing [18] M. J. Handy, M. Haase, D. Timmermann," Low Energy
Chain Oriented Sensor Networks ", Communication Adaptive Clustering Hierarchy with Deterministic Cluster-
Networks and Services Research Conference (CNSR 2008), Head Selection", Fourth IEEE Conference on Mobile and
ISBN 978-0-7695-3135-9, May 2008. Wireless Communications Networks, Stockholm, erschienen
[8] A.S.Poornima, B.B.Amberker, "Tree-based Key in Proceedings, S. 368-372, ISBN 0-7803-7606-4, World
Management Scheme for Heterogeneous Sensor Networks", Scientific Publishing Co. Pte. Ltd., September 2002.
16th IEEE International Conference, ICON 2008, ISBN 978- [19] Arvinderpa.S.W, Nils Gura,Hans Eberl, Vipul Gupta,
1-4244-3805-1 , NewDelhi, 2008. sheuuling Chang shantz, " Energy analyses of public key
[9] Yi-Ying Zhang, Wen-Cheng Yang, Kee-Bum Kim, Myong- cryptography for wireless sensor networks ", Third IEEE
Soon Park, "An A VL Tree-Based Dynamic Key International Conference on Pervasive Computing and
Management in Hierarchical Wireless Sensor Network ", Communications, (PerCom'05), ISBN 0-7695-2299-8m,
International Conference on Intelligent Information Hiding Kauai Island, Hawaii, 2005, page (5).
and Multimedia Signal Processing, ISBN 978-0-7695-3278- [20] Nils Gura, Arun Patel, Arvinderpal Wander, Hans Eberle,
3, August 2008. Sheueling Chang Shantz, " Comparing Elliptic Curve
[10] A VL Tree in : Dictionnaires et Encyclopédies sur Academic, Cryptography and RSA on 8-bit CPUs ", in the book"
http://fr.academic.ru/dic.nsf/frwikilI24260. Cryptographic Hardware and Embedded Systems - CHES
[II] E.Munivel, Dr G M Ajit, "Efficient Public Key Infrastructure 2004, 6th International Workshop Cambridge, MA, USA,
Implementation in Wireless Sensor Networks ", International August 11-13, 2004 ", ISBN 978-3-540-22666-6, Chaptre(4),
conference on Wireless Communication and Sensor page (8), Springer Berlin / Heidelberg, July 08, 2004.
Computing, ISBN 978-1-4244-5136-4, February 2010. [21] TELOSB mote platform in:
[12] O.Arazil, H.Qi, D.Rosel , "A Public Key Cryptographic http://www.memsic.com/products/wireless-sensor-
Method for DeniaI of Service Mitigation in Wireless Sensor networks/wireless-modules.html.
Networks ", 4th Annual IEEE Communications Society, [22] Garci , a, E.M., Bermu , dez, A., Casado, R. , "Range-free
Conference on Sensor, Mesh and Ad Hoc Communications localization for air-dropped WSNs by filtering node
and Networks, ISBN 1-4244-1268-4 , San Diego, CA, estimation improvements", 6th International Conference on
August 2007. Wireless and Mobile Computing, Networking and
[13] Xiaojiang Du, Mohsen Guizani, Yang Xiao, and Hsiao-Hwa Communications (WiMob), 2010 IEEE , E-ISBN : 978-1-
Chen, "A Routing-Driven Elliptic Curve Cryptography 4244-7741-8, November 2010.
Based Key Management Scheme for Heterogeneous Sensor Contact person for correspondence:
Networks", IEEE International Conference Boucif Amar Bensaber, Ph.D
on Communications, ICC 2007, ISBN 1-4244-0353-7 , Laboratoire de Mathématiques et Informatique appliquées
Glasgow, August 2007. LAMlA.
[14] Hua-Yi Lin, " High-Effect Key Management Associated Department of Mathematics and Computer Science
With Secure Data Transmission Approaches in Sensor University ofQuebec at Trois-Rivières, Canada
Networks Using a Hierarchical-based Cluster Elliptic Curve 3351 Bd des Forges, C.P 500
Key Agreement", ncm, pp.308-314, Fifth International Joint Trois-Rivières, G9A 5H7 - Qc - Canada.
Conference on !NC, IMS and IDC, ISBN 978-0-7695-3769- Email: [email protected]
6, Seoul, Korea, 2009.