一、指出ActiveX控件對(duì)于腳本與數(shù)據(jù)初始化是安全的
1.? 將下行添加到組件的繼承列表的末尾:
public
?IObjectSafetyImpl
<
CPolyCtl,?INTERFACESAFE_FOR_UNTRUSTED_CALLER?
|
?INTERFACESAFE_FOR_UNTRUSTED_DATA
>
2.? 將下行添加到COM 映射:
COM_INTERFACE_ENTRY(IObjectSafety) 二、電子簽名
可使用 MAKECERT 和 CERT2SPC 實(shí)用工具生成測(cè)試 Software Publisher Certificate。請(qǐng)注意,此測(cè)試 SPC 對(duì)軟件發(fā)布無效,但可用于測(cè)試
代碼簽名。
1.? 創(chuàng)建證書文件:
makecert??/sv? "私鑰文件.pvk"??/n?"CN=公司的名字"??"證書文件名.cer"?//注意保留擴(kuò)展名
2.? 轉(zhuǎn)換cer格式為spc格式:
cert2spc???dream.cer???dream.spc???3.? 給cab文件簽名
signtool?signwizard4.? 在web頁上嵌套入簽名的CAB文件
<BODY>
<OBJECT?ID="PolyCtl"?
CLASSID="CLSID:4CBBC676-507F-11D0-B98B-000000000000"
CODEBASE="http://example.sq-soft.com/mydir/myctl.cab#version=1,0,0,1">
</OBJECT>

</BODY>CODEBASE 也可以直接指向 OCX 或 DLL 文件:
三、創(chuàng)建CAB文件(摘錄自MSDN)
1.? 創(chuàng)建INF文件
;?Sample?INF?file?for?POLYGON.DLL
[version]?
;?version?signature?(same?for?both?NT?and?Win95)?do?not?remove
signature="$CHICAGO$"
AdvancedINF=2.0??

[Add.Code]
polygon.dll=polygon.dll
atl.dll=atl.dll

;?needed?DLL
[atl.dll]
file-win32-x86=thiscab
FileVersion=2,00,0,7024
DestDir=11
RegisterServer=yes?

[polygon.dll]
file-win32-x86=thiscab

clsid=
{4CBBC676-507F-11D0-B98B-000000000000}?
FileVersion=1,0,0,1?
RegisterServer=yes??
;?end?of?INF?file

其中“thiscab”是一個(gè)關(guān)鍵字,表示 CAB 包含此 DLL,也可通過指定一條絕對(duì)或相對(duì)路徑,從一個(gè) HTTP 位置下載所需的 DLL,例如:
file-win32-x86=http://example.microsoft.com/mydir/NEEDED.DLL?關(guān)鍵字“file-win32-x86”將平臺(tái)標(biāo)識(shí)為 x86 特定的。
可通過在 Windows 資源管理器中的文件上單擊鼠標(biāo)右鍵來獲取文件的版本號(hào)。從顯示的列表中選擇“屬性”,然后在顯示的對(duì)話框中選擇“版本”選項(xiàng)卡。有時(shí)需要在文件版本中額外插入一個(gè) 0。例如,在對(duì)話框中 ATL.DLL 的版本號(hào)顯示為 2.00.7024。而在 INF 文件中,這變?yōu)?2, 00, 0, 7024。
“DestDir”是將要加載文件的目錄所在的位置:11 指定系統(tǒng)目錄為 WINDOWS/SYSTEM 或 WINNT/SYSTEM32;10 指定 Windows 目錄、WINDOWS 或 WINNT。如果未指定任何 DestDir(典型情況),則代碼安裝在固定的 OCCACHE 目錄中。
“clsid”是將要安裝的控件的 CLSID。
2.? 創(chuàng)建CAB文件
創(chuàng)建了 INF 文件后,運(yùn)行 CABARC 實(shí)用工具以創(chuàng)建 CAB 文件。應(yīng)在包含源文件的目錄下運(yùn)行 CABARC。在命令行上,按源文件出現(xiàn)在 INF 中的順序排列它們,并將 INF 文件放在最后。例如:
CABARC?-s?6144? n? MYCTL.CAB?NEEDED1.DLL?NEEDED2.DLL?MYCTL.OCX?MYCTL.INF
應(yīng)在包含源文件(INF、OCX 和 DLL 文件)的目錄下運(yùn)行 CABARC。將在 CAB 文件中存檔的文件應(yīng)該按它們?cè)?INF 文件中列出的同一順序在命令行中列出。在上面的示例中,INF 文件應(yīng)該將 NEEDED1.DLL 列在第一位,接下來是 NEEDED2.DLL,然后是 MYCTL.OCX。
-s 選項(xiàng)在壓縮文件中保留用于代碼簽名的空間。n 命令指定希望創(chuàng)建 CAB 文件。
?