Quhj_ 2021-12-22 15:40 采纳率: 100%
浏览 84
已结题

.net后端获取不到前端XMLHttpRequest.send上传的文件

如题,代码如下
前端JS

function uploadBlob(blob) {
    console.log(blob);
    xmlhttp = null;
    if (window.XMLHttpRequest) {
        xmlhttp = new XMLHttpRequest();
    }
    else if (window.ActiveXObject) {
        xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
    }
    if (xmlhttp != null) {
        try {
    
            //开始上传
            xmlhttp.open('POST', '../upLoad/uploadBlob', true);
            xmlhttp.send(blob);
            xmlhttp.onload = function () {
                // 处理取回的数据(在 xmlhttp.response 中找到)
                console.log(xmlhttp.response);
            };
        } catch (error) {
            console.log(error)
        }
    }
    else {
        alert("浏览器不支持XMLHTTP.");
    }
}

后端C#

    public class upLoadController : Controller
    {
        public string UploadBlob( )
        {
            string i = Request.Files.Count.ToString();
            return i;
        }
    }

img

img

实在不知道怎么解决了,百度上找了一天,没有这种上传方式的案例,我恰好又是个钻牛角尖的人,就一直卡在这里了,望解答!

  • 写回答

1条回答 默认 最新

  • CSDN专家-showbo 2021-12-22 15:45
    关注

    用FormData对象上传。。直接传Blob数据数据目测是未生成multipart/form-data数据的multipart/form-data; boundary分隔内容,改下面这样

    
        function uploadBlob(blob) {
            console.log(blob);
            xmlhttp = null;
            if (window.XMLHttpRequest) {
                xmlhttp = new XMLHttpRequest();
            }
            else if (window.ActiveXObject) {
                xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
            }
            var fd = new FormData();///////
            fd.append('blob', blob);//////////
            if (xmlhttp != null) {
                try {
                    //开始上传
                    xmlhttp.open('POST', '../upLoad/uploadBlob', true);
                    xmlhttp.send(fd);//////////////
                    xmlhttp.onload = function () {
                        // 处理取回的数据(在 xmlhttp.response 中找到)
                        console.log(xmlhttp.response);
                    };
                } catch (error) {
                    console.log(error)
                }
            }
            else {
                alert("浏览器不支持XMLHTTP.");
            }
        }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 12月30日
  • 已采纳回答 12月22日
  • 修改了问题 12月22日
  • 创建了问题 12月22日

悬赏问题

  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效