惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

H
Help Net Security
博客园 - Franky
GbyAI
GbyAI
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
爱范儿
爱范儿
IT之家
IT之家
酷 壳 – CoolShell
酷 壳 – CoolShell
aimingoo的专栏
aimingoo的专栏
博客园_首页
MongoDB | Blog
MongoDB | Blog
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
Recent Announcements
Recent Announcements
Scott Helme
Scott Helme
有赞技术团队
有赞技术团队
M
MIT News - Artificial intelligence
C
CERT Recently Published Vulnerability Notes
K
KPMG report finds enterprise disconnect between AI and its ROI | CIO
Jina AI
Jina AI
F
Fortinet All Blogs
N
Netflix TechBlog - Medium
L
LangChain Blog
L
LINUX DO - 最新话题
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
H
Hacker News: Front Page
MyScale Blog
MyScale Blog
P
Palo Alto Networks Blog
G
Google Developers Blog
Google DeepMind News
Google DeepMind News
AI
AI
T
Troy Hunt's Blog
Microsoft Azure Blog
Microsoft Azure Blog
阮一峰的网络日志
阮一峰的网络日志
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
Vercel News
Vercel News
Microsoft Security Blog
Microsoft Security Blog
罗磊的独立博客
S
Secure Thoughts
大猫的无限游戏
大猫的无限游戏
博客园 - 叶小钗
人人都是产品经理
人人都是产品经理
Blog — PlanetScale
Blog — PlanetScale
博客园 - 司徒正美
Apple Machine Learning Research
Apple Machine Learning Research
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
博客园 - 三生石上(FineUI控件)
S
Security @ Cisco Blogs
Cloudbric
Cloudbric
E
Exploit-DB.com RSS Feed
Attack and Defense Labs
Attack and Defense Labs

博客园 - joe

通过70-542 在sharepoint中利用文档库扩展新闻应用(引用) 屏蔽“网站操作”菜单 图片库不能以缩略图方式显示的原因 - joe - 博客园 新建文件夹的时候自动按照文档库模板生成子文件夹和文件的解决代码 在SSP中通过ldap方式导入用户信息 form认证搜索不了的解决办法 form认证让“记住我”自动勾上 - joe - 博客园 安装MOSS的账号问题 Excel Calculation Services 无法启动的原因 sharepoint域认证的时候给用户一个友好的登陆界面 实现sharepoint 内容编辑器直接上传图片功能 sharepoint2007单点登陆问题 用户信息不同步的问题 在其他应用程序上传文件到MOSS文档库的例子 此网页的安全性验证无效并且可能损坏的错误的解决方法 wss2 如何在页面上显示登陆的用户名 找到表中某一列值相同的记录,而且只要其中一条记录的sql 三、设计一个K2.net2003的工作流程
一个文档库权限控制的eventhandler
joe · 2009-11-05 · via 博客园 - joe

      最近在写一个文档库的eventhandler,目的是是操作人拥有对自己新建的文件夹(文件)完全控制的权限,这样该用户就可以完全控制属于自己的文件。一个简单的eventhandler,折磨了我1,2日的时间,为了以后防止这样的“低级”错误,所以要记下来。

      注意红色代码部分,当前用户不一定拥有某些代码的执行权限,所以使用提升权限方法,尽量提升为管理员权限去执行。建议以下写法:

 using (SPSite ElevatedSite = new SPSite(properties.SiteId))
                {
                    using (SPWeb ElevatedWeb = ElevatedSite.OpenWeb(properties.OpenWeb().ID))

      另外list.GetItemById方法和list.Items.GetItemById方法是有区别的,用list.Items.GetItemById的效率比较低,因为它会首先获取所有的item,所以建议尽量用list.GetItemById
SPListItem item = list.GetItemById(properties.ListItemId);

上代码:

using System;
using System.Collections.Generic;
using System.Text;
using Microsoft.SharePoint;

namespace ******.EventHandle
{
    //此类的作用就是用户上传文档的时候给用户完全对自己的文件完全控制的权限,这样就可以在文档库级别给用户添加的权限就行了
    public class ControlMyDoc : SPItemEventReceiver
    {
        public override void ItemAdded(SPItemEventProperties properties)
        {
            SPSecurity.RunWithElevatedPrivileges(delegate()
            {
                using (SPSite ElevatedSite = new SPSite(properties.SiteId))
                {
                    using (SPWeb ElevatedWeb = ElevatedSite.OpenWeb(properties.OpenWeb().ID))
                    {
                        try
                        {
                            ElevatedWeb.AllowUnsafeUpdates = true;
                            string SiteCollectionOwner = ElevatedSite.Owner.Name;

                            SPList list = ElevatedWeb.Lists[properties.ListId];
                            SPListItem item = list.GetItemById(properties.ListItemId);

                            //如果是基础父级权限,没独立出来权限的话就拷贝父级权限,然后脱离继承
                            if (!item.HasUniqueRoleAssignments)
                            {
                                item.BreakRoleInheritance(true);//取消权限继承,如果false去除所有权限,true复制所有权限并停止继承
                               
                              
                            }
                            else
                            {
                                //先重新继承上级权限,再去除所有权限重新分配
                                properties.ListItem.ResetRoleInheritance();
                                properties.ListItem.BreakRoleInheritance(true);

                              
                            }
                            SPUser user = ElevatedWeb.Users.GetByID(properties.CurrentUserId);
                            SPRoleAssignment ra1 = new SPRoleAssignment(ElevatedWeb.EnsureUser(user.LoginName));
                            ra1.RoleDefinitionBindings.Add(ElevatedWeb.RoleDefinitions["完全控制"]);
                            item.RoleAssignments.Add(ra1);


                          
                            //资料上说ItemUpdated会执行10次,用下面这个方法解决

                            this.DisableEventFiring();
                            item.Update();
                            this.EnableEventFiring();

                        }
                        catch
                        {
                          
                        }
                    }
                }
            }
            );

        }
    }

}

注意:后来发现,当文档库设置为需要签入、签出的时候,非管理员上传文档的时候,文档的权限并不能从父级剥离和继承权限,初步怀疑原因是整个操作都是以系统管理员身份进行的,但是系统管理员也并不能看到用户已上传但没签入的文档,就是说这一句的代码:SPListItem item = list.GetItemById(properties.ListItemId);里,item并不能获取到。至于怎么解决这个问题,目前还没想到。如果有想到的请告诉我一下,谢谢!