Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/383.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/198.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/performance/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 如何正确使用设置的FixedLengthStreamingMode(int)_Java_Android - Fatal编程技术网

Java 如何正确使用设置的FixedLengthStreamingMode(int)

Java 如何正确使用设置的FixedLengthStreamingMode(int),java,android,Java,Android,我在使用此函数时遇到问题。我得到长度();我需要上传的文件的第二个错误-> 总是比预期的字节多 Exception : expected 589715 bytes but received 589840 java.io.IOException: expected 589715 bytes but received 589840 at libcore.net.http.FixedLengthOutputStream.write(FixedLengthOutputStream.java:39) at

我在使用此函数时遇到问题。我得到长度();我需要上传的文件的第二个错误->

总是比预期的字节多

Exception : expected 589715 bytes but received 589840
java.io.IOException: expected 589715 bytes but received 589840
at libcore.net.http.FixedLengthOutputStream.write(FixedLengthOutputStream.java:39)
at java.io.DataOutputStream.write(DataOutputStream.java:98)
at com.androidexample.uploadtoserver.UploadToServer.uploadFile(UploadToServer.java:152)
at com.androidexample.uploadtoserver.UploadToServer$1.run(UploadToServer.java:62)
at java.lang.Thread.run(Thread.java:856)
我用这个来获取文件的大小

int fixedLength = (int) fileInputStream.getChannel().size();
int total = (int) sourceFile.length();
是否可以正确发布工作集FixedLengthStreamingMode(int)的示例?我只能看到这种方法的问题

这里有完整的代码,是的,它是用来传输一个文件或一些文件的,每个文件的大小可以是15 Mb,也可以是15 Mb以上,有时我会在一些旧设备中内存不足

public int uploadFile(String sourceFileUri) {

    String fileName = sourceFileUri;

    HttpURLConnection conn = null;
    DataOutputStream dos = null;  
    String lineEnd = "\r\n";
    String twoHyphens = "--";
    String boundary = "*****";
    int bytesRead, bytesAvailable, bufferSize;
    byte[] buffer;
    int maxBufferSize = 1 * 1024 * 1024; 
    File sourceFile = new File(sourceFileUri); 

    if (!sourceFile.isFile()) {
        runOnUiThread(new Runnable() {
            public void run() {
                /*   messageText.setText("Source File not exist :"
                        +uploadFilePath + "" + uploadFileName);*/
            }
        }); 

        return 0;
    } else {
        try { 
            FileInputStream fileInputStream = new FileInputStream(sourceFile);
            int fixedLength = (int) fileInputStream.getChannel().size();
            URL url = new URL(upLoadServerUri);
            //int total = (int) sourceFile.length();
            // Open a HTTP  connection to  the URL
            conn = (HttpURLConnection) url.openConnection();
            conn.setFixedLengthStreamingMode(fixedLength);
            conn.setDoInput(true); // Allow Inputs
            conn.setDoOutput(true); // Allow Outputs
            conn.setUseCaches(false); // Don't use a Cached Copy
            conn.setRequestMethod("POST");
            conn.setRequestProperty("Connection", "Keep-Alive");
            conn.setRequestProperty("ENCTYPE", "multipart/form-data");
            conn.setRequestProperty("Content-Type", "multipart/form-data;boundary=" + boundary);
            conn.setRequestProperty("uploaded_file", fileName); 
            conn.setRequestProperty("mail", MAIL); 
            conn.setRequestProperty("OS", "1");
            conn.setRequestProperty("LANG", "ES");
            //conn.setChunkedStreamingMode(maxBufferSize);

            dos = new DataOutputStream(conn.getOutputStream());

            dos.writeBytes(twoHyphens + boundary + lineEnd); 
            dos.writeBytes("Content-Disposition: form-data; name=\"uploaded_file\";filename=\""
                    + fileName + "\"" + lineEnd);

            dos.writeBytes(lineEnd);

            // create a buffer of  maximum size
            bytesAvailable = fileInputStream.available(); 

           bufferSize = Math.min(bytesAvailable, maxBufferSize);
           buffer = new byte[bufferSize];

           // read file and write it into form...
           bytesRead = fileInputStream.read(buffer, 0, bufferSize);  

            while (bytesRead > 0) {
                dos.write(buffer, 0, bufferSize);
                bytesAvailable = fileInputStream.available();
                bufferSize = Math.min(bytesAvailable, maxBufferSize);
                bytesRead = fileInputStream.read(buffer, 0, bufferSize);   

            }

            // send multipart form data necesssary after file data...
            dos.writeBytes(lineEnd);
            dos.writeBytes(twoHyphens + boundary + twoHyphens + lineEnd);

            // Responses from the server (code and message)
            serverResponseCode = conn.getResponseCode();
            // String serverResponseMessage = conn.getResponseMessage();

            // Log.i("uploadFile", "HTTP Response is : " 
            //       + serverResponseMessage + ": " + serverResponseCode);

            if(serverResponseCode == 200) {
                runOnUiThread(new Runnable() {
                    public void run() {
                        /*messageText.setText(msg);
                        Toast.makeText(UploadToServer.this, "File Upload Complete.", 
                                     Toast.LENGTH_SHORT).show();*/
                    }
                });
            }    

            //close the streams //
            fileInputStream.close();
            dos.flush();
            dos.close();
        }
    }
}

您必须将其设置为要传输的总字节数。很明显,你发送的不止这些。您尚未显示相关代码,因此无法进一步评论

为什么是DataOutputStream?你不需要仅仅为了发送一个文件

编辑:您的代码存在许多问题

dos.writeBytes(twoHyphens + boundary + lineEnd); 
dos.writeBytes("Content-Disposition: form-data; name=\"uploaded_file\";filename=\""
                                     + fileName + "\"" + lineEnd);
dos.writeBytes(lineEnd);
这就是固定长度传输模式的问题所在。你还没有把这些东西算作固定长度的一部分

// create a buffer of  maximum size
您不需要最大大小的缓冲区。8192字节的缓冲区就足够了

bytesAvailable = fileInputStream.available(); 
InputStream.available()
在Javadoc中具体描述如下:使用此方法的返回值来分配用于保存此流中所有数据的缓冲区是不正确的。幸运的是,您可以删除这一行

bufferSize = Math.min(bytesAvailable, maxBufferSize);
buffer = new byte[bufferSize];
不必要,见上文。只需使用
新字节[8192]

// read file and write it into form...
bytesRead = fileInputStream.read(buffer, 0, bufferSize);  
while (bytesRead > 0) {
    dos.write(buffer, 0, bufferSize);
    bytesAvailable = fileInputStream.available();
    bufferSize = Math.min(bytesAvailable, maxBufferSize);
    bytesRead = fileInputStream.read(buffer, 0, bufferSize);   
}
这也是完全错误的。首先,这是对
available()
的滥用。Java中复制流的标准方法如下:

while ((count = in.read(buffer)) > 0)
{
    out.write(buffer, 0, count);
}
它适用于任何大于零的缓冲区大小;它不在乎输入的时间有多长;无论大小,它都能正确地用于最终读取

// send multipart form data necesssary after file data...
dos.writeBytes(lineEnd);
dos.writeBytes(twoHyphens + boundary + twoHyphens + lineEnd);
同样,您还没有将其计算为固定长度传输大小的一部分


但是我必须说,您最好使用分块传输模式,让
HttpURLConnection
完成所有繁重的工作:然后您只需要上面的复制循环。

您必须将其设置为要传输的总字节数。很明显,你发送的不止这些。您尚未显示相关代码,因此无法进一步评论

为什么是DataOutputStream?你不需要仅仅为了发送一个文件

编辑:您的代码存在许多问题

dos.writeBytes(twoHyphens + boundary + lineEnd); 
dos.writeBytes("Content-Disposition: form-data; name=\"uploaded_file\";filename=\""
                                     + fileName + "\"" + lineEnd);
dos.writeBytes(lineEnd);
这就是固定长度传输模式的问题所在。你还没有把这些东西算作固定长度的一部分

// create a buffer of  maximum size
您不需要最大大小的缓冲区。8192字节的缓冲区就足够了

bytesAvailable = fileInputStream.available(); 
InputStream.available()
在Javadoc中具体描述如下:使用此方法的返回值来分配用于保存此流中所有数据的缓冲区是不正确的。幸运的是,您可以删除这一行

bufferSize = Math.min(bytesAvailable, maxBufferSize);
buffer = new byte[bufferSize];
不必要,见上文。只需使用
新字节[8192]

// read file and write it into form...
bytesRead = fileInputStream.read(buffer, 0, bufferSize);  
while (bytesRead > 0) {
    dos.write(buffer, 0, bufferSize);
    bytesAvailable = fileInputStream.available();
    bufferSize = Math.min(bytesAvailable, maxBufferSize);
    bytesRead = fileInputStream.read(buffer, 0, bufferSize);   
}
这也是完全错误的。首先,这是对
available()
的滥用。Java中复制流的标准方法如下:

while ((count = in.read(buffer)) > 0)
{
    out.write(buffer, 0, count);
}
它适用于任何大于零的缓冲区大小;它不在乎输入的时间有多长;无论大小,它都能正确地用于最终读取

// send multipart form data necesssary after file data...
dos.writeBytes(lineEnd);
dos.writeBytes(twoHyphens + boundary + twoHyphens + lineEnd);
同样,您还没有将其计算为固定长度传输大小的一部分


但是我必须说,您最好使用分块传输模式,让
HttpURLConnection
完成所有繁重的工作:然后您只需要上面的复制循环。

您必须将其设置为要传输的总字节数。很明显,你发送的不止这些。您尚未显示相关代码,因此无法进一步评论

为什么是DataOutputStream?你不需要仅仅为了发送一个文件

编辑:您的代码存在许多问题

dos.writeBytes(twoHyphens + boundary + lineEnd); 
dos.writeBytes("Content-Disposition: form-data; name=\"uploaded_file\";filename=\""
                                     + fileName + "\"" + lineEnd);
dos.writeBytes(lineEnd);
这就是固定长度传输模式的问题所在。你还没有把这些东西算作固定长度的一部分

// create a buffer of  maximum size
您不需要最大大小的缓冲区。8192字节的缓冲区就足够了

bytesAvailable = fileInputStream.available(); 
InputStream.available()
在Javadoc中具体描述如下:使用此方法的返回值来分配用于保存此流中所有数据的缓冲区是不正确的。幸运的是,您可以删除这一行

bufferSize = Math.min(bytesAvailable, maxBufferSize);
buffer = new byte[bufferSize];
不必要,见上文。只需使用
新字节[8192]

// read file and write it into form...
bytesRead = fileInputStream.read(buffer, 0, bufferSize);  
while (bytesRead > 0) {
    dos.write(buffer, 0, bufferSize);
    bytesAvailable = fileInputStream.available();
    bufferSize = Math.min(bytesAvailable, maxBufferSize);
    bytesRead = fileInputStream.read(buffer, 0, bufferSize);   
}
这也是完全错误的。首先,这是对
available()
的滥用。Java中复制流的标准方法如下:

while ((count = in.read(buffer)) > 0)
{
    out.write(buffer, 0, count);
}
它适用于任何大于零的缓冲区大小;它不在乎输入的时间有多长;无论大小,它都能正确地用于最终读取

// send multipart form data necesssary after file data...
dos.writeBytes(lineEnd);
dos.writeBytes(twoHyphens + boundary + twoHyphens + lineEnd);
同样,您还没有将其计算为固定长度传输大小的一部分


但是我必须说,您最好使用分块传输模式,让
HttpURLConnection
完成所有繁重的工作:然后您只需要上面的复制循环。

您必须将其设置为要传输的总字节数。很明显,你发送的不止这些。您尚未显示相关代码,因此无法进一步评论

为什么是DataOutputStream?你不需要仅仅为了发送一个文件

编辑:您的代码存在许多问题

dos.writeBytes(twoHyphens + boundary + lineEnd); 
dos.writeBytes("Content-Disposition: form-data; name=\"uploaded_file\";filename=\""
                                     + fileName + "\"" + lineEnd);
dos.writeBytes(lineEnd);
这就是固定长度传输模式的问题所在。你还没有把这些东西算作固定长度的一部分

// create a buffer of  maximum size
您不需要最大大小的缓冲区。8192字节的缓冲区就足够了

bytesAvailable = fileInputStream.available(); 
InputStream.available()
在Javadoc中具体描述如下:使用此方法的返回值来分配用于保存此流中所有数据的缓冲区是不正确的。幸运的是,您可以删除这一行

bufferSize = Math.min(bytesAvailable, maxBufferSize);
buffer = new byte[bufferSize];
不必要,见上文。只需使用
新字节[8192]

// read file and write it into form...
bytesRead = fileInputStream.read(buffer, 0, bufferSize);  
while (bytesRead > 0) {
    dos.write(buffer, 0, bufferSize);
    bytesAvailable = fileInputStream.available();
    bufferSize = Math.min(bytesAvailable, maxBufferSize);
    bytesRead = fileInputStream.read(buffer, 0, bufferSize);   
}
这也是完全错误的。这是对
available()