设为首页 收藏本站
查看: 905|回复: 0

[经验分享] SharePoint学习札记[1] — WSS与MOSS的关系

[复制链接]

尚未签到

发表于 2015-9-29 11:24:45 | 显示全部楼层 |阅读模式
Windows SharePoint Services 是一个用来创建能够实现信息共享和文档协作的Web站点的引擎,从而有助于提高个人和团队的生产力。它是Microsoft Windows Server™ 2003中所提供的信息工作者体系结构的重要组成部分, 为Microsoft Office System和其他的桌面应用程序提供了附加的功能,并能够作为应用程序开发的平台。
      SharePoint 站点将文件存储提升到一个新的高度,从存储文件到共享信息。这些站点可以为团队协作提供社区,使得用户能够在文档、任务、联系人、事件以及其他信息上开展协作。它们允许团队和站点管理者更轻松地管理站点内容和活动。这样的环境旨在实现轻松和灵活的部署、管理以及应用程序开发。
      Windows SharePoint Services 是一种通用方法,各种规模的组织和业务单位都可以使用它来提高业务流程的效率和团队的工作效率。通过使用有助于用户跨组织和跨地区边界保持连接的协作工具,Windows SharePoint Services 使用户能够访问他们所需的信息。
      建立在 Microsoft Windows Server 2003 之上的 Windows SharePoint Services 还提供了一个基础平台,用于构建基于 Web 的业务应用程序,可以轻松地调整和缩放这些程序以满足不断变化和日益增长的业务需求。通过使用可靠的管理控件来管理存储和 Web 基础架构,IT 部门可以采用一种节省成本的方式实现和管理高性能协作环境。由于采用大家所熟悉的基于 Web 的界面,并且与日常工具(包括 2007 Microsoft Office system)紧密集成,因此 Windows SharePoint Server 易于使用,并且可以快速进行部署。
      Microsoft Office SharePoint Service 2007是微软最新的企业协作应用和开发平台。简称MOSS,MOSS基于Window SharePoint Service 3.0 (简称WSS)开发。MOSS是收费的,WSS是免费的,只要拥有了Window Server2003的许可,就可以免费安装WSS。
     WSS拥有站点,列表,文档库,文档管理,WebPart,集群部署,站点内搜索,基于WF的工作流等功能。MOSS扩展实现了增强的文档管理,企业搜索,扩展了工作流,引入了Web内容管理,Form Service,Excel Service,个人站点等。
      以下若没有特别强调,所有内容都适合WSS和MOSS的(所有适合WSS的内容也一定适合MOSS,反之则不然)。
l         WSSIIS的扩展
      WSS基于标准的Asp.Net2.0开发,这是WSS开发中要始终记住的一点. 要精通WSS开发,一定要精通Asp.Net。      每次新建一个WSS站点,IIS中会同样新建一个网站,我们称这个网站是被WSS扩展后的网站。那么扩展后发生了什么呢?
      首先,IIS站点的所有文件的处理都被影射为需要Asp.Net运行引擎处理,而标准的IIS站点只有Asp.Net本身的文件(如aspx,asmx等)才需要运行引擎处理的,其他文件由IIS直接输出到客户端。
      查看一下站点下的web.config文件,我们看到有这么一项配置:
<httpHandlers>
      <removeverb="GET,HEAD,POST"path="*" />
      <addverb="GET,HEAD,POST"path="*"type="Microsoft.SharePoint.ApplicationRuntime.SPHttpHandler, Microsoft.SharePoint, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" />
      <addverb="OPTIONS,PROPFIND,PUT,LOCK,UNLOCK,MOVE,COPY,GETLIB,PROPPATCH,MKCOL,DELETE,(GETSOURCE),(HEADSOURCE),(POSTSOURCE)"path="*"type="Microsoft.SharePoint.ApplicationRuntime.SPHttpHandler, Microsoft.SharePoint, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" />
      <addverb="*"path="Reserved.ReportViewerWebControl.axd"type="Microsoft.Reporting.WebForms.HttpHandler, Microsoft.ReportViewer.WebForms, Version=8.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
</httpHandlers>
      HttpHandler是Asp.Net的一个扩展机制,通过实现一个HttpHandler,可以来直接针对较低层的Request,Response编程,WSS通过实现自己的HttpHandler实现对客户端所有请求文件的处理,并且通过扩展Http请求(扩展OPTIONS,PROPFIND,LOCK,UNLOCK,MOVE,COPY等动作)实现文档的在线编辑(在线编辑的实现原理可参考这篇文章:http://www.cnblogs.com/jianyi0115/archive/2007/07/15/818566.html)。
    注意httpModules节点下的这项配置:
     <addname="SPRequest"type="Microsoft.SharePoint.ApplicationRuntime.SPRequestModule, Microsoft.SharePoint, Version=12.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" />  
      HttpModule也是Asp.Net的扩展机制,通过实现一个HttpModule,可以切入Http请求的某个阶段做出相应的处理,如身份校验,初始化一些通用模块等。
      WSS通过实现SPRequestModule,切入Http请求,进行一些需要的处理。最重要的是,WSS通过SPRequestModule引入了SPVirtualPathProvider。SPRequestModule的OnInit方法中有这个关键的一句:
      SPVirtualPathProvider provider2 = new SPVirtualPathProvider();
      HostingEnvironment.RegisterVirtualPathProvider(provider2);
      VirtualPathProvider也是Asp.Net的扩展机制,通过实现VirtualPathProvider可以控制Asp.Net页面的提供机制,默认的VirtualPathProvider的实现直接访问服务器硬盘上的文件。WSS通过SPVirtualPathProvider实现了自己的页面Provider机制&#8212;WSS站点的页面是由文件系统和数据库联合存储的。
    新建一个WSS站点后,它的所有的文件都是放在硬盘上,我们通过SharePoint Designer打开一个WSS站点,可以看到完整的目录结构,这些文件实际上全部都影射到文件系统上的某个文件,这个功能叫做ghost。当我们通过SPD修改了某个文件之后,WSS会把这个修改的文件保存到数据库,这个文件跟原始的文件系统上的文件就脱离关联了,这叫做unghost.通过ghost,WSS做到了是不同的站点可以共享相同的文件,通过unghost,WSS又实现了一个站点对页面的修改不会影响到其他站点.   l         WSS的一些概念
1)Farm -- 服务器场
     服务器场是WSS最大的一个概念,整个WSS的所有服务器,包括前端服务器,数据服务器,组成了服务器场,一个服务器场有一个配置数据库,多个内容数据库,多个应用程序.
2)Application -- 应用程序
    应用程序对应IIS的一个站点,它是一个安全和程序文件的独立主体。即一个应用程序可以有自己的用户身份认证机制,有自己独立的一套运行程序文件,一个应用程序会映射到硬盘上的一个独立的目录,一般为"C:"Inetpub"wwwroot"wss"VirtualDirectories"里面的某个目录.一个应用程序下可以有多个站点集.
3)Site Collection -- 站点集
    站点集是一个虚拟的单元,在内容,用户和权限上是独立的. 一个站点集可以有多个子站点.
4)Web--站点
    站点内容和权限的组织单元.一个站点可以有多个子站点,多个列表,文档库,多个页面.站点可以有独立的权限.站点可以有子站点,站点和子站点组成树型关系.子站点的权限默认集成于父站点.
5)List-列表和文档库
    列表可以理解成一个数据库表,用来存储一些业务数据。一个列表有很多字段。WSS3.0的列表可以存放多个内容类型。6)ConentType--内容类型
    内容类型可以理解成数据实体,如用户,联系人,日程数据等。一个内容类型包含很多字段。
7)Field-字段
     可以理解成数据库的字段,Field是WSS整个架构的最底层元素。        
   l         WSS的对象模型
       WSS开发很大一部分工作是需要调用各种WSS中的对象来实现的.常用的对象都放在Microsoft .SharePoint这个dll中.我们通常的开发都要从站点集对象开始.
Using(SPSite site = new SPSte(&#8220;&#8221;))
{
&#8230;
}  
     SPSite和SPWeb对象都是需要释放资源的,如果我们自己构造这两个对象,一定要在代码执行完毕时调用Dispose方法,来释放资源.
     如果我们的代码处于WSS的运行环境之下,即代码直接运行在WSS的页面上,那么我们可以直接从WSS的上下文中获取到相关对象.
SPSIte site = SPContext.Current.Site;
SPWeb web = SPContext.Current.Web;
SPUser user = SPContext.Current.Web.CurrentUser;
    上下文对象提供了更好的性能(不需要重复创建对象),并且直接跟当前用户的身份挂钩.上下文对象由运行环境进行资源管理,不需要我们用代码来Dispose.

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-120392-1-1.html 上篇帖子: SharePoint2007安装:Microsoft.SharePoint.Upgrade.SPUpgradeException: 未能加载一个或多个类型。 下篇帖子: Integrating 3rd Party Single Sign On in Sharepoint Portal Server
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表