保存的ZIP文件被损坏(从Android应用程序到IIS服务器)

本文关键字:应用程序 Android IIS 服务器 ZIP 文件 损坏 保存 | 更新日期: 2023-09-27 17:56:52


尝试将XML文件从我的客户端应用程序(在Android上)发送到服务器端(IIS 7)之后。我没有获得XML文件的文件名,而只是内容。
现在我意识到简单地传输裸XML文件会太重(在我将几乎所有应用程序的数据同步到服务器之后)。

- 现在我正在追求将压缩文件从我的客户端应用程序发送到服务器端。
- XML文件被完美地压缩,将其大小缩小到不到其原始大小的一半。文件是使用HTTP POST方法直接使用FileEntity而不是使用MultiPart发送的(这可能是一个问题)。

更新2:添加了我自己的答案(:D效果更好)。

更新:添加了客户端代码。

问题:
- zip 文件保存在服务器端,但当我打开它时,winrar/7zip 给了我一个错误,说unexpected end of archive.

我提到了一个几乎类似的问题,但我在.NET开发方面也处于较低水平C# :(所以无法真正使用确切的代码(丢失、未初始化的变量等)。另外,该线程就像 4 岁一样,我对任何人都会在那里做出回应的希望真的很低。

我现有的服务器端代码:

string fileName = "D:''newZIPfile.zip";
        Stream myStream = Request.InputStream;
        byte[] message = new byte[myStream.Length];
        myStream.Read(message, 0, (int)myStream.Length);
        string data = System.Text.Encoding.UTF8.GetString(message);
        using (FileStream fs = new FileStream(fileName, FileMode.Create))
        {
            using (StreamWriter writer = new StreamWriter(fs, System.Text.Encoding.UTF8))
            {
                writer.Write(data);
            }
        }

我的客户端代码:

 File file2send = new File(newzipfile);
                String urlString = "http://192.168.1.189/prodataupload/Default.aspx";       // FOR TEST
                HttpParams httpParams = new BasicHttpParams();
                int some_reasonable_timeout = (int) (30 * DateUtils.SECOND_IN_MILLIS);
                HttpConnectionParams.setConnectionTimeout(httpParams, some_reasonable_timeout);
                HttpClient client = new DefaultHttpClient(httpParams);
                HttpPost post = new HttpPost(urlString);
                //System.out.println("SYNC'ing USING METHOD: " + post.getMethod().toString());
             try {
                   //OLD FILE-ENTITY MECHANISM >
                    FileEntity fEntity = new FileEntity(file2send, "application/zip");
                    //NEW (v1.5) INPUTSTREAM-ENTITY MECHANISM >
                    //InputStreamEntity fEntity = new InputStreamEntity(new FileInputStream(newzipfile), -1);
                   // fEntity.setContentType("application/zip");
                    post.setEntity(fEntity);
                    HttpResponse response = client.execute(post);
                    resEntity = response.getEntity();
                    res_code = response.getStatusLine().getStatusCode();            
                    final String response_str = EntityUtils.toString(resEntity);
                    if (resEntity != null) {        
                        Log.i("RESPONSE",response_str);
            //...

如何解决此问题? :(

保存的ZIP文件被损坏(从Android应用程序到IIS服务器)

我会

告诉问题是由于代码中的 ZIP 文件(二进制)转换为 UTF-8 流。

尝试将服务器端代码替换为以下内容:

string fileName = "D:''newZIPfile.zip";
using (FileStream fs = new FileStream(fileName, FileMode.Create))
{
    byte[] buffer = new byte[32768];
    int read;
    while ((read = Request.InputStream.Read(buffer, 0, buffer.Length)) > 0)
    {
        fs.Write (buffer, 0, read);
    }
}

这会将收到的输入流写入 ZIP 文件。

要同时接收客户端 ZIP 文件名,一种可能的方法是更改行

String urlString = "http://192.168.1.189/prodataupload/Default.aspx";

像这样:

String urlString = "http://192.168.1.189/prodataupload/Default.aspx?CLIENTFILENAME=" + 
    urlEncodedFilename;

因此,您可以使用 Request.Params 属性访问参数。

警告:不要信任客户端发送的文件名(有人可以操纵它!对参数进行严格的卫生/验证!

因此,

到目前为止,这个问题在我经历的许多论坛/线程中一直困扰着很多人。

这是我所做的:
- 将客户端更改为具有binary/octet-stream内容类型。

- 将服务器端代码更改为:更新:

if(Request.InputStream.Length < 32768) {
        Request.ContentType = "binary/octet-stream";
        Stream myStream = Request.InputStream;
        string fName = Request.Params["CLIENTFILENAME"];
        //string fName = Request.Params.GetValues("zipFileName");
        int iContentLengthCounter = 0;
        int maxlength = (int) myStream.Length;
        byte[] bFileWriteData = new byte[maxlength];
        string fileName = "D:''"+ fName +".zip";
        //FileStream oFileStream = new FileStream();
        while (iContentLengthCounter < maxlength)
       {
           iContentLengthCounter += Request.InputStream.Read(bFileWriteData, iContentLengthCounter, (maxlength - iContentLengthCounter));
       }
        System.IO.FileStream oFileStream = new System.IO.FileStream(fileName, System.IO.FileMode.Create, System.IO.FileAccess.Write);
       oFileStream.Write(bFileWriteData, 0, bFileWriteData.Length);
        oFileStream.Close();
       Request.InputStream.Close();
    }
    else
    {
    }

基本上。。我没有根据其长度收集数据。(答案需要编辑..稍后再做)