用InstallShield 进行ASP 软件的打包和自动安装

2024-01-20 11:08

本文主要是介绍用InstallShield 进行ASP 软件的打包和自动安装,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前些时候看到这篇文章,对比了自己和作者的实现方法,感觉有一定的参考价值,大家不妨看看。 

用InstallShield 进行 ASP 软件的打包和自动安装(Jaron原创) 

作者: Jaron 点击链接查看作者详细信息 

简介: 用InstallShield 进行 ASP 软件的打包和自动安装(原创) 

#include "ifx.h" //不能移动 
// 
// 用InstallShield 进行 ASP 软件的打包和自动安装 
// 原创作者: 贾俊 (Jaron) 
// 网址: http://www.jiangdu.net 
// 邮件: jaron@jdinfo.net 
// 首次发表于网易,ChinaASP,ASPHouse 
// 
// 功能: 
// 1.文件复制 
// 2.可选自动设置独立站点运行(设置IIS) 
// 3.可选自动设置虚拟站点运行(设置IIS) 
// 4.设置目录可读,可写及可运行脚本 
// 5.自动创建ODBC 
// 6.自动创建或附加MDF格式的SQL数据库 并优化 
// 7.自动安装 ScriptEncode 解码程序 
// 本文仅列出了 InstallShield 的 Script 部分,还有两个 VBS 文件及其他设置 
// 测试过程中有任何问题,请来 http://www.jiangdu.net/bbs 编程空间版 讨论 
// 
prototype CreateDataBase(STRING,STRING,STRING); 
prototype CreateWebSite(STRING,STRING); // 创建 IIS 站点 
prototype CreateVirtualDir(STRING); // 创建虚拟目录 

// 
// 
// 函数: OnFirstUIBefore 
// 
// 事件: FirstUIBefore event is sent when installation is run for the first 
// time on given machine. In the handler installation usually displays 
// UI allowing end user to specify installation parameters. After this 
// function returns, ComponentTransferData is called to perform file 
// transfer. 
// 
/// 
function OnFirstUIBefore() 
NUMBER nResult,nSetupType,nOpt,svEdit1,svEdit2; 
STRING szTitle, szMsg,szBmpPath; 
STRING szLicenseFile, szQuestion; 
STRING szServerIP,szServerPort,szServerIPDefault,szServerPortDefault; 
STRING szSQLsvr,szSQLusr,szSQLpwd,svSQLsvr,svSQLusr,svSQLpwd; 
STRING svName, svCompany, svSerial; 
STRING szFile,szTargetPath,szDir,szfolder; 
STRING szComponents, szTargetdir; 
STRING szField1,szField2; 
STRING szDefault,svResult; 
OBJECT piisObj; 
LIST list,listStartCopy; 
NUMBER nLevel,nvSize; 
begin 

szBmpPath="C:"^"temp"^"left.bmp"; 
DialogSetInfo (DLG_INFO_ALTIMAGE, szBmpPath, TRUE); // 设置左边的图片 
//To Do: if you want to enable background, window title, and caption bar title 
//SetTitle( @TITLE_MAIN, 24, WHITE ); 
//SetTitle( @TITLE_CAPTIONBAR, 0, BACKGROUNDCAPTION ); 
//Enable( FULLWINDOWMODE ); 
//Enable( BACKGROUND ); 
//SetColor(BACKGROUND,RGB (0, 128, 128)); 

//默认值设定 
TARGETDIR = "C:"^"inetpub"^"JaronSoft"^@FOLDER_NAME; 
szDir = TARGETDIR; 
SHELL_OBJECT_FOLDER = @FOLDER_NAME; 
svName = "试用版用户"; 
svCompany = "JDinfo Network"; 
svSerial = "111-1111111"; 

Dlg_Start: 
// beginning of dialogs label 

Dlg_SdWelcome: //欢迎 对话框 
szTitle = "欢迎进入"; 
szMsg = ""; 
nResult = SdWelcome( szTitle, szMsg ); 
if (nResult = BACK) goto Dlg_Start; 

Dlg_SdLicense://软件许可协议 对话框 
szLicenseFile = SUPPORTDIR ^ "license.txt"; 
szTitle = "许可协议"; 
szMsg = ""; 
szQuestion = ""; 
nResult = SdLicense( szTitle, szMsg, szQuestion, szLicenseFile ); 
if (nResult = BACK) goto Dlg_SdWelcome; 

Dlg_SdShowInfoList://readme文件 对话框 
szFile = SUPPORTDIR ^ "infolist.txt"; 
list = ListCreate( STRINGLIST ); 
ListReadFromFile( list, szFile ); 
szTitle = "README"; 
szMsg = ""; 
nResult = SdShowInfoList( szTitle, szMsg, list ); 
ListDestroy( list ); 
if (nResult = BACK) goto Dlg_SdLicense; 

Dlg_SdRegisterUserEx://用户信息 对话框 
szMsg = ""; 
szTitle = "用户信息"; 
nResult = SdRegisterUserEx( szTitle, szMsg, svName, svCompany, svSerial ); 
if (nResult = BACK) goto Dlg_SdShowInfoList; 
//检查序列号 
//if (CHK_serial(svCompany, svSerial)<0) then 
//goto Dlg_SdRegisterUserEx; 
//endif; 
//检查序列号完毕 
Dlg_SdAskDestPath://安装位置 对话框 
szTitle = "检查序列号"; 
szMsg = ""; 
nResult = SdAskDestPath( szTitle, szMsg, szDir, 0 ); 
TARGETDIR = szDir; 
if (nResult = BACK) goto Dlg_SdRegisterUserEx; 

Dlg_SetupType: //安装类型 对话框 
nSetupType = TYPICAL; 
szTitle = "安装类型"; 
szMsg = "请选择您需要按哪种方式安装"; 
nResult = SetupType ( szTitle , szMsg , "" , nSetupType , 0 ); 
if (nResult = BACK) then 
goto Dlg_SdAskDestPath; 
else 
nSetupType = nResult; 
if (nSetupType != CUSTOM) then 
  szTargetPath = TARGETDIR; 
  nvSize = 0; 
  ComponentCompareSizeRequired(MEDIA,szTargetPath,nvSize); 
  if (nvSize != 0) then 
  MessageBox( szSdStr_NotEnoughSpace, WARNING ); 
  goto Dlg_SetupType; 
  endif; 
endif; 
endif; 

Dlg_SdComponentTree: //对话框 
if ((nResult = BACK) && (nSetupType != CUSTOM)) goto Dlg_SetupType; 
szTitle = "对话框"; 
szMsg = ""; 
szTargetdir = TARGETDIR; 
szComponents = ""; 
nLevel = 2; 
if (nSetupType = CUSTOM) then 
nResult = SdComponentTree(szTitle, szMsg, szTargetdir, szComponents, nLevel); 
if (nResult = BACK) goto Dlg_SetupType; 
endif; 

Dlg_SdSelectFolder://对话框 
szfolder = SHELL_OBJECT_FOLDER; 
szTitle = "文件夹"; 
szMsg = ""; 
nResult = SdSelectFolder( szTitle, szMsg, szfolder ); 
SHELL_OBJECT_FOLDER = szfolder; 
if (nResult = BACK) goto Dlg_SdComponentTree; 

Dlg_SelMode ://设置数据库服务器 对话框 
szTitle = "设置"+@PRODUCT_NAME+"的运行模式"; 
szMsg = "请选择软件运行的方式,极力推荐使用独立站点方式运行"; 
szField1="独立站点方式运行(自动创建新站点)"; 
szField2="虚拟目录方式运行(自动创建虚拟目录)"; 
svEdit1=TRUE; 
svEdit2=FALSE; 
SetDialogTitle(DLG_ASK_TEXT,szTitle); 
//DialogSetInfo ( DLG_INFO_CHECKSELECTION, "", 1); 
nOpt = EXCLUSIVE ; 
nResult = AskOptions (nOpt,szMsg,szField1,svEdit1,szField2,svEdit2); 
if (nResult = BACK) goto Dlg_SdSelectFolder; 
if (svEdit1=FALSE) goto Dlg_SdStartCopy; 

Dlg_AskText ://设置数据库服务器 对话框 
szTitle = "设置IIS信息服务及数据库服务器"; 
szMsg = "现在开始设置IIS系统"; 
szQuestion=" 请输入本服务器的主机名或IP地址,安装程序将按照您提供的资料设置IIS信息服务。如果您没有填写,安装程序将自动跳过站点的创建!"; 
szServerIP="地址:"; 
szServerPort="端口:"; 
szServerIPDefault="192.168.0.1"; 
szServerPortDefault="80"; 
SetDialogTitle(DLG_ASK_TEXT,szTitle); 
nResult=SdShowDlgEdit2 (szTitle, szQuestion,szServerIP,szServerPort,szServerIPDefault,szServerPortDefault); 
if (nResult = BACK) goto Dlg_SelMode; 

Dlg_AskSQL ://设置数据库服务器 对话框 
szTitle = "设置数据库"; 
szMsg = "现在开始设置Microsoft SQL Server数据库系统"; 
szQuestion=" 请输入SQL SERVER数据库服务器的用户名和密码,安装程序将按照您上步提供的IP地址和下面的用户名和密码创建和优化数据库系统。如果您提供的用户名和密码是错误的,安装程序将自动跳过数据的设置!"; 
szSQLsvr="主机名:"; 
szSQLusr="用户名:"; 
szSQLpwd="密码:"; 
svSQLsvr="localhost"; 
svSQLusr="sa"; 
szSQLpwd=""; 
SetDialogTitle(DLG_ASK_TEXT,szTitle); 
nResult=SdShowDlgEdit3 (szTitle, szQuestion,szSQLsvr,szSQLusr,szSQLpwd,svSQLsvr,svSQLusr,svSQLpwd); 
if (nResult = BACK) goto Dlg_SelMode; 

Dlg_SdStartCopy://开始复制文件 对话框 
szTitle = "开始复制文件"; 
szMsg = "点击下一步开始复制文件"; 
listStartCopy = ListCreate( STRINGLIST ); 
ListAddString(listStartCopy,"用户名:"+svName,AFTER); 
ListAddString(listStartCopy,"公司名称:"+svCompany,AFTER); 
ListAddString(listStartCopy,"序列号:"+svSerial,AFTER); 
ListAddString(listStartCopy,"目标目录:"+szDir,AFTER); 
if (svEdit1=TRUE) then 
ListAddString(listStartCopy,"IP地址:"+szServerIPDefault,AFTER); 
ListAddString(listStartCopy,"端口号:"+szServerPortDefault,AFTER); 
endif; 
ListAddString(listStartCopy,"请确认您填写的信息,按下一步开始复制文件",AFTER); 
nResult = SdStartCopy( szTitle, szMsg, listStartCopy ); 
ListDestroy(listStartCopy); 
if (nResult = BACK) goto Dlg_AskText; 
// setup default status 
SetStatusWindow(0, ""); 
Enable(STATUSEX); 
StatusUpdate(ON, 100); 
if (svEdit1=TRUE) then 
CreateWebSite(szServerIPDefault,szServerPortDefault); // 开始创建 IIS 站点 
endif; 
if (svEdit2=TRUE) then 
CreateVirtualDir("NetOA"); // 开始创建 IIS 站点 
endif; 
CreateDataBase(svSQLsvr,svSQLusr,svSQLpwd); // 创建和优化数据库 

return 0; 
end; 
// 
// 
// 函数: OnFirstUIAfter 
// 
// 事件: FirstUIAfter event is sent after file transfer, when installation 
// is run for the first time on given machine. In this event handler 
// installation usually displays UI that will inform end user that 
// installation has been completed successfully. 
// 
/// 
function OnFirstUIAfter() 
STRING szTitle,szMsg1, szMsg2, szOption1, szOption2,szCmdLine; 
NUMBER bOpt1, bOpt2; 

begin 
//set_vod_liveaddress(); 

szCmdLine = SUPPORTDIR ^"SCE10CHS.EXE"; 
if (LaunchAppAndWait(szCmdLine, " /q",WAIT) < 0) then 
MessageBox ("不能安装解码程序,请联系供应商.",SEVERE); 
endif; 

Disable(STATUSEX); 
bOpt1 = FALSE; 
bOpt2 = FALSE; 
szMsg1 = SdLoadString(IFX_SDFINISH_MSG1); 
szMsg2 = "请浏览本主机WEB服务器上的 "+@PRODUCT_NAME+" 虚拟目录/n/n 例:/n http://Localhost/ 
szOption1 = ""; 
szOption2 = ""; 
szTitle = @PRODUCT_NAME+"安装完成"; 
SdFinishEx(szTitle,szMsg1,szMsg2,szOption1,szOption2,bOpt1,bOpt2); 

szCmdLine = "http://LocalHost"; 
//if (LaunchApp(PROGRAMFILES ^"Internet Explorer"^"IEXPLORE.EXE", szCmdLine) < 0) then 
//MessageBox ("不能打开浏览器.",SEVERE); 
//endif; 

return 0; 
end; 

// 
// 创建IIS站点 
// 
function CreateWebSite(szServerIPDefault,szServerPortDefault) 
STRING szCmdLine,szWaitTxt; 
begin 
if ((szServerIPDefault = "") || (szServerPortDefault = "")) then 
  MessageBox ("您没有设定"+@PRODUCT_NAME+"运行的服务器IP地址或端口!!IIS信息服务设置失败!/n请自行创建IIS站点,并将主目录设为:"+TARGETDIR,SEVERE); 
else 
  szWaitTxt=" 正在创建IIS和设置站点...."; 
  SdShowMsg (szWaitTxt, TRUE); 
  Delay(2); 
  szCmdLine = SUPPORTDIR ^"mkw3site.vbs"+" -r "+TARGETDIR+" -i "+szServerIPDefault+" -o "+szServerPortDefault+" -t "+@PRODUCT_NAME; 
  if (LaunchAppAndWait("WScript.exe", szCmdLine,WAIT) < 0) then 
  MessageBox ("不能建立WEB 虚拟目录,没有找到 WScript.exe 或执行脚本错误.",SEVERE); 
  endif; 
  SdShowMsg (szWaitTxt, FALSE); 
endif; 
return 0; 
end; 

// 
// 创建虚拟目录 
// 
function CreateVirtualDir(VirtualFolder) 
STRING szCmdLine,szWaitTxt; 
begin 
if (VirtualFolder = "") then 
  MessageBox ("没能读取到虚拟目录的名称!请联系系统供应商!"+TARGETDIR,SEVERE); 
else 
  szWaitTxt=" 正在创建"+@PRODUCT_NAME+"的虚拟目录...."; 
  SdShowMsg (szWaitTxt, TRUE); 
  Delay(2); 
  szCmdLine = SUPPORTDIR ^"mkwebdir.vbs "+" -w 1 -v /""+VirtualFolder+"/",/""+ TARGETDIR+"/"" ; 
  if (LaunchAppAndWait("WScript.exe", szCmdLine,WAIT) < 0) then 
  MessageBox ("不能建立WEB 虚拟目录,没有找到 WScript.exe 或执行脚本错误.",SEVERE); 
  endif; 
  SdShowMsg (szWaitTxt, FALSE); 
endif; 
return 0; 
end; 

// 
// 创建和优化数据库 
// 
function CreateDataBase(svSQLsvr,svSQLusr,svSQLpwd) 
STRING szCmdLine,szWaitTxt; 
begin 
szWaitTxt=" 正在创建"+@PRODUCT_NAME+"所需数据库...."; 
SdShowMsg (szWaitTxt, TRUE); 
Delay(2); 
szCmdLine = "/U "+svSQLusr+" /P "+svSQLpwd+" /S "+svSQLsvr+" /Q /"exec sp_attach_db N'OASystem' , N'"+SUPPORTDIR ^"OASystem_data.mdf'/""; 
if (LaunchAppAndWait("osql.exe", szCmdLine,WAIT) < 0) then 
  MessageBox ("数据库创建失败!请确您的系统中已安装 Microsoft SQL Server 2000./n如仍无法解决,请联系系统供应商!",SEVERE); 
endif; 
SdShowMsg (szWaitTxt, FALSE); 
szWaitTxt=" 正在优化"+@PRODUCT_NAME+"系统数据库...."; 
SdShowMsg (szWaitTxt, TRUE); 
Delay(2); 
szCmdLine = "/U "+svSQLusr+" /P "+svSQLpwd+" /S "+svSQLsvr+" /Q /"use OASystem ; exec sp_updatestats/""; 
if (LaunchAppAndWait("osql.exe", szCmdLine,WAIT) < 0) then 
  MessageBox ("数据库优化失败!您可以在 sql查询分析器中执行 /n use OASystem ; exec sp_updatestats /n完成!",SEVERE); 
endif; 
SdShowMsg (szWaitTxt, FALSE); 
return 0; 
end; 

这篇关于用InstallShield 进行ASP 软件的打包和自动安装的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/625809

相关文章

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa

Java进行文件格式校验的方案详解

《Java进行文件格式校验的方案详解》这篇文章主要为大家详细介绍了Java中进行文件格式校验的相关方案,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、背景异常现象原因排查用户的无心之过二、解决方案Magandroidic Number判断主流检测库对比Tika的使用区分zip

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

SpringBoot中封装Cors自动配置方式

《SpringBoot中封装Cors自动配置方式》:本文主要介绍SpringBoot中封装Cors自动配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot封装Cors自动配置背景实现步骤1. 创建 GlobalCorsProperties

Flutter打包APK的几种方式小结

《Flutter打包APK的几种方式小结》Flutter打包不同于RN,Flutter可以在AndroidStudio里编写Flutter代码并最终打包为APK,本篇主要阐述涉及到的几种打包方式,通... 目录前言1. android原生打包APK方式2. Flutter通过原生工程打包方式3. Futte