[Guid("CB5BDC81-93C1-11CF-8F20-00805F2CD064"),InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
public interface IObjectSafety { // methods void GetInterfacceSafyOptions( System.Int32 riid, out System.Int32 pdwSupportedOptions, out System.Int32 pdwEnabledOptions); void SetInterfaceSafetyOptions( System.Int32 riid, System.Int32 dwOptionsSetMask, System.Int32 dwEnabledOptions); } |
#region IObjectSafety 成员
public void GetInterfacceSafyOptions(Int32 riid, out Int32 pdwSupportedOptions, out Int32 pdwEnabledOptions) { pdwSupportedOptions = 1; pdwEnabledOptions = 2; } public void SetInterfaceSafetyOptions(Int32 riid, Int32 dwOptionsSetMask, Int32 dwEnabledOptions) { } #endregion |
三.发布
用到MakeCert.exe,Cert2Spc.exe,SignCode.exe.这些文件
安装VS的时候已经安装.不知道位置,可以使用windows的搜索功能.
首先,利用MakeCert生成一个
证书cer和一个私匙pvk.
MakeCert -sv MyKey.pvk n "CN=My Software
Company" MyCert.cer
然后,用Cert2Spc将.cer文件转换成为PKCS
#7软件发布Certificate(.spc文件)
Cert2Spc MyCert.cer
MyCert.spc
最后,用SignCode,按着提示操作对文件进行数字签名(cab,msi,exe,这些文件是你事先打好
的包)(dll的还没有测试,明天测试吧)
提示:cab包可使用system32目录下的iexpress.exe工具打包
真正需要发布的时候,要从签名授权中心申请,并得到私匙.
四.使用
<OBJECT ID="myobj"
CLASSID="clsid:....................................."
CODEBASE="http://server.com/ctrl1.cab#version=8,0,0,5007">
</OBJECT>
说明:
ID:唯一标识.JS交互时可
用.e.g.onclick="myobj.publicmethod1();"
CLASSID:控件的系统标识.clsid:开
头,其后内容可用GUID,也可用文件名#命名空间.控件类名
CODEBASE:下载地址#版本号.版本号用于自动更新.
我测试的时候TM就搞不懂
下载的CAB包就是装不上
做成EXE的时候会安装到添家删除程序里,不爽,更新升级也麻烦
直接使用DLL时用GUID又调用不出来
娘那个腿的.明天测试DLL文件签名,切记切记
附:INF的写法
最开始一般是[Version]区:
eg: [Version] signature="$XXXX$" AdvancedINF=2.0 接下来就是最重要的[Add.Code]区: eg: [Add.Code] Ctrl1.dll=C1Section Ctrl2.dll=Ctrl2.dll 前面是要下载的文件名,后面是对应这个文件的区域名,可以是任何名字,不过一般都是和文件的名字相同,这样方便维护。还有需要注意 是在[Add.Code]区出现的文件要根据依赖性进行排序,例如前面说的ctrl1.dll要依赖于ctrl2.dll,则ctrl2.dll要出现在 ctrl1.dll的前面。因为安装时是按照相反的顺序进行的,也就是说先安装ctrl2.dll,然后才是ctrl1.dll,哧哧,记清楚了,不要搞 反了。 再接下来是各个文件的区域了 [Ctrl1.dll] file-win32-x86=thiscab RegisterServer=yes clsid={.....} DestDir= FileVersion=1,0,0,0 [Ctrl1.dll]区域中的第一个file值告诉ie到哪里去得到这个dll,file一共包括三个部分,第一部分是 file,这个永远都是这样的(至少目前来说);第二部分告诉声明支持的OS,win32表示windows,mac就是苹果MAC OX了;第三部分是CPU类型,比如说x86、 ppc (Power PC)、 mips或者alpha了。 file的值可以取三个一个URL、ignore和thiscab,如果是URL则说明到URL所在的位置去下;如果是 ignore说明对于这种OS和CPU,不需要下载这个文件(ctrl1.dll);如果是thiscab很明显就在当前的cab文件中了。 接下来是RegisterServer,可以取两个值yes和no,如果为yes则说明ie要注册该dll,如果是no就不必了; 再下来是DestDir,它的值是dll将要存到本地硬盘的位置,如果它的值是10,则将dll放到\Windows或者\ WinNT下;如果是11,则放到\Windows\System或者 \WinNT\System32下;如果是空(就是没有值)则会放到\Windows或者\WinNT下的Downloaded Program Files目录下; 最后是FileVersion,这个就比较明显了,说明了ctrl1.dll的版本号。 有时候我们使用VB来开发控件的时候,需要将VB的虚拟机装上去,它需要一些其它的说明的,简单地讲一下吧: 在[Add.Code]中增加一项MSVBVM60.DLL=MSVBVM60.DLL(以VB6为例)下面是 MSVBVM60.DLL区域: [MSVBVM60.DLL] hook=MSVBVM60.cab_Installer FileVersion=6,0,81,76 FileVersion很明显,是版本号,就不再说发,就说说hook吧。 hook区域是在安装的时候需要执行的区域,它分为两种,一种是有条件的,另外一种是无条件的,无条件的hook区域是必须执行 的,反之则根据条件判断是否执行。以[Setup Hooks]标记的区域是无条件区域,如下所示 [Setup Hooks] hookname=section-name [section-name] run=%EXTRACT_DIR%\setup.exe 无条件区域常用来通过一个inf文件执行一个安装程序,这就是我们在资源管理器右键点击一个inf文件时在执行安装这样的菜单的原 因了 当ie下载了一个cab文件,如果文件中没有[Add.Code],则处理[Setup Hooks]区域,运行run所指定程序,哧哧,上面就是setup.exe; 条件区域则为在一定条件下执行,前面为MSVBVM60.DLL指定的hook区域就是一个条件区域,如果在 MSVBVM60.DLL指定的CLSID或者version不能满足需要而且没有file这个命名值,则执行hook所指定的区域。 [MSVBVM60.cab_Installer] file-win32-x86=http://activex.microsoft.com/controls/vb6/VBRun60.cab run=%EXTRACT_DIR%\VBRun60.exe 上面[MSVBVM60.cab_Installer]是一个hook区域,它也包含了一个file值,指定一个URL,表示 MSVBVM60.DLL可以从这个URL下载得到;run则说明了执行哪一个文件 这里有必要说明一下的是,MS对一些常用的Redistributable Microsoft DLLs 可以通过指定CODEBASE属性为http://activex.microsoft.com/controls,这样在cab文件中就中需要包含这些文件,在计算机上有一个文件redist.txt上面的dll就是Redistributable Microsoft DLLs |