如何解决Sharepoint Digest 超时问题
2016-07-28 14:00
357 查看
背景:将js脚本挂载在Sharepoint(以下简称sp)站点上从而构建可与sharepoint交互的web 应用。
问题:一旦页面长期没有和sharepoint进行交互(调用sp List API,文档库api等),当前页面维持的验证将会在默认时间之后过期,一般是30 minutes。这个时候再去向sharepoint上传文件时,会出现:The security validation for this page is invalid and might be corrupted.
Please use your web browser's Back button to try your operation again.
解决方法:
function listenSPPageDigest() {
var updateSPDigest = function () {
var pagaContextInfo = window._spPageContextInfo,
spDigestRefreshInterval = window._spFormDigestRefreshInterval,
siteRelativeUrl;
if (pagaContextInfo !== undefined && typeof pagaContextInfo.webServerRelativeUrl === 'string' && typeof spDigestRefreshInterval === 'number') {
siteRelativeUrl = pagaContextInfo.webServerRelativeUrl;
window.UpdateFormDigest(siteRelativeUrl, spDigestRefreshInterval);
}
};
window.setInterval(updateSPDigest, 1750000);
}
在一个只加载一次的js程序里调用以下方法,在单页面应用中,在容器js执行中调用就ok。
listenSPPageDigest();
问题:一旦页面长期没有和sharepoint进行交互(调用sp List API,文档库api等),当前页面维持的验证将会在默认时间之后过期,一般是30 minutes。这个时候再去向sharepoint上传文件时,会出现:The security validation for this page is invalid and might be corrupted.
Please use your web browser's Back button to try your operation again.
解决方法:
function listenSPPageDigest() {
var updateSPDigest = function () {
var pagaContextInfo = window._spPageContextInfo,
spDigestRefreshInterval = window._spFormDigestRefreshInterval,
siteRelativeUrl;
if (pagaContextInfo !== undefined && typeof pagaContextInfo.webServerRelativeUrl === 'string' && typeof spDigestRefreshInterval === 'number') {
siteRelativeUrl = pagaContextInfo.webServerRelativeUrl;
window.UpdateFormDigest(siteRelativeUrl, spDigestRefreshInterval);
}
};
window.setInterval(updateSPDigest, 1750000);
}
在一个只加载一次的js程序里调用以下方法,在单页面应用中,在容器js执行中调用就ok。
listenSPPageDigest();
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- MySQL 安全事宜
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 设计模式---状态模式在web前端中的应用
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法