用户按下“取消”或“下载”的I跟踪?!您可以强制下载:与只允许下载一次相比,允许在有限的时间段内下载任意次数可能更容易。取决于您的用例,这可能就足够了。这是我问题的一部分,我如何在Web应用程序中使用JAVA跟踪从数据库(Sqlite)下载的文件,以了解用

用户按下“取消”或“下载”的I跟踪?!您可以强制下载:与只允许下载一次相比,允许在有限的时间段内下载任意次数可能更容易。取决于您的用例,这可能就足够了。这是我问题的一部分,我如何在Web应用程序中使用JAVA跟踪从数据库(Sqlite)下载的文件,以了解用,java,servlets,Java,Servlets,用户按下“取消”或“下载”的I跟踪?!您可以强制下载:与只允许下载一次相比,允许在有限的时间段内下载任意次数可能更容易。取决于您的用例,这可能就足够了。这是我问题的一部分,我如何在Web应用程序中使用JAVA跟踪从数据库(Sqlite)下载的文件,以了解用户是否真的完全下载了该文件?! @WebServlet("/download") public class download extends HttpServlet { private static final long ser


用户按下“取消”或“下载”的I跟踪?!您可以强制下载:与只允许下载一次相比,允许在有限的时间段内下载任意次数可能更容易。取决于您的用例,这可能就足够了。这是我问题的一部分,我如何在Web应用程序中使用JAVA跟踪从数据库(Sqlite)下载的文件,以了解用户是否真的完全下载了该文件?!
@WebServlet("/download")
    public class download extends HttpServlet {
    private static final long serialVersionUID = 1L;
    private static final int DEFAULT_BUFFER_SIZE = 10240;
/**
 * @see HttpServlet#HttpServlet()
 */
public download() {
    super();
    // TODO Auto-generated constructor stub
}

/**
 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse
 *      response)
 */
protected void doGet(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {
    try {

        Class.forName("org.sqlite.JDBC");
        Connection c = DriverManager.getConnection("jdbc:sqlite:C:\\sqlite\\mascapp.db");
        c.setAutoCommit(false);
        Cookie[] cookies = request.getCookies();
        if(request.getSession().getAttribute("aeid") == null || request.getSession().getAttribute("uid") == null)
        {
            response.sendRedirect("/index.jsp");
        }
        int ae_num = Integer.parseInt(request.getSession().getAttribute("aeid").toString());




        String sql = "SELECT file, filename FROM reports INNER JOIN download USING(tipid) WHERE reports.tipid = ?"+
                "AND download.ts_" + ae_num+ " = 0;";

        PreparedStatement stmt = c.prepareStatement(sql);
        String tipNum = request.getParameter("tipid");
        if (tipNum != null) {

            stmt.setString(1, tipNum);
            //stmt.setString(2, tipNum);
            ResultSet res = stmt.executeQuery();
            BufferedInputStream fileBlob = null;
            String filename = "";

            while (res.next()) {
                fileBlob = new BufferedInputStream(res.getBinaryStream("file"), DEFAULT_BUFFER_SIZE);

                filename = res.getString("filename");
            }
            if (fileBlob != null) {
                System.out.println(filename);
                response.setContentType("APPLICATION/OCTET-STREAM");
                response.setHeader("Content-Disposition", "attachment; filename=\"" + filename + "\"");

                BufferedOutputStream output = new BufferedOutputStream(response.getOutputStream(),
                        DEFAULT_BUFFER_SIZE);

                byte[] buffer = new byte[DEFAULT_BUFFER_SIZE];
                int length;
                while ((length = fileBlob.read(buffer)) > 0) {
                    output.write(buffer, 0, length);
                }

                output.close();
                fileBlob.close();
                Date now = new Date();

                sql = "UPDATE download SET ts_" + ae_num + " = " + now.getTime() + " WHERE tipid = ?;";
                System.out.println(sql);
                stmt = c.prepareStatement(sql);
                stmt.setString(1, tipNum);

                stmt.executeUpdate();
                stmt.close();

                c.commit();
                c.close();
            }
            else
            {

                c.close();
                response.sendRedirect("/MASC/formdownloaded.jsp");

            }
        }
        else
        {
            response.getWriter().append("<html><body><h1>Error: no param</h1></body></html>");
            c.close();

        }
    } catch (SQLException | ClassNotFoundException e) {
        e.printStackTrace();

    }
}

/**
 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse
 *      response)
 */
protected void doPost(HttpServletRequest request, HttpServletResponse response)
        throws ServletException, IOException {
    // TODO Auto-generated method stub
    doGet(request, response);
}

}
Cookie fileDwnld = new Cookie("fileDownload", "true");
fileDwnld.setPath("/");
response.addCookie(fileDwnld);
<script src="http://code.jquery.com/jquery-2.1.4.min.js"></script>
<script src="jquery.fileDownload.js"></script>
<script>
$(document).ready(function() {
    $("#btnSubmit").click(function(){
        $.fileDownload('path/to/servlet')
            .done(function () { alert('File download a success!'); })
            .fail(function () { alert('File download failed!'); });
    }); 
});