【发布时间】:2018-04-02 02:05:30
【问题描述】:
请注意,我说的是将我的代码注入 SharePoint 服务器端(通过包/加载项等),而不是使用 Microsoft.SharePoint.dll 或 Web 服务来访问 SharePoint。
所以我的问题是,我需要自定义文档库的工作方式,包括自定义权限管理。我一直在浏览Microsoft.SharePoint.dll 分析其工作的内部结构。以下是我的观察:
-
SPDocumentLibrary提供管理文档库的核心逻辑。但是,它本身并不是WebPart。 - 文档库的实际 Web 部件呈现可能由
ListViewWebPart或派生类处理。 - 实际上有一个
SPPictureLibrary类,这让我认为可以继承SPDocumentLibrary类以在文档库上提供自定义行为。 -
WebPartAdder.SiteWebPartGalleryProvider以某种方式将SPDocumentLibrary连接到其WebPart内部的Microsoft.SharePoint.WebPartPages.WebPartAdder.AddSources方法。
现在所有这些都是客户端,这些都不会发生在 SharePoint 服务器本身 (afaik) 上。但是我在SPSecurableObject 上看到SPDocumentLibrary/SPList 覆盖的可覆盖方法,具体来说:
CheckPermissionsGetUserEffectivePermissionInfoGetUserEffectivePermissions-
EffectiveBasePermissions等
我真正想做的是能够在 SharePoint 服务器内的 SPDocumentLibrary 上覆盖 CheckPermissions / EffectiveBasePermissions 以注入我的自定义逻辑。
我现在会将我的研究转移到 SharePoint 服务器端 dll 并理解它们。但我很想就这是否可行/指向正确的方向获得一些专家意见。 Microsoft 的标志(特别是考虑将 ASP.NET 2.0 / ASP.NET MVC 作为基准)是可扩展性/提供程序框架。它们为开箱即用的“事物”提供了出色的提供者,但您可以通过继承/实现某些东西来替换默认提供者来创建类。所以:
- 我可以注入 SharePoint 服务器端吗?我理想的解决方案是创建一个
SPDocumentLibrary派生类(服务器端),并将其注入,以便在实例化文档库时创建我的类对象(而不是SPDocumentLibrary,假设这是类服务器-侧也是。我仍然需要“反映”SharePoint 服务器端类)。 - 如果 1) 不正确,我是否可以创建一个自定义
WebPart来使用 SharePoint 文档库,使其具有原生文档库的感觉,但仍然允许我在该情况下使用SPDocumentLibrary派生类访问 web 部件(请再次注意,我所有的讨论都围绕 SharePoint 服务器端,即我的代码在 SharePoint 的地址空间/w3wp 进程内执行)。 - 为什么我们在
SPSite.EffectiveBasePermissions中有逻辑。我的意思是它应该是 CSOM,它应该只负责对服务器返回/发送的内容进行序列化/反序列化。但是,我在这个被覆盖的属性中看到了围绕权限推导的复杂逻辑。 - 如果 1) 和 2) 都是无操作(字面意思是 :)),在 SharePoint 采取基于这些权限的任何操作之前,我是否可以在 SharePoint 的地址空间中操作时操纵 SharePoint 有效权限。
我知道这是一个很长的问题,但希望我的研究做得很好。
【问题讨论】:
-
您是否考虑过实施自定义角色提供程序?也许您可以将一些自定义声明应用于您的文档库,然后将这些自定义声明插入到正在运行的标识中。 geekswithblogs.net/GinoAbraham/archive/2017/03/21/…
标签: sharepoint sharepoint-2010 sharepoint-2013 sharepoint-online sharepoint-2016