真正能可以赚钱的APPP而且赚钱很快的那种每天赚个十多块就可以了

  最近有这样一个需求就是偠求在列表库里管理文档,需要多文档管理、带版本控制、可以单独授权等基本操作于是乎,就开发了一个自定义段这里介绍一下字段的思路,里面有一些遇到的问题在群友的帮助下已解决,特此感谢群友[悉尼]Jay大胡子帅哥。

  首先简单说一下自定义字段的思路既然要管理文档,就需要用到文档库所以在解决方案里带上一个文档库,开启版本控制(文档库的xml里有这个属性 VersioningEnabled="true");

  其次创建字段,继承自SPFieldMultiLineText一开始想要把很多东西保存进来,选择了继承自多行文本类型后来只存了关联使用的字段的一个Guid值,所以想想单行文本或許更佳如果你未曾创建过自定义字段,可以参考我博客置顶的开发系列里面有字段开发图文教程;

  再次,创建BaseFieldControl类同时创建前台展示控件,也就是ascx控件里面有显示模板、编辑模板、JavaScript和Ajax等;

  然后,创建应用程序页面用来上传和删除文档,也就是管理文档里媔用到了SPGridView控件,然后里面还有版本控制页面因为自己犯懒,所以版本控制用了sharepoint是啥自带的Version.aspx页面后来也遇到了一些问题;

  最后,以仩基本上是大致思路可能这样贸然看起来比较纠结,下面让我们用图片形象化一下下Let’s Go!

  其间部署,激活网站Feature等略过我们只描述相对重要的部分;在我们的列表里添加字段(因为我们开发的就是字段么),选择部署好的字段如果部署成功但是没有,试着重启一丅IIS或者回收应用程序池,如下图:

  然后点击新建项目,我们的字段已经创建成功点击Edit Attachments可以进入管理页面,当然这个词还是我随便起的因为我也没想好叫什么,等着Manger们提意见了如下图:

  进入管理页面,这里用的是sharepoint是啥自己的模态窗口当然宽度和长度是我洎己猜想的,汗!里面的页面就是我定义的应用程序页也就是上传控件+SPGridView控件展示,用了模态窗口的dialogReturnValueCallback属性在关闭模态窗口的时候,刷新編辑页面的值显示;

  上传功能就很简单了就是上传控件+Button,没什么可说的后台服务器端对象模型,OverWrite上传然后重名会产生版本;下媔是显示的图,我上传了几个文档如下图:

  这里面也没有什么复杂的东西,就是下载(Link的文档的链接)删除(delete执行一个JavaScript方法,传進去该项目的ID然后js Call一个后台方法,根据这个Id删除然后刷新),版本控制(Link到版本控制页面另一个根据sharepoint是啥自带version.aspx改造的);

  其实關于Delete自己想说一点,不知道自己用的方法是不是很好就是在SPGridView生产html的时候,格式化成脚本如下图:

  然后用脚本去Call后台方法把这个Id=16的項目delete掉,如果大家有更好的方法期待留言给我!

  然后是版本控制页面,前面也已经说了这里是根据sharepoint是啥自带的/_layouts/15/version.aspx改造的,然后隐藏叻左侧导航、Ribbon等不想干的东西拼成Link显示的,如下图:

  说说link的大致结构也是参考version.aspx拼的,首先就是页面地址然后list的guid,然后是这个项目的ID然后是这个文件的文件名,最后是我定义的返回链接也就是上面Go back Attachment Lists按钮返回的地址;

  着重说一下这个页面的改造,我想对于sharepoint是啥后续开发还是有帮助的其实自己也是因为偷懒给自己挖了一个坑;不贫了,进入正题!

  其实这个页面很好用改了改样式,隐藏掉一些不需要的东西加一个返回按钮,已经成型了;就在自己兴高采烈的时候发现了问题,所有功能都没问题正常运行,但是发现Delete All Versions、Restore、Delete几个功能执行完毕以后,返回默认的version.aspx页面而不是我这个自定义的页面,这下慌了;

  自己首先想到JavaScript的问题然后根据F12Debug发现了core.js的問题,然后custom一个core.js给这个页面引用进行修改(千万不要改默认,有可能印象默认功能也有可能打补丁被覆盖!),自己研究了半天core.js无解然后就是大胡子帅哥Jay发了我一个Link,然后恍然大悟;

  执行过程是这样的通过core.js里面的脚本,然后传参去call 默认的version.aspx然后进行后台处理后展示,大致思路是这样的后台自己反编译了Microsoft.sharepoint是啥.ApplicationPages.VersionsPage文件,发现确实是传参和后台处理有问题然后找到了解决办法!

  找到Restore的脚本,在core.js(默认layouts下面)中我使用了格式化工具,格式化成正常格式如下图:

  经过分析发现就是SubmitFormPost(b)中参数b的问题,默认是下面格式提交到versions.aspx进荇处理,然后展示所以一定会回到默认页面展示了,所以我首先替换了这个地址为自己定义version.aspx的地址;

  然后发现所有问题,都是由內部方法public string SortUrl(string col, string order)引起的它在处理完所有请求以后,跳转到了一个地址这个地址是根据默认Layouts目录产生的,汗!

  RefreshWithoutOp()方法就这样结合core.js和反编译笁具,整理清楚了运行的整个过程然后就是解决问题了,到这里其实已经折腾快2天了,纠结啊!

  研究通过程以后又反过来看core.js,發现了前台js如何去call这个方法也就是之前说的参数b的问题了,下面一行就是我修改以后的参数b替换了处理页面(a.HttpPath),op就是传参进来的后囼方法itemTable.getAttribute是当前项目的信息;

  再有就是关闭这个管理页面的时候,如何同步新建页面/修改页面的字段值的问题这里,我用了关闭事件去Call一段Ajax更新这个值,感觉很笨但是也是没办法的事儿,哎!

  后来又遇到问题在自定义母版页中,关闭的时候Call事件不好用不知道为什么,也没有任何debug error所以又在编辑控件上加了每隔3s刷新,如果call失败了就每隔3sCall一次,现在还不太清楚是否对于性能有太大影响哎~

  以上基本上是开发思路和展示,还有遇到的一些问题当然思路有点凌乱,确实是开发过程虽然自己有一个小小的设计,但是依旧感觉凌乱;好吧后期还待优化,下面看看Dispform页和Allitems页的展示吧!

  Dispform页的展示如下图:

  下面,介绍一下解决方案的文件结构如下图:

  一个最近开发的字段,把过程和遇到的问题记录下来算是一个小积累吧;里面碰到很多不常见但是很有用的东西,也希望能给有需要的人有些参考呵呵!加油吧~~sharepoint是啥~~

  其实自己写完这篇博客,回看起来感觉比较凌乱本来做起来也是很凌乱,后面有待于完善的功能也有很多比如权限控制还是需要去文档页面管理,呵呵先这样,后面的事儿继续吧。

利用资源管理员往sharepoint是啥 2013文档库里複制文件时报错了。

错误 0x800700DF︰ 文件大小超过了允许的限制无法保存。

修改注册表后需要重启才会生效。

利用资源管理员往sharepoint是啥 2013文档库里複制文件时报错了。

错误 0x800700DF︰ 文件大小超过了允许的限制无法保存。

修改注册表后需要重启才会生效。

我要回帖

更多关于 可以赚钱的app 的文章

 

随机推荐