关于网友提出的“ ATLCOM数字签名问题”问题疑问,本网通过在网上对“ ATLCOM数字签名问题”有关的相关答案进行了整理,供用户进行参考,详细问题解答如下:
问题: ATLCOM数字签名问题描述:
我是VC内嵌的HTML, HTML使用ATLCOM的时侯总是弹出确认是否使用不安全的Active的问题,
效果很不好
我想问下在不改变IE设置前提下,还有没有其他方法让他自动运行,
而不提示不安全的active问题
或者提供可能或是不可能
跪谢了
当然还除了花钱去CA注册...
解决方案1:
其实楼主的问题就是关于安全组件的问题。你去找一下资料就知道了,其实就是在注册表里添加一些说明,表明自己是安全的,是值得浏览器信赖的。所以,在安全组件结合可信站点就能完全解决弹出警告的问题。因为1:插件自己申明了自己是可信的2:使用者也把该插件所在站点设为可信的。这样一来就等于双方基本都承认插件是安全的,所以浏览器就不会发出警告了(通俗的解释)。
解决方案2:IE7版本开始对安全要求比较严格,如果按照IE7默认的设置,不用CA机构的证书做签名的控件始终是不能安装的。
解决方案3: 你在MSDN搜一下"How to mark MFC ActiveX controls as Safe for Scripting and Initialization",或者"CreateComponentCategory",微软在MSDN里提到了这个问题的部分解决方案。当然,如果要最终解决还是要每年花好像xxx银子去注册。你也可参考下面的代码:
(其实也是MSDN上的东西,我在一个插件项目里用来解决安全提示问题的,如果能让客户把你的网站设置为可信任站点那就完美无缺)
希望对你有帮助。
/////////////////////////////////////////////////////////////////////////////
//创建组件种类
HRESULT CreateComponentCategory(CATID catid, WCHAR* catDescription)
{
ICatRegister* pcr = NULL ;
HRESULT hr = S_OK ;
hr = CoCreateInstance(CLSID_StdComponentCategoriesMgr,
NULL, CLSCTX_INPROC_SERVER, IID_ICatRegister, (void**)&pcr);
if (FAILED(hr))
return hr;
// Make sure the HKCR\Component Categories\{..catid...}
// key is registered.
CATEGORYINFO catinfo;
catinfo.catid = catid;
catinfo.lcid = 0x0409 ; // english
// Make sure the provided description is not too long.
// Only copy the first 127 characters if it is.
int len = wcslen(catDescription);
if (len>127)
len = 127;
wcsncpy(catinfo.szDescription, catDescription, len);
// Make sure the description is null terminated.
catinfo.szDescription[len] = '\0';
hr = pcr->RegisterCategories(1, &catinfo);
pcr->Release();
return hr;
}
/////////////////////////////////////////////////////////////////////////////
//注册组件种类
HRESULT RegisterCLSIDInCategory(REFCLSID clsid, CATID catid)
{
// Register your component categories information.
ICatRegister* pcr = NULL ;
HRESULT hr = S_OK ;
hr = CoCreateInstance(CLSID_StdComponentCategoriesMgr,
NULL, CLSCTX_INPROC_SERVER, IID_ICatRegister, (void**)&pcr);
if (SUCCEEDED(hr))
{
// Register this category as being "implemented" by the class.
CATID rgcatid[1] ;
rgcatid[0] = catid;
hr = pcr->RegisterClassImplCategories(clsid, 1, rgcatid);
}
if (pcr != NULL)
pcr->Release();
return hr;
}
////////////////////////////////////////////////////////////////////////////
//
HRESULT UnRegisterCLSIDInCategory(REFCLSID clsid, CATID catid)
{
ICatRegister* pcr = NULL ;
HRESULT hr = S_OK ;
hr = CoCreateInstance(CLSID_StdComponentCategoriesMgr,
NULL, CLSCTX_INPROC_SERVER, IID_ICatRegister, (void**)&pcr);
if (SUCCEEDED(hr))
{
// Unregister this category as being "implemented" by the class.
CATID rgcatid[1] ;
rgcatid[0] = catid;
hr = pcr->UnRegisterClassImplCategories(clsid, 1, rgcatid);
}
if (pcr != NULL)
pcr->Release();
return hr;
}
/////////////////////////////////////////////////////////////////////////////
// DllRegisterServer - Adds entries to the system registry
STDAPI DllRegisterServer(void)
{
AFX_MANAGE_STATE(_afxModuleAddrThis);
if (!AfxOleRegisterTypeLib(AfxGetInstanceHandle(), _tlid))
return ResultFromScode(SELFREG_E_TYPELIB);
if (!COleObjectFactoryEx::UpdateRegistryAll(TRUE))
return ResultFromScode(SELFREG_E_CLASS);
// 标记控件初始化安全.
// 创建初始化安全组件种类
HRESULT hr;
hr = CreateComponentCategory(CATID_SafeForInitializing, L"Controls safely initializable from persistent data!");
if (FAILED(hr))
return hr;
// 注册初始化安全
hr = RegisterCLSIDInCategory(CLSID_SafeItem, CATID_SafeForInitializing);
if (FAILED(hr))
return hr;
// 标记控件脚本安全
// 创建脚本安全组件种类
hr = CreateComponentCategory(CATID_SafeForScripting, L"Controls safely scriptable!");
if (FAILED(hr))
return hr;
// 注册脚本安全组件种类
hr = RegisterCLSIDInCategory(CLSID_SafeItem, CATID_SafeForScripting);
if (FAILED(hr))
return hr;
return NOERROR;
}
STDAPI DllUnregisterServer(void)
{
AFX_MANAGE_STATE(_afxModuleAddrThis);
// 删除控件初始化安全入口.
HRESULT hr;
hr=UnRegisterCLSIDInCategory(CLSID_SafeItem, CATID_SafeForInitializing);
if (FAILED(hr))
return hr;
// 删除控件脚本安全入口
hr=UnRegisterCLSIDInCategory(CLSID_SafeItem, CATID_SafeForScripting);
if (FAILED(hr))
return hr;
if (!AfxOleUnregisterTypeLib(_tlid, _wVerMajor, _wVerMinor))
return ResultFromScode(SELFREG_E_TYPELIB);
if (!COleObjectFactoryEx::UpdateRegistryAll(FALSE))
return ResultFromScode(SELFREG_E_CLASS);
return NOERROR;
}
花钱买CA,然后,数字签名,别无他法.
解决方案5: 微软就是垄断 要想保证控件的安全 就算是用了数字签名 也要给微软钱 IE才会给你显示(已经验证) 不然一直是(未验证)
在这种情况下,要想让自己的控件标志成安全并能无阻拦的安装、运行 基本上是不可能的。 不然微软怎么有理由找咱们收银子啊!
在应用初始化时调用InternetSetOption,使用INTERNET_OPTION_SECURITY_FLAGS选项类型来设置安全特性。
解决方案7: BOOL CXXXXXDlg::CanAccessExternal()
{
// we trust all com object
return TRUE;
}
重载这个函数