Требования безопасности доступа к коду PortalSiteMapprovider

Я использую объект portalsitemapprovider для создания элемента управления моего сервера навигации.

Я назначил права доступа к объектной модели sharepoint и права олицетворения в элементах управления CAS. Однако, несмотря на это, я не могу получить дочерние узлы корневого узла карты сайта, они просто возвращают ошибку.

Если я изменю веб-приложение для работы с полным доверием, я могу получить дочерние узлы.

Таким образом, мой вопрос заключается в том, какие политики CAS требуются для полного доступа к данным в объекте поставщика карты сайта, и почему я могу получить доступ к корневому узлу, но не к его дочерним элементам в настоящее время?

Пример кода:

PortalSiteMapProvider sp = PortalSiteMapProvider.WebSiteMapProvider;
PortalSiteMapNode rootNode = (PortalSiteMapNode)siteProvider.RootNode;
foreach (SiteMapNode node in rootNode.ChildNodes)
{
    //this loop returns 1 item with title "Error" with no exception thrown. 
}

Моя сборка имеет следующие запросы CAS:

[assembly: SharePointermission(SecurityAction.RequestMinimum, ObjectModel=true, Impersonate=true)]

С соответствующими записями IPermission в манифесте развертывания. После развертывания веб-приложения web.config обновляется до уровня доверия WSS_Custom, как и ожидалось.

Есть идеи?

Спасибо

1 ответ

Вы можете попробовать использовать Reflector. Это должно показать вам разрешения CAS для этого класса.

Или используйте WSPBuilder, который будет использовать отражение для создания файла CAS для вас. Я рекомендую эту опцию, так как вам не нужно беспокоиться о повторном редактировании файлов CAS!

Другие вопросы по тегам