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

.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日

悬赏问题

  • ¥15 umi接入sentry遇到问题
  • ¥15 HBuilderX打包H5网页,扫码模块无法使用
  • ¥15 Javascript跳转页面后,无法执行后面代码,如何解决?
  • ¥15 echarts绘制图表
  • ¥15 请教两个关于高德地图定位不准的技术问题
  • ¥15 根据企业名称 对照两个文件 样本筛选/匹配
  • ¥15 Linux环境下CA证书更新问题
  • ¥15 sqlserver语句提取结果以外数据
  • ¥60 微信小程序如何上传QQ聊天文件
  • ¥300 开发的系统遭到无良商家的破解,请问如何防止再次发生,并追回损失