我在网络应用中生成普通链接,例如:<a href="/path/to/image"><img src="/path/to/image" /></a>
。
当我点击链接时,它会在新页面中显示图片。如果要保存图片,则需要右键单击它并选择“另存为”
我不想要这种行为,我想在点击链接时弹出一个下载框,这是否可能只是用html或javascript?怎么样?
如果不是,我想我必须编写一个download.php脚本,并将其作为参数调用href,文件名为...?
答案 0 :(得分:217)
<a download="custom-filename.jpg" href="/path/to/image" title="ImageName">
<img alt="ImageName" src="/path/to/image">
</a>
尚未完全支持 http://caniuse.com/#feat=download ,但您可以使用modernizr https://modernizr.com/download/?adownload-setclasses (在非核心检测下)检查浏览器的支持。
答案 1 :(得分:54)
为图片或html创建下载链接的最简单方法是设置download attribute,但此解决方案仅适用于现代浏览器。
<a href="/path/to/image" download="myimage"><img src="/path/to/image" /></a>
“myimage”是要下载的文件的名称。扩展名将自动添加 Example here
答案 2 :(得分:45)
<a href="download.php?file=path/<?=$row['file_name']?>">Download</a>
的download.php:
<?php
$file = $_GET['file'];
download_file($file);
function download_file( $fullPath ){
// Must be fresh start
if( headers_sent() )
die('Headers Sent');
// Required for some browsers
if(ini_get('zlib.output_compression'))
ini_set('zlib.output_compression', 'Off');
// File Exists?
if( file_exists($fullPath) ){
// Parse Info / Get Extension
$fsize = filesize($fullPath);
$path_parts = pathinfo($fullPath);
$ext = strtolower($path_parts["extension"]);
// Determine Content Type
switch ($ext) {
case "pdf": $ctype="application/pdf"; break;
case "exe": $ctype="application/octet-stream"; break;
case "zip": $ctype="application/zip"; break;
case "doc": $ctype="application/msword"; break;
case "xls": $ctype="application/vnd.ms-excel"; break;
case "ppt": $ctype="application/vnd.ms-powerpoint"; break;
case "gif": $ctype="image/gif"; break;
case "png": $ctype="image/png"; break;
case "jpeg":
case "jpg": $ctype="image/jpg"; break;
default: $ctype="application/force-download";
}
header("Pragma: public"); // required
header("Expires: 0");
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Cache-Control: private",false); // required for certain browsers
header("Content-Type: $ctype");
header("Content-Disposition: attachment; filename=\"".basename($fullPath)."\";" );
header("Content-Transfer-Encoding: binary");
header("Content-Length: ".$fsize);
ob_clean();
flush();
readfile( $fullPath );
} else
die('File Not Found');
}
?>
答案 3 :(得分:9)
不,不是。您将需要服务器上的某些内容来发送Content-Disposition标头以将文件设置为附件而不是内联。您可以使用普通的Apache配置执行此操作。
我找到an example of doing it using mod_rewrite,虽然我知道有一种更简单的方法。
答案 4 :(得分:7)
如果您使用HTML5,则可以将属性“下载”添加到链接中。
<a href="/test.pdf" download>
答案 5 :(得分:6)
试试这个......
<a href="/path/to/image" download>
<img src="/path/to/image" />
</a>
答案 6 :(得分:3)
你不能用纯html / javascript做到这一点。这是因为您与Web服务器有单独的连接以检索单独的文件(图像),而普通的Web服务器将为设置了内容标题的文件提供服务,以便浏览内容类型的浏览器将决定可以在内部处理该类型。
强制浏览器不在内部处理文件的方法是更改标题(内容处置优先或内容类型),以便浏览器不会尝试在内部处理文件。您可以通过在动态设置标题的Web服务器上编写脚本(即download.php)或通过配置Web服务器为您要下载的文件返回不同的标题来完成此操作。您可以在网络服务器上按目录进行此操作,这样您就可以在不编写任何php或javascript的情况下离开 - 只需将所有下载图像放在该位置即可。
答案 7 :(得分:3)
<html>
<head>
<title> Download-Button </title>
</head>
<body>
<p> Click the image ! You can download! </p>
<?php
$image = basename("http://localhost/sc/img/logo.png"); // you can here put the image path dynamically
//echo $image;
?>
<a download="<?php echo $image; ?>" href="http://localhost/sc/img/logo.png" title="Logo title">
<img alt="logo" src="http://localhost/sc/img/logo.png">
</a>
</body>
答案 8 :(得分:1)
我做了这个简单的代码!:)
<html>
<head>
<title> Download-Button </title>
</head>
<body>
<p> Click the image ! You can download! </p>
<a download="logo.png" href="http://localhost/folder/img/logo.png" title="Logo title">
<img alt="logo" src="http://localhost/folder/img/logo.png">
</a>
</body>
</html>
答案 9 :(得分:1)
HTML下载属性,用于指定当用户单击超链接时将下载目标。
仅在设置href属性时使用此属性。
该属性的值将是下载文件的名称。允许的值没有限制,浏览器将自动检测正确的文件扩展名并将其添加到文件(.img,.pdf,.txt,.html等)中。
示例代码:
<a href="https://www.w3schools.com/images/myw3schoolsimage.jpg"> Download Image >></a>
HTML5:
<a href="https://www.w3schools.com/images/myw3schoolsimage.jpg" download> Download Image >></a>
输出:
HTML5下载或Chrome浏览器