2011-04-04 58 views
1

我已经使用getCSV功能在客户端返回的CSV文件的完整下载后文件,但我想删除在客户端下载完成后文件如何删除客户端PC上的MVC asp.net

我函数

Public Function GetCSVFile(ByVal listSeperator As String) As CSVResult 
    Dim result As Boolean 
    Dim Service As New Service() 
    Dim types As IList(Of ProductType) = Service.GetAllWithAllLocalizedNames(New ListOptions(Name", OrderByDirection.Ascending, 1, -1)) 
    Dim path As String, colname As String 
    colname = Settings.GetLanguage() 
    path = Common.GetLocalizeDataPath() 
    Dim seprator As String = Common.GetListSepratorForCSV(listSeperator) 
    Dim cs As New CSVGenerator(path, colname, seprator) 
    result = cs.CreateCSVFile(types) 
    If result Then 
     Return New CSVResult With {.FileName = "Sample.csv", .Path = "~/Mydir/Sample.csv"} 
    Else 
     Return New CSVResult With {.FileName = "Error.csv", .Path = "~/Mydir/Error.csv"} 
    End If 
End Function 

回答

0

我看到你写了一个自定义的CSVResult类。您可以在将文件写入ExecuteResult方法中的响应流后删除该文件。显然,更好的方法是永不生成文件,但直接从内存提供CSV并将其写入响应流。

0

科瑞类和继承形式actionfilterattribute和覆盖OnResultExecuted方法

Public Class DeleteFileAttribute 
    Inherits ActionFilterAttribute 
    Public Overrides Sub OnResultExecuted(ByVal filterContext As ResultExecutedContext) 
     Dim path As String = filterContext.HttpContext.Server.MapPath("~/LocalizeData") 
     Dim filename As String = DirectCast(filterContext.Result, CSVResult).FileName 'filterContext.RouteData.Values("Path").ToString() 
     If File.Exists(System.IO.Path.Combine(path, filename)) Then 
      File.Delete(System.IO.Path.Combine(path, filename)) 
     End If 

    End Sub 
End Class 

和功能应用删除属性

例如

<DeleteFile()> 
Public Function GetCSVFile(ByVal listSeperator As String) As CSVResult 
    Dim result As Boolean 
    Dim Service As New Service() 
    Dim types As IList(Of ProductType) = Service.GetAllWithAllLocalizedNames(New ListOptions(Name", OrderByDirection.Ascending, 1, -1)) 
    Dim path As String, colname As String 
    colname = Settings.GetLanguage() 
    path = Common.GetLocalizeDataPath() 
    Dim seprator As String = Common.GetListSepratorForCSV(listSeperator) 
    Dim cs As New CSVGenerator(path, colname, seprator) 
    result = cs.CreateCSVFile(types) 
    If result Then 
     Return New CSVResult With {.FileName = "Sample.csv", .Path = "~/Mydir/Sample.csv"} 
    Else 
     Return New CSVResult With {.FileName = "Error.csv", .Path = "~/Mydir/Error.csv"} 
    End If 
End Function 

和执行结果多了一个问题,请刷新反应并关闭它

context.HttpContext.Response.Flush() 
context.HttpContext.Response.End() 
6

只适用于我,如果你刷新响应。属性过滤器应该看起来像这样

public class DeleteTempFileResultFilter : ActionFilterAttribute 
    { 
     public override void OnResultExecuted(ResultExecutedContext filterContext) 
     { 
      string fileName = ((FilePathResult)filterContext.Result).FileName; 

      filterContext.HttpContext.Response.Flush(); 
      filterContext.HttpContext.Response.End(); 

      System.IO.File.Delete(fileName); 
     } 
    } 
0

希望这会帮助你。首先,您需要将数据写入服务器上的文件,然后使用提供选项给客户端下载文件。之后使用file.delete删除服务器上的文件

Response.ContentType = ContentType; 
Response.AppendHeader("Content-Disposition","attachment;filename=myFile.txt"); 
Response.WriteFile(Server.MapPath("~/FilePath")); 
Response.Flush(); 
System.IO.File.Delete(Server.MapPath("~/FilePath")); 
Response.End();