5/5 (8 avis)
Snippet vu 21 700 fois - Téléchargée 30 fois
Essayez cette méthode en ajoutant dans votre projet la référence "Microsoft Windows Installer Object Library" qui pointe sur Msi.dll (C:\Windows\System32 Sous XP ou C:\WinNT\system32 sous 2000 et NT4) puis dans le code : Set ObjMSI = CreateObject("WindowsInstaller.Installer") ObjMSI.InstallProduct MSIPathFile(Ici une string), PropertyValue(Ici une string)
26 mai 2004 à 22:04
Au départ il s'agissait en fait d'une réponse à une question mais la date du post était de 2003 ...
Au dernier moment j'ai préféré le pousser en trucs et astuces sur le site. Je ne pensais pas vraiment attirer autant de commentaire.
Pour ceux que cela intéresse en fait un fichier MSI n'est pas autre chose qu'une base de données.
Elle stocke entre autre l'arborescence, les fichiers, les dll, la registerie, les icônes et shurtcut, les ODBC ... d'une application a installer. Avec un peu de SQL et les objets, méthodes, propriétés exportés par MSI.DLL un peu obtenir une interface comme décrit dans la capture.
Je sort juste de formation sur AdminStudio d'InstallShield (Effectivement produit payant mais dans le cadre de grande société, le setup dit classique ne suffit pas. ), je commence tout juste le soft que je montre en capture. De plus Windows Installer propose le principe du roll back pendant l'installation et surtout l'autoréparation en cas de problème.
Il reste encore beaucoup de choses a coder : seul les deux premiers onglets sont codés.
Ceux qui veulent vraiment le source n'ont qu'à me demander par mail.
J’vois pas trop l'intérêt de mettre la source pour l'instant en ligne tant qu'elle n'est pas plus avancée.
Désolé d'avoir mis l'eau à la bouche pour certain ...
Sinon la base du code est du genre
'Penser a rajouter la référence MSI.DLL dans votre projet
Global MSI_DB As WindowsInstaller.Database
Global MSI_Obj As WindowsInstaller.Installer
Global MSI_InfoFeature As WindowsInstaller.FeatureInfo
Global MSI_InfoSummary As WindowsInstaller.SummaryInfo
Global MSI_RecordSet As WindowsInstaller.Record
Global MSI_Session As WindowsInstaller.Session
Global MSI_View As WindowsInstaller.View
Global MSI_Connected As Boolean
Global Const msiOpenDatabaseModeReadOnly = 0 'Opens a database read-only, no persistent changes.
Global Const msiOpenDatabaseModeTransact = 1 'Opens a database read/write in transaction mode.
Global Const msiOpenDatabaseModeDirect = 2 'Opens a database direct read/write without transaction.
Global Const msiOpenDatabaseModeCreate = 3 'Creates a new database, transact mode read/write.
Global Const msiOpenDatabaseModeCreateDirect = 4 'Creates a new database, direct mode read/write.
Global Const msiOpenDatabaseModePatchFile = 32 'Adds this flag to indicate a patch file.
Public Function fx_MSI_Connect(ByVal sMsiFile As String)
On Error Resume Next
Set MSI_Obj = CreateObject("WindowsInstaller.Installer")
Set MSI_DB = MSI_Obj.OpenDatabase(sMsiFile, msiOpenDatabaseModeTransact)
If Err.Number <> 0 Then
fx_MSI_Connect = False
MSI_Connected = False
objMsiDB = Nothing
MSI_DB = Nothing
Else
fx_MSI_Connect = True
MSI_Connected = True
End If
End Function
'N'ayant pas trouvé le moyen de mettre en relation la base MSI avec le code via un connecteur (DATA ou Remote_DATA) je stocke la liste des tables dans un tableau de string ...
Public Sub fx_LoadMSI_Tables()
On Error Resume Next
Dim i As Integer
ReDim Preserve tabMSI_Tables(0)
Set MSI_View = MSI_DB.OpenView("SELECT * FROM _Tables")
MSI_View.Execute
Set MSI_RecordSet = MSI_View.Fetch
Do While Err.Number = 0
ReDim Preserve tabMSI_Tables(i)
tabMSI_Tables(i) = MSI_RecordSet.StringData(1)
'Debug.Print MSI_RecordSet.StringData(1); "Status = "; MSI_RecordSet
i = i + 1
Set MSI_RecordSet = MSI_View.Fetch
Loop
If Err.Number = 91 Then Exit Sub
End Sub
Voilà pour le début ...
A+
Blu
26 mai 2004 à 09:26
++
Bazinou
26 mai 2004 à 08:43
Je vais télécharger innosetup pour essayer...connaisais pas !
Amitiés
Jmluc
26 mai 2004 à 08:21
DarK Sidious
26 mai 2004 à 07:40
Reste à verser le liquide !
Vous n'êtes pas encore membre ?
inscrivez-vous, c'est gratuit et ça prend moins d'une minute !
Les membres obtiennent plus de réponses que les utilisateurs anonymes.
Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.
Le fait d'être membre vous permet d'avoir des options supplémentaires.