ASP.NET 使用浏览器下载 SFTP 文件
ASP.NET Download a SFTP file using the browser
我尝试使用 C# 和 asp.net 下载 SFTP 文件 (.csv),但所有示例都需要我有一个远程文件目录。
对于这种情况,我需要浏览器下载文件,而不是我将文件放入目录,因为浏览器(客户端)将无法直接将文件放入目录。
以前有人做过吗?
我尝试使用 SSH.NET,但没有找到方法。
解决了这个问题,方法是使用 SFTP 将文件移动到我的服务器,然后正常下载文件。
string host = @"host";
string username = "user";
string password = "pass";
string remoteDirectory = "/remote";
string localDirectory = Server.MapPath(@"\pdf\");
using (var sftp = new SftpClient(host, username, password))
{
sftp.Connect();
var files = sftp.ListDirectory(remoteDirectory);
foreach (var file in files)
{
string remoteFileName = file.Name;
if (remoteFileName == "APADEAATTT.csv")
{
using (Stream file1 = File.OpenWrite(localDirectory + "APADEAATTT.csv"))
{
sftp.DownloadFile(remoteDirectory + "APADEAATTT.csv", file1);
}
}
}
}
FileInfo fileInfo = new FileInfo(localDirectory+"APADEAATTT.csv");
Response.Clear();
Response.AddHeader("Content-Disposition", "attachment;filename=" + fileInfo.Name);
Response.AddHeader("Content-Length", fileInfo.Length.ToString());
Response.ContentType = "text/csv";
Response.Flush();
Response.WriteFile(fileInfo.FullName);
Response.End();
我尝试使用 C# 和 asp.net 下载 SFTP 文件 (.csv),但所有示例都需要我有一个远程文件目录。
对于这种情况,我需要浏览器下载文件,而不是我将文件放入目录,因为浏览器(客户端)将无法直接将文件放入目录。
以前有人做过吗?
我尝试使用 SSH.NET,但没有找到方法。
解决了这个问题,方法是使用 SFTP 将文件移动到我的服务器,然后正常下载文件。
string host = @"host";
string username = "user";
string password = "pass";
string remoteDirectory = "/remote";
string localDirectory = Server.MapPath(@"\pdf\");
using (var sftp = new SftpClient(host, username, password))
{
sftp.Connect();
var files = sftp.ListDirectory(remoteDirectory);
foreach (var file in files)
{
string remoteFileName = file.Name;
if (remoteFileName == "APADEAATTT.csv")
{
using (Stream file1 = File.OpenWrite(localDirectory + "APADEAATTT.csv"))
{
sftp.DownloadFile(remoteDirectory + "APADEAATTT.csv", file1);
}
}
}
}
FileInfo fileInfo = new FileInfo(localDirectory+"APADEAATTT.csv");
Response.Clear();
Response.AddHeader("Content-Disposition", "attachment;filename=" + fileInfo.Name);
Response.AddHeader("Content-Length", fileInfo.Length.ToString());
Response.ContentType = "text/csv";
Response.Flush();
Response.WriteFile(fileInfo.FullName);
Response.End();