服务器给出 500 代码错误但仍提供内容

Server gives 500 code error but still serves content

我正在 "serveraddress/img/:imageid" 使用此功能:

 public static String getImage(Request req, Response res) {
        String imageId = req.params("imageid");
        byte[] bytes = readImage("img/" + imageId);

        return Base64.getMimeEncoder().encodeToString(bytes); 
    }

 public static byte[] readImage(String image) {
        byte[] bytes;
        try {
            File fff = new File(image);
            FileInputStream fileInputStream = new FileInputStream(fff);
            long byteLength = fff.length();

            bytes = new byte[(int) byteLength];
            fileInputStream.read(bytes, 0, (int) byteLength);
        } catch (Exception ex) {
            ex.printStackTrace();
            bytes = null;
        }
        return bytes;
    }

对于前几个请求,它正常交付。但是当更多的时候,比如 5 或 6 个请求请求图像,它开始发送服务器错误代码 500 而没有任何堆栈跟踪。我不确定是什么问题,但我希望有人能帮我弄清楚。

这是我的 gradle.build 文件,供任何想要测试的人使用:

testCompile group: 'junit', name: 'junit', version: '4.12'
compile group: 'org.slf4j', name: 'slf4j-log4j12', version: '1.7.21'
compile "com.sparkjava:spark-core:2.7.1"

这也是主要功能:

public static void main(String[] args) {
        BasicConfigurator.configure();
        org.apache.log4j.Logger.getRootLogger().setLevel(Level.ERROR);
        port(8883);
        get("/img/:imageid", this::getImage);
}

看起来您的代码从未关闭它使用的 FileInputStream,因此您正在泄漏文件描述符和内存。您应该使用 try-with-resources 或在 finally 块中关闭它们(附带说明一下,也许您可​​以使用 linter 来警告您未关闭的资源)。