dongyan6910 2012-08-21 02:57
浏览 52
已采纳

如何强制下载图像?

I hava a dynamically generated image on my page like so:

<img id="my_image" src="data:image/jpeg;base64,/9j/4AAQSkZJRgABAgEA/gD+AAD/etc............" />

Instead of telling my users to right click on the image and hit save I want to expose a download link which when clicked will prompt the image to be downloaded. How to achieve this?

Initially my attempt with thus in js:

var path = $('#my_image').attr('src');
window.open('./download.php?file=' + path);

and in download.php:

<?php
    header('Content-Description: File Transfer');
    header("Content-type: application/octet-stream");
    header("Content-disposition: attachment; filename= " . $_GET['file'] . "");
?>

<img src="<?= $_GET['file'] ?>" />

But problem is, Base64 url stirngs are so large it exceeds the GET request byte limit.

I am open to a solution in either JavaScript or PHP.

  • 写回答

2条回答 默认 最新

  • dongyi8416 2012-08-22 01:46
    关注

    Turns out one of the other questions did have the answer:

    Browser/HTML Force download of image from src="data:image/jpeg;base64..."

    I am doing it strictly on the client sde like so:

    $('a#download_image').on('click', function() {
        var url = $('#my_image').attr('src').replace(/^data:image\/[^;]/, 'data:application/octet-stream');
        location.href = url;
    });
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器
  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)
  • ¥15 Vue3地图和异步函数使用
  • ¥15 C++ yoloV5改写遇到的问题
  • ¥20 win11修改中文用户名路径
  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
  • ¥15 帮我写一个c++工程