RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 709530
Accepted
Nikolay
Nikolay
Asked:2020-08-23 19:04:21 +0000 UTC2020-08-23 19:04:21 +0000 UTC 2020-08-23 19:04:21 +0000 UTC

快递返回 krakozyabry 而不是图片

  • 772

这是节点代码:

    router.post('/crop', upload.fields([{name: 'img'}]), function (req, res, next) {

    console.log('files', req.files.img);

    var path = __dirname + '/' + req.files.img[0].path;
    console.log(path)
    res.sendFile(path);

来自服务器的响应最终是这样的:

�PNG IHDR��d�4 cHRMz%������u0�:�o�_�FbKGD������� pHYs.#.#x�?v�IDATx���i�%Iv~�xD�{ߒ��UY��u�]���t��A$�M��ȱ5��q836#�FFӈ2�b�pH�� �� ���w׾We��޻K������#�}�Y[gU�m��xxx���s�s�������������?zg��.........

如何通过api正确显示来自服务器的图像?

标题: 在此处输入图像描述

服务器响应: 在此处输入图像描述

以及如何显示接收到的数据?格式是什么?我以为链接是,需要插入,但是出现了一堆难以理解的字符

这是对服务器的请求:

$('#form1').submit(function(e){
    var formData = new FormData($(this)[0]);
    $.ajax({
        type:'POST',
        url:'http://localhost:8080/crop',
        data : formData,
        contentType: false, // <-----------------
        processData: false
    }).done(function(data){
        //print response on success
        $("#status").html(data);

    }).fail(function(data) {
        $("#status").html('Error');
    });
    e.preventDefault();
});
javascript
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Darth
    2020-08-23T19:08:03Z2020-08-23T19:08:03Z

    添加一个标题Content-Type: image/png,以便浏览器理解这是一个图像。

    res.set('Content-Type', 'image/png');
    

    UP: 这条线做了你所看到的——

        $("#status").html(data);
    

    尝试将文件内容附加为 html(即文本)。解决问题的方法 -

    1)返回的不是文件,而是它的url,并以常规方式获取文件本身,将此url放在图像标签的src中(有很多选项可以做到这一点)

    2)如果您不想将此文件存储在您的服务器上,那么您可以例如将其驱动到 base64 -

    router.get('/img', (req, res) => {
        res.end(
        `<script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
        <form id='form1'>
            <input type='file' />
            <button>Send</button>
        </form>
        <div id='status'></div>
        <script>
            $('#form1').submit(function(e){
                var formData = new FormData($(this)[0]);
                $.ajax({
                type:'POST',
                url:'http://localhost:8080/img',
                data : formData,
                contentType: false, // <-----------------
                processData: false
                }).done(function(data){
                    img = new Image();
                    img.src = data;
                $("#status").html(img);
                }).fail(function(data) {
                $("#status").html('Error');
                });
                e.preventDefault();
            });
        </script>
        `);
    });
    
    router.post('/img', (req, res) => {
        const path = __dirname + '/img.png';
        const base64Image = new Buffer(fs.readFileSync(path), 'binary').toString('base64');        
        res.end(`data:image/png;base64,${base64Image}`);
    });
    

    3)只是一个工作版本(只有你需要学习如何在jQuery中做到这一点xhr.responseType = 'blob';)-

    $('#form1').submit(function(e){
        e.preventDefault();
        var xhr = new XMLHttpRequest();
        xhr.onreadystatechange = function(){
            if (this.readyState == 4 && this.status == 200){
                var img = document.createElement('img');
                var url = window.URL || window.webkitURL;
                img.src = url.createObjectURL(this.response);
                $('#status').html(img);
            }
        }
        xhr.open('POST', '/img');
        xhr.responseType = 'blob';
        xhr.send(); 
    });
    
    • 2

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    Python 3.6 - 安装 MySQL (Windows)

    • 1 个回答
  • Marko Smith

    C++ 编写程序“计算单个岛屿”。填充一个二维数组 12x12 0 和 1

    • 2 个回答
  • Marko Smith

    返回指针的函数

    • 1 个回答
  • Marko Smith

    我使用 django 管理面板添加图像,但它没有显示

    • 1 个回答
  • Marko Smith

    这些条目是什么意思,它们的完整等效项是什么样的

    • 2 个回答
  • Marko Smith

    浏览器仍然缓存文件数据

    • 1 个回答
  • Marko Smith

    在 Excel VBA 中激活工作表的问题

    • 3 个回答
  • Marko Smith

    为什么内置类型中包含复数而小数不包含?

    • 2 个回答
  • Marko Smith

    获得唯一途径

    • 3 个回答
  • Marko Smith

    告诉我一个像幻灯片一样创建滚动的库

    • 1 个回答
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Алексей Шиманский 如何以及通过什么方式来查找 Javascript 代码中的错误? 2020-08-03 00:21:37 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    user207618 Codegolf——组合选择算法的实现 2020-10-23 18:46:29 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5