I have done the file uploading using below code in electron app
if (window.FormData !== undefined) {
var formData = new FormData();
let response = await fetch(path); // give local file path stored at appdata folder
let data = await response.blob();
formData.append("file", new File([data], "YourfileName"))
let _url = "api/webservice url";
$.ajax({
type: "POST",
url: _url,
contentType: false,
processData: false,
data: formData,
success: function (result) {
console.log(result);
},
error: function (xhr, status, p3, p4) {
var err = "Error " + " " + status + " " + p3 + " " + p4;
if (xhr.responseText && xhr.responseText[0] == "{")
err = JSON.parse(xhr.responseText).Message;
console.log(err);
}
});
} else {
alert("This browser doesn't support HTML5 file uploads!");
}
At server side (C# Code)
var provider = new MultipartMemoryStreamProvider();
await Request.Content.ReadAsMultipartAsync(provider);
// extract file name and file contents
var fileNameParam = provider.Contents[0].Headers.ContentDisposition.Parameters
.FirstOrDefault(p => p.Name.ToLower() == "filename");
string fileName = (fileNameParam == null) ? "" : ileNameParam.Value.Trim('"');
var divs = fileName.Split('.').ToList();
var ext = divs.LastOrDefault();
byte[] file = await provider.Contents[0].ReadAsByteArrayAsync();
// Here you can use EF with an entity with a byte[] property, or
// an stored procedure with a varbinary parameter to insert the
// data into the DB
var fileVM = new FileViewModel
{
AttachmentType = AttachmentTypeEnum.File,
FileName = fileName,
FileExtension = ext,
ContentType = MimeMapping.GetMimeMapping(fileName),
ContentLength = file.Length,
ContentByte = file,
};