我有一个简单的html表单,我有一个请求是使用REST上传文件到Sharepoint Server 2013(从网上参考代码)。
以下是代码段
<html>
<head>
<script src="https://ajax.aspnetcdn.com/ajax/jQuery/jquery-1.9.1.min.js" type="text/javascript"></script>
<script>
function AddAttachments()
{
var digest = "";
$.ajax(
{
url: "http://vmjnjlabeling01:22216/as/Shared Documents/_api/contextinfo",
method: "POST",
headers: {
"ACCEPT": "application/json;odata=verbose",
"content-type": "application/json;odata=verbose",
"Authorization" : "Basic c3AyMDEzOlNoYXJlcG9pbnRAMjAxMw=="
},
success: function (data) {
digest = data.d.GetContextWebInformation.FormDigestValue;
},
error: function (data) {
}
}).done(function() {
var fileInput = $('#uploadFile');
var fileName = fileInput[0].files[0].name;
var reader = new FileReader();
reader.onload = function (e) {
var fileData = e.target.result;
var res11 = $.ajax(
{
//url: "http://vmjnjlabeling01:22216/as/_api/web/lists/getbytitle('DocTest')/items(1)/AttachmentFiles/ add(FileName='" + fileName + "')",
url:"http://vmjnjlabeling01:22216/as/_api/web/getfolderbyserverrelativeurl('/as/Shared Documents')/Files/add(overwrite=true, url='" + fileName + "')",
method: "POST",
binaryStringRequestBody: true,
data: fileData,
processData: false,
headers: {
"ACCEPT": "application/json;odata=verbose",
"X-RequestDigest": digest,
// "content-length": fileData.byteLength
},
success: function (data) {
},
error: function (data) {
alert("Error occured." + data.responseText);
}
});
};
reader.readAsArrayBuffer(fileInput[0].files[0]);
});
}
</script>
</head>
<body>
<div>
<input id="uploadFile" type="file">
</div>
<div>
<input type="submit" onclick="AddAttachments()" value="Add Attachments"> </input>
</div>
</body>
</html>
但是当我上传文档时,我每次都会收到401错误,尽管已经给出了所有权限。
非常感谢有关此主题的任何帮助以解决此问题。
此致 Ñ
答案 0 :(得分:1)
您需要启用基本身份验证凭据,该凭据在身份验证提供程序中以明文形式发送。 去 中央管理>>安全性>>安全身份验证提供程序>> 在右侧下拉列表中,选择应用程序,然后单击默认值
声明身份验证类型中的基本身份验证
答案 1 :(得分:0)
因为您的页面不在SharePoint内部(您没有得到任何&#34; SharePoint&#34;在其中),您需要以不同于SharePoint页面的方式进行授权。最简单的答案可能是查看加载项模型的工作原理。另一方面,由于除了您尝试上传附件之外,页面上没有任何内容,该页面是否可以成为SharePoint页面?