我对 Silverlight 相当陌生。我正在尝试在 Silverlight 中下载 .pdf 文件(以及其他几种格式)。用户点击一个按钮,系统去获取URI,然后显示一个SaveFileDialog来获取保存文件的位置。这是一个代码片段:
WebClient wc = new WebClient();
wc.DownloadStringCompleted += (s, e3) =>
{
if (e3.Error == null)
{
try
{
byte[] fileBytes = Encoding.UTF8.GetBytes(e3.Result);
using (Stream fs = (Stream)mySaveFileDialog.OpenFile())
{
fs.Write(fileBytes, 0, fileBytes.Length);
fs.Close();
MessageBox.Show("File successfully saved!");
}
}
catch (Exception ex)
{
MessageBox.Show("Error getting result: " + ex.Message);
}
}
else
{
MessageBox.Show(e3.Error.Message);
};
wc.DownloadStringAsync("myURI", UriKind.RelativeOrAbsolute));
该文件保存正常,但它大约是原始文件的两倍并且不可读。e3.Result 看起来大小合适(5Mb),但我怀疑它包含很多无关字符。FileBytes 似乎大了大约两倍(11Mb)。我想尝试使用 DownloadDataAsync 而不是 DownloadStringAsync(希望它能解决任何编码问题),但 Silverlight 有一个非常精简的 System.Net.WebClient 版本,并且不支持 DownloadDataAsync(它不会编译)。
我相当确定这是一个编码问题,但我不知道如何解决它。