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)
ben et le source???
Pourrait tu donner plus d'explications ou un petit bout de code d'exemple, cela me parait interressant mais j'aimerai en savoir plus sur les possibilitées de cet ajout de reference.De ce que je comprend on peut lancer la diffusion d'un package MSI en une ligne de code VB ??Merci.
manque la source pour mieux visualisez ,(mieux codez mieux visualizes............ben fait une petit source .
Tu as mis l'eau à la bouche...Reste à verser le liquide !
Cela suffit ? En tout cas, je conseille d'utiliser InnoSetup pour créer des installation, c'est très simple, très puissant, et c'est gratuit !DarK Sidious
Salut Dark...En forme je vois !Je vais télécharger innosetup pour essayer...connaisais pas !AmitiésJmluc
Oui, il est vrai qu'InnoSetup est très bien. Je conseille également ISTool (interface graphique d'InnoSetup) et InnoScript. Ce dernier permet de générer des .iss (projet InnoSetup) depuis un .vbp ou un .lst. Perso je préfère travailler depuis le .lst généré par l'Assistant Empaquetage & déploiement de VB.++Bazinou
J'avoue ...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 projetGlobal MSI_DB As WindowsInstaller.DatabaseGlobal MSI_Obj As WindowsInstaller.InstallerGlobal MSI_InfoFeature As WindowsInstaller.FeatureInfoGlobal MSI_InfoSummary As WindowsInstaller.SummaryInfoGlobal MSI_RecordSet As WindowsInstaller.RecordGlobal MSI_Session As WindowsInstaller.SessionGlobal MSI_View As WindowsInstaller.ViewGlobal MSI_Connected As BooleanGlobal 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 NextDim i As IntegerReDim 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 SubEnd SubVoilà pour le début ...A+ Blu
Se souvenir du profil
Mot de passe oublié ? / Activation de compteCréer un compte
1 873 833 membres 115 nouveaux aujourd'hui 16 151 membres club