FormData上传图片并预览报错

问题遇到的现象和发生背景
问题相关代码,请勿粘贴截图
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .container {
            padding-top: 60px;
        }
        
        .padding {
            padding: 5px 0 20px 0;
        }
        
        .progress {
            width: 800px;
            height: 20px;
            border: 1px solid #F4F4F4;
            background-color: #F4F4F4;
        }
        
        .progress-bar {
            text-align: center;
            color: #fff;
            background-color: #2E77BD;
        }
    </style>
</head>

<body>
    <div class="container">
        <div class="form-group">
            <h2>请选择文件</h2>
            <input type="file" id="file">
            <div class="padding" id="box">
                <!-- <img src="" alt="" class="img-rounded img-responsive"> -->
            </div>
            <div class="progress">
                <div class="progress-bar" style="width:0;" id="bar">0%</div>
            </div>
        </div>
    </div>
    <script>
        //黑马P29集

        // 获取文件选择控件
        var file = document.getElementById('file');
        // 获取进度条元素
        var bar = document.getElementById('bar');
        // 获取图片容器
        var box = document.getElementById('box');
        // 为文件选择控件添加onchanges事件
        // 在用户选择文件时触发
        file.onchange = function() {
            // 创建空的formData表单对象
            var formData = new FormData();
            // 将用户选择的文件追加到formData表单对象中
            formData.append('attrName', this.files[0]);
            //创建Ajax对象
            var xhr = new XMLHttpRequest();
            // 对Ajax对象进行配置
            xhr.open('POST', 'http://localhost:3000/upload3');
            // 在文件上传的过程中持续触发
            xhr.onprogress = function(ev) {
                // ev.loaded 文件已经上传了多少
                // ev.total 上传文件的总大小
                var result = (ev.loaded / ev.total) * 100 + '%';
                // 设置进度条的宽度
                bar.style.width = result;
                // 将百分比显示在进度条中
                bar.innerHTML = result;
                // console.log(ev);
            }

            // 发送ajax请求
            xhr.send(formData);
            // 监听服务器端响应给客户端的数据
            xhr.onload = function() {
                // 如果服务器端返回的http状态码为200
                // 说明请求是成功的
                if (xhr.status == 200) {
                    // 将服务器端返回的数据显示在控制台中
                    console.log(xhr.responseText);
                    // 响应数据返回的是JSON数据
                    var result = JSON.parse(xhr.responseText);
                    console.log(result);
                    // 动态创建img表单
                    var img = document.createElement('img');
                    // 给图片设置src属性
                    img.src = result.path;
                    img.onload = function() {
                        // 将图片显示在页面中
                        box.appendChild(img);
                    }

                }
            }
        }
    </script>

</body>

</html>

// 05-FormData即时图片预览
app.all('/upload3', async(req, res) => {
    res.setHeader('Access-Control-Allow-Origin', '*');

    // 创建formidable表单解析对象
    // 保留上传文件的后缀名字
    const form = new formidable.IncomingForm({ multiples: true, uploadDir: path.join(__dirname, 'formData', 'uploads'), keepExtensions: true });
    // 设置客户端传递过来的FormData对象
    // form.uploadDir = path.join(__dirname, 'formData', 'uploads');
    // 解析客户端传递过来的FormData对象
    form.parse(req, (err, fields, files) => {
        // 将客户端传递过来的文件地址响应到客户端
        // res.send(files.attrName.filepath.split('formData')[1]);
        res.send({
            path: files.attrName.filepath.split('formData')[1]
        });
    });
});

运行结果及报错内容

img

点击控制台中的图片路径后的界面出现

img

我的解答思路和尝试过的方法
我想要达到的结果

node需要代理uploads路径,前端使用是http://localhost:3000/upload/23e.....jpg 这样