无法以编程方式从 SPWeb 对象获取回收站项 当代码包装在计时器作业中时



>我有一个计时器作业,通过它,我以编程方式遍历网站集中的每个网站,并希望获取每个网站的回收站项目。下面是我的代码 -

public override void Execute(Guid targetInstanceId) { SPSecurity.RunWithElevatedPrivileges(delegate { SPFarm farm = SPFarm.Local;

            SPWebService service = farm.Services.GetValue<SPWebService>("");
            foreach (SPWebApplication webapp in service.WebApplications)
            {
                foreach (SPSite site in webapp.Sites)
                {
                    foreach (SPWeb web in site.AllWebs)
                    {
                        //Get the recycle Bin Items of the site
                                SPRecycleBinQuery rbQuery = new SPRecycleBinQuery();
                                rbQuery.ItemState = SPRecycleBinItemState.SecondStageRecycleBin;
                                rbQuery.RowLimit = 10000;
                                SPRecycleBinItemCollection actualRBItems = web.GetRecycleBinItems(rbQuery);

                                if (actualRBItems != null)
                                { if (actualRBItems.Count != 0) {//do something} }
}}

}});}

但是,即使在网站回收站中有项目之后,我每次在 SPWeb.RecycleBin.Count 的代码中都会得到计数 0,而我能够获得带有项目的网站集 RB SPWeb.Site.Recyclebin。有没有人有任何想法,我的要求是分别从网站中的每个网站获取项目。任何帮助都非常感谢!

另外,补充一点,我在事件接收器中尝试了相同的代码,它有效!是计时器作业的限制还是我的代码中的问题

我已经尝试了下面的代码,并且能够循环访问列表项。

static void GetSiteRecycleBin(string pSiteUrl, int pMaxRecycleBinDelete)
    {
        try
        {
            using (SPSite site = new SPSite(pSiteUrl))
            {
                SPRecycleBinQuery query = new SPRecycleBinQuery();
                query.RowLimit = pMaxRecycleBinDelete;
                SPRecycleBinItemCollection recycleitems = site.GetRecycleBinItems(query);
                foreach (SPRecycleBinItem item in recycleitems)
                {
                }
            }
        }
        catch (Exception ex)
        {               
        }
    }

相关内容

  • 没有找到相关文章

最新更新