浏览器直接从ftp服务器上下载文件

本文介绍如何使用HTML的<a>标签结合download属性实现从FTP服务器直接下载文件的功能,并提供了一种通过JavaScript动态获取下载链接的方法来避免FTP账号密码泄露的风险。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.利用HTML <a> 标签
ftp://帐号:密码@FTP网址
download:添加download属性后,无论a标签的href属性链接到一个网页、图片、文本等,download属性都会强制触发下载操作,
         且自动命名文件为download属性。但是这个属性对浏览器有一定要求.

<a href="ftp://user:pwd@url" download=" " > FTP下载 </a>
user : 账号
pwd : 密码

url : FTP网址 (可以是ftp的目录, 也可以是精确到具体文件)

这样点击这个<a> 标签就可以下载指定的文件了

但是这样会有一个问题, 就是把自己的ftp服务账号密码暴露在用户面前, 很不安全.



2.利用 window.location.href = url;

点击<a> 标签的时候先去后台要一次下载地址,然后再利用window.location.href = url下载

url : ftp://user:pwd@url"
<a href="javascript:void(0)" onclick="link()">客户端下载</a>

<script>
    var url;
    function link() {
        //你的功能
        $.ajax({
            type: "get",
            url: "<%=path%>/download.do",
            async: false,
            success: function (data) {
                url = data;
            }
        });
        window.location.href = url;
    }
</script>

java
        String server = (String) config.get("server");
        Integer port = Integer.parseInt((String) config.get("port"));
        String user = (String) config.get("user");
        String password = (String) config.get("password");
        String url_fileName = URLEncoder.encode(versionName, "GBK");
        String url="ftp://"+user+":"+password+"@"+server+"/"+downLoadPath+"/"+url_fileName+"";
        return url;

package com.kwantler.YN_EW.service.impl; import java.io.ByteArrayOutputStream; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL; public class FilePhoto { /** * 从网络Url下载文件 * * @param urlStr * @param fileName * @param savePath * @throws IOException */ public static void downLoadByUrl(String urlStr, String fileName, String savePath) throws IOException { URL url = new URL(urlStr); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); // 设置超时间为3秒 conn.setConnectTimeout(5 * 1000); // 防止屏蔽程序抓取而返回403错误 conn.setRequestProperty("User-Agent", "Mozilla/4.0 (compatible; MSIE 5.0; Windows NT; DigExt)"); // 得到输入流 InputStream inputStream = conn.getInputStream(); // 获取自己数组 byte[] getData = readInputStream(inputStream); // 文件保存位置 File saveDir = new File(savePath); if (!saveDir.exists()) { saveDir.mkdir(); } File file = new File(saveDir + File.separator + fileName); FileOutputStream fos = new FileOutputStream(file); fos.write(getData); if (fos != null) { fos.close(); } if (inputStream != null) { inputStream.close(); } System.out.println("info:" + url + " download success"); } /** * 从输入流中获取字节数组 * * @param inputStream * @return * @throws IOException */ public static byte[] readInputStream(InputStream inputStream) throws IOException { byte[] buffer = new byte[1024]; int len = 0; ByteArrayOutputStream bos = new ByteArrayOutputStream(); while ((len = inputStream.read(buffer)) != -1) { bos.write(buffer, 0, len); } bos.close(); return bos.toByteArray(); } public static void main(String[] args) { try { downLoadByUrl( "https://www.mybiosource.com/images/tds/protocol_samples/MBS700_Antibody_Set_Sandwich_ELISA_Protocol.pdf", "ELISA.pdf", "E:/upload/protocol"); } catch (Exception e) { // TODO: handle exception } } }
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是饭七分饱

生活在阴沟,也得仰望星空

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值