如何解决XmlDeserialization在中等信任级别中失败
| 我们以中等信任级别托管我们的网站,托管提供商拒绝给予我们完全信任。我们的代码尝试使用下面的代码片段反序列化代码,但由于反射权限错误而失败。调试后,我收到“ XML文档(71,6)中有错误。”错误。在完全信任的情况下,它运行良好。在我们决定转向完全信任托管服务提供商之前,请有人提出我可以解决此问题的建议。 public static T Decrypt<T>(Stream stream)
{
Rijndael rij = Rijndael.Create();
rij.Key = key;
rij.IV = iv;
T obj = default(T); // assigns null if T is a reference type,or 0 (zero) for value types
using (CryptoStream cs = new CryptoStream(stream,rij.CreateDecryptor(),CryptoStreamMode.Read))
{
using (GZipStream zs = new GZipStream(cs,CompressionMode.Decompress))
{
XmlSerializer xs = new XmlSerializer(typeof(T));
obj = (T)xs.Deserialize(zs);
zs.Close();
}
cs.Close();
}
return obj;
}
解决方法
打开项目属性,并将“生成序列化程序集”设置为“打开”。这将使编译器在编译时而不是在运行时生成序列化程序集。只要确保部署序列化程序集即可。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。