我正在尝试为动态CRM创建一个java脚本Web资源,它实质上允许用户选择要上载的文件,然后将其存储到注释实体中。我知道执行此操作的一般过程,但它会继续上传空文件。使用base 64函数不会将数据转换为base 64。我很难使用文件读取器功能将上传的文件转换为base 64. dataURL变量保持返回空。有人可以帮助我将所选文件转换为base 64吗?这不一定是动态特定的我认为它是一般的java脚本html问题。我想我使用文件阅读器功能错了。
谢谢
function uploadFile(event) {
var input = event.target;
var file = input.files[0];
//var file = document.getElementById("myFile").files[0];
var str;
var reader = new FileReader();
reader.onload = function() {
var dataURL = reader.result;
str = _arrayBufferToBase64(dataURL);
};
reader.readAsDataURL(input.files[0]);
var id = window.parent.Xrm.Page.data.entity.getId();
var nam = window.parent.Xrm.Page.data.entity.getEntityName();
var entity = {};
entity.Subject = "first new annotation3";
entity.NoteText = "way to go you just made a new annotation";
entity.DocumentBody = str;
entity.FileName = file.name;
entity.MimeType = file.type;
entity.ObjectId = {
Id: id,
LogicalName: nam
};
SDK.REST.createRecord(entity, "Annotation", SucessCallback2, errorCallback2);
}
function _arrayBufferToBase64(buffer) { // Convert Array Buffer to Base 64 string
var binary = '';
var bytes = new Uint8Array(buffer);
var len = bytes.byteLength;
for (var i = 0; i < len; i++) {
binary += String.fromCharCode(bytes[i]);
}
return window.btoa(binary);
}
<
input type = "file"
id = "myFile"
placeholder = "Choose File"
onchange = "uploadFile(event)" >
答案 0 :(得分:1)
我想出来了,对于其他有类似问题的人。事实证明,你不能把数据带到onload函数之外,你必须使用回调函数将数据传递给另一个函数。见下文。
function uploadFile(event)
{
var input = event.target;
var file = input.files[0];
//var file = document.getElementById("myFile").files[0];
var str;
var reader = new FileReader();
reader.onload = function(eve){
var theResult = reader.result;
str = _arrayBufferToBase64(theResult);
AttachFileFunction(file.name,file.type,str);
};
reader.readAsArrayBuffer(file);
&#13;