会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 134268个问题

image.png

JAVA 全系列/第二十四阶段:数字货币交易所项目/IASS基础服务的搭建和开发 26356楼
JAVA 全系列/第一阶段:AI驱动的JAVA编程/面向对象详解和JVM底层内存分析 26357楼

我的项目输出目录找不到图片,不知道配置是哪里出了问题

666.png


888.png



代码如下:

package com.bjsxt.servletDemo;

import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.OutputStream;

/**
 * 文件下载
 */
public class DownFileServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        this.doPost(req,resp);
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        //获取ServletContext对象
        ServletContext servletContext = this.getServletContext();

        //路径转换
        String realPath = servletContext.getRealPath("image/美女.jpg");
        System.out.println(realPath);
        //读文件
        File file = new File(realPath);
        FileInputStream fis = new FileInputStream(file);
        byte[] buff = new byte[fis.available()];
        fis.read(buff);

        //在响应中添加附加信息
        resp.addHeader("Content-Disposition","attachment; filename="+new String(file.getName().getBytes("gbk"),"iso-8859-1"));
        OutputStream os = resp.getOutputStream();
        os.write(buff);
        os.flush();
        os.close();



    }
}


JAVA 全系列/第六阶段:JavaWeb开发/Servlet技术详解(旧) 26358楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/IO 流技术(旧) 26359楼
JAVA 全系列/第一阶段:AI驱动的JAVA编程/面向对象详解和JVM底层内存分析 26360楼
Python全系列/第八阶段:轻量级Web开发利器-Flask框架/GraphQL 26361楼
JAVA 全系列/第十七阶段:海量数据存储与查询/MyCat(旧) 26363楼
JAVA 全系列/第四阶段:数据库与AI协同技术实战/JDBC技术 26364楼
Python全系列/第六阶段:数据库与AI协同技术实战/mysql的使用 26365楼

<!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>
    <script src="./jquery-3.6.0.min.js"></script>
</head>

<body>
    <div></div>
    <script>
        function loadImageAsync(url) {
            var promise = new Promise(function(resolve, reject) {
                var image = new Image();
                image.src = url;
                // onload方法,代表图片加载完成
                image.onload = function() {
                    resolve(image);
                };
                // 图片加载失败
                image.onerror = function() {
                    reject(new Error("Could not load image at " + url));
                }
            })
            return promise;
        }
        loadImageAsync("http://iwenwiki.com/api/vue-data/vu-data-1.png").then(
            function(data) {
                $("div").append(data);
            },
            function(error) {
                $("div").html("error");
            })
    </script>
</body>

</html>

image.png

WEB前端全系列/第七阶段:ECMAScript6新特性模块/ES6 第一部分 26366楼
JAVA 全系列/第五阶段:Web全栈开发基础与Vue/HTML5 26368楼
JAVA 全系列/第五阶段:Web全栈开发基础与Vue/JavaScript语言 26369楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637