mai
2010
Il peut arriver, dans le cadre d’un développement spécifique, qu’il soit nécessaire d’implémenter la gestion et la création de liens entre fichiers (pour les linuxiens, grosso modo, l’équivalent de la commande ln).
Avec NTFS, il existe deux types de lien entre fichiers :
- les liens physiques (Hard Link)
- les liens symboliques (Symbolic Link)
Un hard link est une entrée supplémentaire dans la table d’adressage NTFS, pointant sur un espace donné, et ne peut pointer que vers un fichier.
Un symbolic link, de son coté, est grosso modo l’équivalent d’un URL pointant vers une adresse donnée sur le disque.
Par conséquent, la grosse différence est que, si on renomme la source d’un hard link, il continue à fonctionner, tandis que le symbolic link ne fonctionnera plus.
Une fois le décor planté, comment les créer ?
Comme souvent dans le case des fonctionnalités du système d’exploitation, on peut s’appuyer (pas trop fort non plus) sur la dll kernel32.
Création de Hard Link
Version client minimum |
Windows 2000 Professional |
Version server minimum |
Windows Server 2000 |
DLL |
Kernel32.dll |
Noms Unicode et ANSI |
CreateHardLinkW (Unicode) / CreateHardLinkA (ANSI) |
using System.Runtime.InteropServices;
...
[DllImport("kernel32.dll", SetLastError = true, CharSet = CharSet.Auto)]
static extern bool CreateHardLink(string lpFileName, string lpExistingFileName,
IntPtr lpSecurityAttributes);
CreateHardLink(@"D:\someDir\test1.txt", @"D:\someDir\test.txt",IntPtr.Zero);
Création de Symbolic Link
Version client minimum |
Windows Vista |
Version server minimum |
Windows Server 2008 |
DLL |
Kernel32.dll |
Noms Unicode et ANSI |
CreateSymbolicLinkW(Unicode) / CreateSymbolicLinkA(ANSI) |
using System.Runtime.InteropServices;
...
[DllImport("kernel32.dll", SetLastError = true, CharSet = CharSet.Auto)]
static extern bool CreateSymbolicLink(string lpFileName, string lpExistingFileName,
UInt32 flags);
const UInt32 SymbolicLinkFlagFile = 0;
const UInt32 SymbolicLinkFlagDirectory = 1;
CreateSymbolicLink(@"D:\someDir\test1.txt", @"D:\someDir\test.txt",SymbolicLinkFlagFile );
CreateSymbolicLink(@"D:\someDir2\", @"D:\someDir\",SymbolicLinkFlagDirectory );
Attention aux droits !
La semaine dernière, pendant la mise en production, grosse surprise, plus aucun liens ne fonctionnait.
En effet, la création de liens fonctionne en local comme en distant, mais il est nécessaire que l’utilisateur créant le lien :
- ait les droits de création de fichier/répertoire (bon, ca, c’était facile)
- mais aussi fasse partie du groupe des utilisateurs de la machine, que ce soit en local ou en distant
.et les deux informations ci-dessus (enfin, surtout le seconde), c’est 2 heures de travail sur les droits.
Articles récents
Archives
- janvier 2014
- septembre 2013
- août 2013
- mai 2013
- avril 2013
- janvier 2013
- août 2012
- juin 2012
- mai 2012
- avril 2012
- mars 2012
- novembre 2011
- septembre 2011
- août 2011
- juillet 2011
- juin 2011
- mai 2011
- avril 2011
- février 2011
- janvier 2011
- novembre 2010
- octobre 2010
- septembre 2010
- août 2010
- juillet 2010
- juin 2010
- mai 2010
- avril 2010
- mars 2010
- février 2010
- janvier 2010
- décembre 2009
- novembre 2009
- octobre 2009
- septembre 2009
- août 2009
- juillet 2009
- juin 2009
- mai 2009
- avril 2009
- mars 2009
- février 2009
- janvier 2009