How to make a self extracting archive that runs your setup.exe with 7zip -sfx switch
When you use the default Microsoft Visual Studio Installer (yes, it is back as an extension for VS 2013 – Visual studio Installer Projects Extension), the output are two files:
- installer.msi – the .msi installation file
- setup.exe – which is the bootstrap that does your pre-requisite checks
So you want to provide a download for your product from your website as a single file.
Some possible options include:
- Zip the two files – the user has to download a zip, extract the zip and run the setup.exe
- Just provide the msi file, but this by passes the pre-requisite checks which is not ideal; or
- Create a self extracting archive that runs, extracts the software and then calls the setup.exe
The self extracting archive option seems the best.
I wanted to use 7Zip to create the self extracting archive but I could not seem to find a simple guide that explained exactly how to do it.
I have finally worked it out and below are some detailed instructions.
How to make a self extracting archive that launches your installer after extraction
It is actually quite simple to do if you follow these easy steps.
Step 1 – Setup your installation folder
To make this easy create a folder c:\Install. This is where we will copy all the required files.
Step 2 – 7Zip your installers
- Go to the folder that has your msi and your setup.exe
- Select both the .msi and the setup.exe
- Right-Click and choose 7Zip –> “Add to Archive”
- Name your archive “Installer.7z” (or a name of your choice)
- Click Ok
- You should now have “Installer.7z”.
- Copy this .7z file to your c:\Install directory
Step 3 – Get the 7z-Extra sfx extension module
You need to download the 7z-Extra.
- Follow this link to go to 7zip download.
- You need to download the 9.20 version (as @ May-2015) as the beta does not contain the correct files.
- A direct download link.
- Extract the 7zip extra files
- Copy the file “7zS.sfx” to c:\Install
Step 4 – Setup your config.txt
I would recommend using NotePad++ to edit this text file as you will need to encode in UTF-8, the following instructions are using notepad++.
- Using windows explorer go to c:\Install
- right-click and choose “New Text File” and name it config.txt
- right-click and choose “Edit with NotePad++
- Click the “Encoding Menu” and choose “Encode in UTF-8”
- Enter something like this:
;!@Install@!UTF-8! Title="SOFTWARE v18.104.22.168" BeginPrompt="Do you want to install SOFTWARE v22.214.171.124?" RunProgram="setup.exe" ;!@InstallEnd@!
Edit this replacing [SOFTWARE v126.96.36.199] with your product name.
Notes on the parameters and options for the setup file are here
You should now have a folder “c:\Install” with the following 3 files:
Step 5 – Create the archive
These instructions I found on the web but nowhere did it explain any of the 4 steps above.
- Open a cmd window, Window + R –> cmd –> press enter
- In the command window type the following
cd \ cd Install copy /b 7zS.sfx + config.txt + Installer.7z MyInstaller.exe
- Look in c:\Install and you will now see you have a MyInstaller.exe
You are finished
Run the installer
Double click on MyInstaller.exe and it will prompt with your message. Click OK and the setup.exe will run.
Everything is easy… once you know how. 🙂
P.S. Note on Automation
Now that you have this working in your c:\Install directory I would create an “Install.bat” file and put the copy script in it.
copy /b 7zS.sfx + config.txt + Installer.7z MyInstaller.exe
Now you can just edit and run the Install.bat every time you need to rebuild a new version of you deployment package.
P.P.S. super user
If you got here from the super user article, perhaps you would like to vote my answer up 🙂