예제 #1
0
 public virtual void TestSendPartialData()
 {
     FSDataInputStream     @in = new FSDataInputStream(new MockFSInputStream());
     ByteArrayOutputStream os  = new ByteArrayOutputStream();
     {
         // test if multiple ranges, then 416
         IList <InclusiveByteRange> ranges   = StrToRanges("0-,10-300", 500);
         HttpServletResponse        response = Org.Mockito.Mockito.Mock <HttpServletResponse>();
         StreamFile.SendPartialData(@in, os, response, 500, ranges);
         // Multiple ranges should result in a 416 error
         Org.Mockito.Mockito.Verify(response).SetStatus(416);
     }
     {
         // test if no ranges, then 416
         os.Reset();
         HttpServletResponse response = Org.Mockito.Mockito.Mock <HttpServletResponse>();
         StreamFile.SendPartialData(@in, os, response, 500, null);
         // No ranges should result in a 416 error
         Org.Mockito.Mockito.Verify(response).SetStatus(416);
     }
     {
         // test if invalid single range (out of bounds), then 416
         IList <InclusiveByteRange> ranges   = StrToRanges("600-800", 500);
         HttpServletResponse        response = Org.Mockito.Mockito.Mock <HttpServletResponse>();
         StreamFile.SendPartialData(@in, os, response, 500, ranges);
         // Single (but invalid) range should result in a 416
         Org.Mockito.Mockito.Verify(response).SetStatus(416);
     }
     {
         // test if one (valid) range, then 206
         IList <InclusiveByteRange> ranges   = StrToRanges("100-300", 500);
         HttpServletResponse        response = Org.Mockito.Mockito.Mock <HttpServletResponse>();
         StreamFile.SendPartialData(@in, os, response, 500, ranges);
         // Single (valid) range should result in a 206
         Org.Mockito.Mockito.Verify(response).SetStatus(206);
         Assert.AssertArrayEquals("Byte range from 100-300", GetOutputArray(100, 201), os.
                                  ToByteArray());
     }
 }
예제 #2
0
        /// <exception cref="Javax.Servlet.ServletException"/>
        /// <exception cref="System.IO.IOException"/>
        protected override void DoGet(HttpServletRequest request, HttpServletResponse response
                                      )
        {
            string path        = ServletUtil.GetDecodedPath(request, "/streamFile");
            string rawPath     = ServletUtil.GetRawPath(request, "/streamFile");
            string filename    = JspHelper.ValidatePath(path);
            string rawFilename = JspHelper.ValidatePath(rawPath);

            if (filename == null)
            {
                response.SetContentType("text/plain");
                PrintWriter @out = response.GetWriter();
                @out.Write("Invalid input");
                return;
            }
            Enumeration <string> reqRanges = request.GetHeaders("Range");

            if (reqRanges != null && !reqRanges.MoveNext())
            {
                reqRanges = null;
            }
            DFSClient dfs;

            try
            {
                dfs = GetDFSClient(request);
            }
            catch (Exception e)
            {
                response.SendError(400, e.Message);
                return;
            }
            HdfsDataInputStream @in   = null;
            OutputStream        out_1 = null;

            try
            {
                @in   = dfs.CreateWrappedInputStream(dfs.Open(filename));
                out_1 = response.GetOutputStream();
                long fileLen = @in.GetVisibleLength();
                if (reqRanges != null)
                {
                    IList <InclusiveByteRange> ranges = InclusiveByteRange.SatisfiableRanges(reqRanges
                                                                                             , fileLen);
                    StreamFile.SendPartialData(@in, out_1, response, fileLen, ranges);
                }
                else
                {
                    // No ranges, so send entire file
                    response.SetHeader("Content-Disposition", "attachment; filename=\"" + rawFilename
                                       + "\"");
                    response.SetContentType("application/octet-stream");
                    response.SetHeader(ContentLength, string.Empty + fileLen);
                    StreamFile.CopyFromOffset(@in, out_1, 0L, fileLen);
                }
                @in.Close();
                @in = null;
                out_1.Close();
                out_1 = null;
                dfs.Close();
                dfs = null;
            }
            catch (IOException ioe)
            {
                if (Log.IsDebugEnabled())
                {
                    Log.Debug("response.isCommitted()=" + response.IsCommitted(), ioe);
                }
                throw;
            }
            finally
            {
                IOUtils.Cleanup(Log, @in);
                IOUtils.Cleanup(Log, out_1);
                IOUtils.Cleanup(Log, dfs);
            }
        }