FtpWebRequest.GetResponse 메서드
정의
중요
일부 정보는 릴리스되기 전에 상당 부분 수정될 수 있는 시험판 제품과 관련이 있습니다. Microsoft는 여기에 제공된 정보에 대해 어떠한 명시적이거나 묵시적인 보증도 하지 않습니다.
FTP 서버 응답을 반환합니다.
public:
override System::Net::WebResponse ^ GetResponse();
public override System.Net.WebResponse GetResponse ();
override this.GetResponse : unit -> System.Net.WebResponse
Public Overrides Function GetResponse () As WebResponse
반환
WebResponse 인스턴스가 들어 있는 FtpWebResponse 참조입니다. 이 개체에는 요청에 대한 FTP 서버의 응답이 들어 있습니다.
예외
GetResponse() 또는 BeginGetResponse(AsyncCallback, Object)가 이 인스턴스에 대해 이미 호출된 경우
또는
HTTP 프록시를 사용하도록 설정되어 있고 DownloadFile, ListDirectory 또는 ListDirectoryDetails 이외의 FTP 명령을 사용하려고 한 경우
예제
다음 코드 예제에서는 요청의 데이터 스트림에 파일을 복사 하 고 서버에 데이터를 추가 하는 요청을 보내는 방법을 보여 줍니다. 이 예제에서는 를 호출 GetResponse 하여 요청을 보내고 서버에서 응답이 반환될 때까지 차단합니다.
static bool AppendFileOnServer( String^ fileName, Uri^ serverUri )
{
// The URI described by serverUri should use the ftp:// scheme.
// It contains the name of the file on the server.
// Example: ftp://contoso.com/someFile.txt.
// The fileName parameter identifies the file containing
// the data to be appended to the file on the server.
if ( serverUri->Scheme != Uri::UriSchemeFtp )
{
return false;
}
// Get the object used to communicate with the server.
FtpWebRequest^ request = dynamic_cast<FtpWebRequest^>(WebRequest::Create( serverUri ));
request->Method = WebRequestMethods::Ftp::AppendFile;
StreamReader^ sourceStream = gcnew StreamReader( fileName );
array<Byte>^fileContents = Encoding::UTF8->GetBytes( sourceStream->ReadToEnd() );
sourceStream->Close();
request->ContentLength = fileContents->Length;
// This example assumes the FTP site uses anonymous logon.
request->Credentials = gcnew NetworkCredential( "anonymous","janeDoe@contoso.com" );
Stream^ requestStream = request->GetRequestStream();
requestStream->Write( fileContents, 0, fileContents->Length );
requestStream->Close();
FtpWebResponse^ response = dynamic_cast<FtpWebResponse^>(request->GetResponse());
Console::WriteLine( "Append status: {0}", response->StatusDescription );
response->Close();
return true;
}
public static bool AppendFileOnServer(string fileName, Uri serverUri)
{
// The URI described by serverUri should use the ftp:// scheme.
// It contains the name of the file on the server.
// Example: ftp://contoso.com/someFile.txt.
// The fileName parameter identifies the file containing
// the data to be appended to the file on the server.
if (serverUri.Scheme != Uri.UriSchemeFtp)
{
return false;
}
// Get the object used to communicate with the server.
FtpWebRequest request = (FtpWebRequest)WebRequest.Create(serverUri);
request.Method = WebRequestMethods.Ftp.AppendFile;
StreamReader sourceStream = new StreamReader(fileName);
byte [] fileContents = Encoding.UTF8.GetBytes(sourceStream.ReadToEnd());
sourceStream.Close();
request.ContentLength = fileContents.Length;
// This example assumes the FTP site uses anonymous logon.
request.Credentials = new NetworkCredential ("anonymous","janeDoe@contoso.com");
Stream requestStream = request.GetRequestStream();
requestStream.Write(fileContents, 0, fileContents.Length);
requestStream.Close();
FtpWebResponse response = (FtpWebResponse) request.GetResponse();
Console.WriteLine("Append status: {0}",response.StatusDescription);
response.Close();
return true;
}
설명
FTP 관련 속성에 액세스하려면 이 메서드FtpWebResponse에서 반환된 개체를 WebResponse 로 캐스팅해야 합니다.
GetResponse 는 컨트롤 연결이 설정되고 데이터 연결을 만들 수도 있습니다. GetResponse 는 응답을 받을 때까지 차단합니다. 이를 방지하기 위해 대신 GetResponse및 EndGetResponse 메서드를 BeginGetResponse 호출하여 이 작업을 비동기적으로 수행할 수 있습니다.
속성이 Proxy 직접 또는 구성 파일에서 설정된 경우 FTP 서버와의 통신은 프록시를 통해 이루어집니다.
이 WebException throw되면 예외의 Response 및 Status 속성을 사용하여 서버의 응답을 확인합니다.
애플리케이션에 네트워크 추적을 사용하도록 설정하면 이 멤버에서 추적 정보를 출력합니다. 자세한 내용은 .NET Framework의 네트워크 추적을 참조하세요.
참고
동일한 응답 개체를 반환하기 위한 GetResponse 여러 호출입니다. 요청이 다시 실행되지 않습니다.
호출자 참고
이 메서드는 네트워크 트래픽을 생성합니다.
적용 대상
추가 정보
.NET