Metro应用程序的后台传输(Up-loader)进度问题

时间:2013-05-16 18:22:52

标签: microsoft-metro progress uploader background-transfer

Metro应用程序的后台传输(上传程序)进度在一秒内给出100%的文件大于1 MB,如下所示:

*Running: c5593753-d155-425a-8e25-6b1f90bbff85
Progress: c5593753-d155-425a-8e25-6b1f90bbff85, Status: Running
 - Sent bytes: 131072 of 1310245 (10%), Received bytes: 0 of 0
Progress: c5593753-d155-425a-8e25-6b1f90bbff85, Status: Running
 - Sent bytes: 1310245 of 1310245 (100%), Received bytes: 0 of 0*

因此,我的进度条也显示100%,这当然是错误的。现在,上传完成后,我得到以下内容:

*Progress: c5593753-d155-425a-8e25-6b1f90bbff85, Status: Completed
 - Sent bytes: 1310245 of 1310245 (100%), Received bytes: 49 of 49
Completed: c5593753-d155-425a-8e25-6b1f90bbff85, Status Code: 200
 - Response updated; Header count: 9*

所以从某种意义上说,up-loader正在工作,但是这又错了,导致文件没有完成100%,实际上。我已经测试了一个10 MB的文件,问题仍然是相同的。进展为100%并且“完成“状态仅在3分钟后到来。

我使用http://code.msdn.microsoft.com/windowsapps/Background-Transfer-Sample-d7833f61中提供的相同上传示例。

我使用的代码如下:

private async void StartUpload_Click(object sender, RoutedEventArgs e)
    {

       if (ApplicationView.Value == ApplicationViewState.Snapped && !ApplicationView.TryUnsnap())
        {
            rootPage.NotifyUser("File picker cannot be opened in snapped mode. Please unsnap first.", NotifyType.ErrorMessage);
            return;
        }

        FileOpenPicker picker = new FileOpenPicker();
        picker.FileTypeFilter.Add("*");
        StorageFile file = await picker.PickSingleFileAsync();

        Uri uri;


        string uploadFileURl = "https://dummy.com/Link1/Link2";


        if (!Uri.TryCreate(uploadFileURl, UriKind.RelativeOrAbsolute, out uri))
        {
            rootPage.NotifyUser("Invalid URI.", NotifyType.ErrorMessage);
            return;
        }

        if (file == null)
        {
            rootPage.NotifyUser("No file selected.", NotifyType.ErrorMessage);
            return;
        }

        BackgroundUploader uploader = new BackgroundUploader();

        uploader.Method = "POST";
        uploader.SetRequestHeader("uid", "1@test.com");
        uploader.SetRequestHeader("pwd","test");



        uploader.SetRequestHeader("file_name", file.Name);
        uploader.SetRequestHeader("p", "/");

        //just hard coding the particular file size for sample here
        Int64 size = 221390;
        uploader.SetRequestHeader("file_size", size.ToString());


        UploadOperation upload = uploader.CreateUpload(uri, file);



        // Attach progress and completion handlers.
        await HandleUploadAsync(upload, true);
    }

  private async Task HandleUploadAsync(UploadOperation upload, bool start)
    {

        try
        {
            LogStatus("Running: " + upload.Guid, NotifyType.StatusMessage);

            Progress<UploadOperation> progressCallback = new Progress<UploadOperation>(UploadProgress);
            if (start)
            {

                // Start the upload and attach a progress handler.
                await upload.StartAsync().AsTask(cts.Token,progressCallback);
            }
            else
            {
                // The upload was already running when the application started, re-attach the progress handler.
                await upload.AttachAsync().AsTask(cts.Token, progressCallback);
            }

            ResponseInformation response = upload.GetResponseInformation();

            LogStatus(String.Format("Completed: {0}, Status Code: {1}", upload.Guid, response.StatusCode),
                NotifyType.StatusMessage);
        }
        catch (TaskCanceledException)
        {
            LogStatus("Canceled: " + upload.Guid, NotifyType.StatusMessage);
        }
        catch (Exception ex)
        {

                throw; 

        }
    }

  private void UploadProgress(UploadOperation upload)
    {
        MarshalLog(String.Format("Progress: {0}, Status: {1}", upload.Guid, upload.Progress.Status));

        BackgroundUploadProgress progress = upload.Progress;

        double percentSent = 100;
        if (progress.TotalBytesToSend > 0)
        {
            percentSent = progress.BytesSent * 100 / progress.TotalBytesToSend;
        }

        //MarshalLog(String.Format(" - Sent bytes: {0} of {1} ({2}%)",
        //  progress.BytesSent, progress.TotalBytesToSend, percentSent));

        MarshalLog(String.Format(" - Sent bytes: {0} of {1} ({2}%), Received bytes: {3} of {4}",
            progress.BytesSent, progress.TotalBytesToSend, percentSent,
            progress.BytesReceived, progress.TotalBytesToReceive));

        if (progress.HasRestarted)
        {
            MarshalLog(" - Upload restarted");
        }

        if (progress.HasResponseChanged)
        {
            // We've received new response headers from the server.
            MarshalLog(" - Response updated; Header count: " + upload.GetResponseInformation().Headers.Count);

            // If you want to stream the response data this is a good time to start.
            // upload.GetResultStreamAt(0);
        }
    }

1 个答案:

答案 0 :(得分:0)

我相信这个问题现在已经解决了。它是一个简单的DNS设置问题。

如果系统落后于代理:

  1. 转到gpedit.msc - &gt;在计算机配置下 - &gt;管理模板 - &gt;网络 - &gt;网络隔离。
  2. 必须使用“IPaddress:Port”语法启用应用程序的Internet代理服务器。
  3. 运行命令行:netsh winhttp import proxy source=ie
  4. 如果系统不在代理服务器之后:

    请确保系统设置中的DNS服务器设置正确。意思是,对于首选&amp;必须提供辅助DNS服务器实际的DNS服务器地址,而不是代理服务器地址。