-1

テキストファイルを作成し、プロジェクトフォルダ内の場所に保存しました。テキストファイルをダウンロードできるように、そのテキストファイルを含むURLにリダイレクトするにはどうすればよいですか。

CreateCSVFileは、データテーブルに基づいてファイルパスにcsvファイルを作成します。

呼び出し:

string pth = ("C:\\Work\\PG\\AI Handheld Website\\AI Handheld Website\\Reports\\Files\\report.txt");
CreateCSVFile(data, pth); 

そして機能:

public void CreateCSVFile(DataTable dt, string strFilePath)
{

    StreamWriter sw = new StreamWriter(strFilePath, false);
    int iColCount = dt.Columns.Count;

    for (int i = 0; i < iColCount; i++)
    {
        sw.Write(dt.Columns[i]);

        if (i < iColCount - 1)
        {
            sw.Write(",");
        }
    }

    sw.Write(sw.NewLine);
    // Now write all the rows.
    foreach (DataRow dr in dt.Rows)
    {
        for (int i = 0; i < iColCount; i++)
        {
            if (!Convert.IsDBNull(dr[i]))
            {
                sw.Write(dr[i].ToString());
            }

            if (i < iColCount - 1)
            {
                sw.Write(",");
            }
        }
        sw.Write(sw.NewLine);
    }
    sw.Close();
    Response.WriteFile(strFilePath);
    FileInfo fileInfo = new FileInfo(strFilePath);

    if (fileInfo.Exists)
    {
        //Response.Clear();
        //Response.AddHeader("Content-Disposition", "attachment; filename=" + fileInfo.Name);
        //Response.AddHeader("Content-Length", fileInfo.Length.ToString());
        //Response.ContentType = "application/octet-stream";
        //Response.Flush();
        //Response.TransmitFile(fileInfo.FullName);

    }
}
4

2 に答える 2

1

Response.Redirect( "〜/ Reports / Files / report.txt");

于 2012-10-19T12:52:22.377 に答える
1

それらの後にテキストファイルのURLに移動しますsw.Close();Response.Redirect()ただし、物理ハードドライブのパスではなく、URLを取得する必要があります。コードに基づいて、次のことができます。

Uri appRootUri = new Uri(HttpContext.Current.Request.ApplicationPath);
Uri fileUri = new Uri(Path.GetFullPath(strFilePath));

Uri relativeUri = fileUri.MakeRelativeUri(appRootUri);

Response.Redirect("~/" + relativeUri.ToString());

コメントでアクィナスが示唆しているように、あなたは本当に逆の方向に進んでいるはずです。ファイルを保存する場所への相対パスを知っておく必要があります。その場合は、代わりに次の方法で保存できます。

// If you want to store it at http://yourapplication/files/file.txt
string relativeFilePath = "/files/file.txt";

CreateCSVFile(dt, Server.MapPath(relativeFilePath));
Response.Redirect("~" + relativeFilePath);
于 2012-10-19T12:59:40.067 に答える