У меня есть строка, которую я Gzip на сервере и загружаю клиенту с помощью класса WebClient. Когда я пытаюсь распаковать его, я получаю сообщение об ошибке, что Magic Number отсутствует. Я пробовал как класс GZipStream, так и методы ICSharpLib для решения этой проблемы, поэтому я в растерянности.
Сжатие / распаковка работает, если я пропущу этап загрузки через WebClient (используя DownloadData, который возвращает данные как byte []), поэтому я могу только предположить, что есть некоторая проблема с усечением или повреждением данных каким-то образом, но поскольку это сжатые данные, я не знаю, как это отладить.
Вот фрагмент кода, который кажется оскорбительным:
byte[] response
try {
response = client.DownloadData(Constants.GetSetting("SyncServer"));
} catch {
MessageBox.Show("There was a problem synchronizing the data. Please try verify the supplied credentials or try again later.", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
return;
}
int rows = SQLiteAPI.ImportStatHistoryXML(CurrentUser.User, myCampus, Convert.ToBase64String(response));
public static int ImportStatHistoryXML(Person tempPerson, Campus tempCampus, string xmlFile) {
byte[] encryptedFile = Convert.FromBase64String(xmlFile);
MemoryStream memStream = new MemoryStream(encryptedFile);
memStream.ReadByte();
GZipInputStream stream = new GZipInputStream(memStream);
MemoryStream memory = new MemoryStream();
byte[] writeData = new byte[4096];
int size;
while (true) {
size = stream.Read(writeData, 0, writeData.Length);
if (size > 0) {
memory.Write(writeData, 0, size);
} else {
break;
}
}
stream.Close();
memory.Position = 0;
StreamReader sr = new StreamReader(memory);
string decompressed = sr.ReadToEnd();
DataSet tempSet = new DataSet();
StringReader xmlReader = new StringReader(decompressed);
tempSet.ReadXml(xmlReader);
DataTable statTable = tempSet.Tables["Stats"];
...more unrelated processing of the table
}
Любая помощь будет оценена. P.S. Я использую строку Base64, чтобы иметь возможность передавать туда и обратно через Интернет. На самом деле это может быть та область, в которой я ошибаюсь, поскольку раньше я не выполнял веб-запросы и ответы между настольным приложением и веб-службой.