重写IInternetSecurityManager中的GetSecurityId

时间:2009-09-30 13:43:08

标签: c++ security internet-explorer webbrowser-control xss

我已经构建了一个可执行文件,它启动了一个对话框,其中嵌入了IE Web浏览器active-x control(C ++)。

我希望此控件允许跨站点脚本。网页上的一个框架加载本地html,其他框架从服务器加载。然后我想让服务器页面调用一个存在于本地html文件中的javascript函数。

我试图通过让控件实现它自己的“IInternetSecurityManager”接口来实现这一点,我在其中提供了我自己的ProcessUrlAction和GetSecurityId方法。

根据我的阅读,我需要做的是让GetSecurityId为所有网址返回相同的域名。我的自定义实现被调用,但无论我做什么,当服务器html尝试访问本地html文件上的脚本时,我得到“权限被拒绝”错误。以下是我的实现。有没有人看错了什么?

#define SECURITY_DOMAIN "http:www.mysite.com"


    STDMETHOD (GetSecurityId)(      
        LPCWSTR pwszUrl,
        BYTE *pbSecurityId,
        DWORD *pcbSecurityId,
        DWORD_PTR dwReserved)
    {
        if (*pcbSecurityId >=512)
        {
            memset(pbSecurityId,0,*pcbSecurityId);
            strcpy((char*)pbSecurityId,SECURITY_DOMAIN);
            pbSecurityId[strlen(SECURITY_DOMAIN)] = 3;
            pbSecurityId[strlen(SECURITY_DOMAIN)+1] = 0;
            pbSecurityId[strlen(SECURITY_DOMAIN)+2] = 0;
            pbSecurityId[strlen(SECURITY_DOMAIN)+3] = 0;

            *pcbSecurityId = (DWORD)strlen(SECURITY_DOMAIN)+4;
            return S_OK;


        }
        return INET_E_DEFAULT_ACTION;
    }

STDMETHOD(ProcessUrlAction)(
        /* [in] */ LPCWSTR pwszUrl,
        /* [in] */ DWORD dwAction,
        /* [size_is][out] */ BYTE __RPC_FAR *pPolicy,
        /* [in] */ DWORD cbPolicy,
        /* [in] */ BYTE __RPC_FAR *pContext,
        /* [in] */ DWORD cbContext,
        /* [in] */ DWORD dwFlags,
        /* [in] */ DWORD dwReserved)
    {

        DWORD dwPolicy=URLPOLICY_ALLOW;
        if ( cbPolicy >= sizeof (DWORD))
        {
            *(DWORD*) pPolicy = dwPolicy;
            return S_OK;
        } 

        return INET_E_DEFAULT_ACTION;
    }

1 个答案:

答案 0 :(得分:4)

通过将这些功能委派给普通安全管理器并查看普通安全管理器填写的结构,我能够确定我的问题是在GetSecurityId中。出于我的目的,我想将安全域设置为所有角色的本地文件。

#define SECURITY_DOMAIN "file:"

if (*pcbSecurityId >=512)
{
    memset(pbSecurityId,0,*pcbSecurityId);
    strcpy((char*)pbSecurityId,SECURITY_DOMAIN);
    pbSecurityId[strlen(SECURITY_DOMAIN)+1] = 0;
    pbSecurityId[strlen(SECURITY_DOMAIN)+2] = 0;
    pbSecurityId[strlen(SECURITY_DOMAIN)+3] = 0;
    pbSecurityId[strlen(SECURITY_DOMAIN)+4] = 0;

    *pcbSecurityId = (DWORD)strlen(SECURITY_DOMAIN)+4;
}