我为供应商创建了一个HTML5在线门户,他们可以根据需要上传和下载尽可能多的文件。不幸的是,我不允许向您展示截图。但问题出在这里: 如果上传了2个或更多文件,则程序应创建一个包含所有PDF的.zip文件。它被正确创建并且文件都在里面,但它们已损坏,意味着我无法打开它们。除此之外,他们获得了1 KB的文件大小。
String zipFile = String.Format(@"{0}.zip", Guid.NewGuid());
String zipPath = String.Format(@"{0}\{1}", Data.Properties.Settings.Default.DownloadPath, zipFile);
using (FileStream zipToOpen = new FileStream(zipPath, FileMode.CreateNew))
{
using (ZipArchive archive = new ZipArchive(zipToOpen, ZipArchiveMode.Create))
{
using (SqlConnection con = new SqlConnection(Data.Properties.Settings.Default.SelectionTMPDatabase))
{
con.Open();
using (SqlCommand cmd = new SqlCommand(String.Format("SELECT [FileName], [File] FROM {0} WHERE [DownloadId] = @downloadId", Data.Properties.Settings.Default.SelectionFileDatabaseTable), con))
{
cmd.Parameters.AddWithValue("@downloadId", downloadID);
using (SqlDataReader dr = cmd.ExecuteReader())
{
while (dr.Read())
{
if (dr["FileName"] != null && dr["FileName"] != DBNull.Value && fileNames.Contains(dr["FileName"].ToString()))
{
ZipArchiveEntry entry = archive.CreateEntry(dr["FileName"].ToString());
using (StreamWriter writer = new StreamWriter(entry.Open()))
{
writer.Write((byte[])dr["File"]);
}
这是创建.zip的部分。我希望你能帮帮我!如果您有任何问题,请询问!
答案 0 :(得分:0)
您正在创建一个空的zip条目,然后使用“文件”列的内容写入它 - 这真的是您打算做的吗?
如何获得archive.CreateEntryFromFile(dr["fileName"], fullPathToFile);
的完整路径,然后只需执行
sed