Updated since WebPICmd.exe is now included with WebPI rather than as a separate download.
I have come across several forum posts by individuals about doing offline installs for computers that do not have internet connectivity. This should apply to most servers within a corporate environment. A server should only have internet connectivity if there is a business reason for it. Since I have come across this multiple times, I figured I would write a blog about it.
There is a command line utility that is included with the Web Platform Installer. You can find it here. Once you have installed WebPI, the WebPICmd.exe (command line installer) will be located in c:Program FilesMicrosoftWeb Platform Installer.
I wanted to use this application to prep for a PHP54 and PHPManager offline install. The beauty of this application is that it determines dependencies and downloads those as well if they are not already installed. For best results, you would want to run this on a machine that closely matches the machine that you are going to be porting the offline cache data to so that you don’t run into issues where you did not download a dependency that the target server needs. You can use All as the Product specification which literally creates an offline cache of all packages in the WPI feed. If you are not sure what you need on the target server, this is the safest option to ensure that you have everything you need when you start, but can be time consuming.
To begin with, I decided to take a look at what was installed on the server I was running this test on. To gather this information, I ran the following command:
c:Program FilesMicrosoftWeb Platform InstallerWebPICmd.exe /List /ListOption:Installed
This returned a list of all applications that have been installed by WebPI.
I then wanted to see all available installation packages so I ran the following command:
>c:Program FilesMicrosoftWeb Platform Installerwpicmd.exe /List /ListOption:Available
This provided a list of applications that could be installed or cached locally for future install. This is a snippet of the output from this command.
The software that you obtain using the Web Platform Installer Command Line Tool
is licensed to you by its owner. Microsoft grants you no rights for third party
Successfully Loaded Feed : https://go.microsoft.com/?linkid=9783679
Current language of installers is English
AdvancedLogging Advanced Logging
AppFabric Windows Server AppFabric
ARRv2Update Hotfix for Application Request Routing 2.1
AzureNodePowershell Windows Azure SDK for Node.js – May 2012
AzureNodeSDK Windows Azure SDK for Node.js – August 2012
AzurePHPSDK Windows Azure SDK for PHP – August 2012
AzurePythonSDK Windows Azure SDK for Python – June 2012
AzurePythonSDKCore Windows Azure SDK for Python (Core) – June 2012
CustomLogging IIS: Custom Logging
DACFX Microsoft SQL Server 2012 Data-Tier Application Framework (
DACFX_11_0 Microsoft SQL Server 2012 Data-Tier Application Framework 1
1.0 (April 2012)
DBManager Database Manager 1.0
DbManagerUpdate Database Manager 1.0 Hotfix
Django Django 1.4 (Python)
DynamicIPRestrictionsRTW Dynamic IP Restrictions 1.0
Since I wanted to install PHP54 and PHPManager on my server, I scrolled through the list until I located those products to determine what the ProductID was.
PHP54 PHP 5.4.24
PHPManager PHP Manager for IIS
I then ran the command to create an offline cache of these two applications and any dependent applications for install purposes.
>C:Program FilesMicrosoftWeb Platform InstallerWebPICMD.exe /Offline /Products:PHP54,PHPManager /Path:c:appsinstall
This created a local cache copy of all necessary data to install these packages with no internet connectivity. It also provides the exact command line to run to complete the install.
To use the new offline feed, please run the following from the command line:
WebPICmd.exe /Install /Products:<products you want> /XML:<Offline main feed>
Now for the fun part. I copied my offline-wpi directory to a USB drive and moved it over to a server that I had disabled the network card on. I created the same directory structure that I had on the original server (c:apps) and copied the offline-wpi folder to this location. That way I didn’t have to do any manual modification of the files that were created originally. The file location is listed in the xml file.
On the target machine, I opened a command prompt and entered the information from the Offline main feed output from the creation of the offline cache.
>c:Program FilesMicrosoftWeb Platform InstallerWebPICmd.exe /Install /Products:PHP54, PHPManager /XML:/c:/apps/install/feeds/latest/webproductlist.xml
After the install information is loaded, you are prompted to accept the license terms for each of the applications to be installed. Answer Y and the application is off to the races installing the requested applications. And last but not least, I had SUCCESS.
Verifying successful installation…
PHP Manager for IIS True
PHP 5.4.0 True
Install of Products: SUCCESS
Upon opening IIS Manager on the server, the PHP Manager plug-in icon was available for use and easy of administration of the installed PHP instance.
This is a very nifty tool that can provide nicely packaged applications for those protected servers that do not have internet access to download and install the applications natively.
I hope you find this information helpful.