Home > Scripts > How to make a self extracting archive that runs your setup.exe with 7zip -sfx switch

How to make a self extracting archive that runs your setup.exe with 7zip -sfx switch

The scenario

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:

  1. installer.msi – the .msi installation file
  2. 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:

  1. Zip the two files – the user has to download a zip, extract the zip and run the setup.exe
  2. Just provide the msi file, but this by passes the pre-requisite checks which is not ideal; or
  3. Create a self extracting archive that runs, extracts the software and then calls the setup.exe

The self extracting archive option seems the best.

The problem

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

  1. Go to the folder that has your msi and your setup.exe
  2. Select both the .msi and the setup.exe
  3. Right-Click and choose 7Zip –> “Add to Archive”
  4. Name your archive “Installer.7z” (or a name of your choice)
  5. Click Ok
  6. You should now have “Installer.7z”.
  7. 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.

  1. Follow this link to go to 7zip download.
  2. You need to download the 9.20 version (as @ May-2015) as the beta does not contain the correct files.
  3. A direct download link.
  4. Extract the 7zip extra files
  5. 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++.

  1. Using windows explorer go to c:\Install
  2. right-click and choose “New Text File” and name it config.txt
  3. right-click and choose “Edit with NotePad++
  4. Click the “Encoding Menu” and choose “Encode in UTF-8”
  5. Enter something like this:
    ;!@Install@!UTF-8!
    Title="SOFTWARE v1.0.0.0"
    BeginPrompt="Do you want to install SOFTWARE v1.0.0.0?"
    RunProgram="setup.exe"
    ;!@InstallEnd@!
    

Edit this replacing [SOFTWARE v1.0.0.0] with your product name.
Notes on the parameters and options for the setup file are here

CheckPoint

You should now have a folder “c:\Install” with the following 3 files:

  1. Installer.7z
  2. 7zS.sfx
  3. config.txt

Step 5 – Create the archive

These instructions I found on the web but nowhere did it explain any of the 4 steps above.

  1. Open a cmd window, Window + R –> cmd –> press enter
  2. In the command window type the following
    cd \
    cd Install
    copy /b 7zS.sfx + config.txt + Installer.7z MyInstaller.exe
    
  3. Look in c:\Install and you will now see you have a MyInstaller.exe
  4. 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 🙂
    Thanks

    VN:F [1.9.22_1171]
    Rating: 9.6/10 (51 votes cast)
    How to make a self extracting archive that runs your setup.exe with 7zip -sfx switch, 9.6 out of 10 based on 51 ratings

Categories: Scripts Tags:
  1. Bob
    March 7th, 2016 at 22:02 | #1

    Great job! Works like a charm. This is exactly what we needed.

    Thnak you!

    VA:F [1.9.22_1171]
    Rating: 0 (from 0 votes)
  2. Jakes
    April 28th, 2016 at 00:25 | #2

    I followed the above instructions to create MyInstaller.exe
    When I run it, it asks me for an administrator password to run the setup.exe.

    If I run the setup.exe directly, it does not ask for Administrator password. Any clues how can I get around this?

    VA:F [1.9.22_1171]
    Rating: 0 (from 0 votes)
    • jcrawfor74
      May 3rd, 2016 at 19:42 | #3

      Hi Jakes, I don’t have this problem? Try installing PatchCleaner from my website, PatchCleaner. This was created in this exact manner. Are you sure the file is not blocked? Right click >> Properties and sometimes you will see a “Unblock” button?

      VN:F [1.9.22_1171]
      Rating: 0 (from 0 votes)
  3. dabiebo
    June 16th, 2016 at 00:29 | #4

    Hi,

    thank you for the walkthrough.
    Creating the package works but it will be a 32-bit executable. I use a x64 system to create and also to distribute. Some commands don’t work if run as 32-bit-application.

    Is there an option to create a 64-bit-executable

    Thank you

    VA:F [1.9.22_1171]
    Rating: 0 (from 0 votes)
  4. avi
    July 21st, 2016 at 16:43 | #5

    Hi
    I installed the software on my computer (and Indoos 8.1) and the software not let me click on the Delete button in any way
    How do I fix this?
    Thank you!.

    VA:F [1.9.22_1171]
    Rating: 0 (from 0 votes)
    • jcrawfor74
      July 22nd, 2016 at 22:07 | #6

      Did it find anything to remove?

      If there is nothing to remove then it would not allow you to click delete.

      Do the other buttons on the program work? Just wondering if it is a general UI issue or just a problem with the Delete action.

      VN:F [1.9.22_1171]
      Rating: 0 (from 0 votes)
  5. avi
    July 21st, 2016 at 16:45 | #7

    I forgot to say that I’m talking of course about the PatchCleaner.

    VA:F [1.9.22_1171]
    Rating: 0 (from 0 votes)
  6. Nitin Tomer
    August 24th, 2016 at 15:08 | #8

    @jcrawfor74
    Hi,

    I am also facing the same problem. I tried PatchCleaner EXE as well, that too asked for administrator password.

    Is there a way to bypass that?

    Regards

    Nitin

    VA:F [1.9.22_1171]
    Rating: 0 (from 0 votes)
  1. No trackbacks yet.