C#WebClient OpenRead网址

时间:2010-12-22 09:51:19

标签: c# webclient

所以我有这个程序使用短链接获取页面(我使用了Google url shortener)。 为了构建我的示例,我使用了Using WebClient in C# is there a way to get the URL of a site after being redirected?

中的代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.IO;
using System.Net;

namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            MyWebClient client = new MyWebClient();
            client.OpenRead("http://tinyurl.com/345yj7x");            
            Uri uri = client.ResponseUri;            
            Console.WriteLine(uri.AbsoluteUri);
            Console.Read();
        }
    }

    class MyWebClient : WebClient
    {
        Uri _responseUri;

        public Uri ResponseUri
        {
            get { return _responseUri; }
        }

        protected override WebResponse GetWebResponse(WebRequest request)
        {
            WebResponse response = base.GetWebResponse(request);
            _responseUri = response.ResponseUri;
            return response;
        }
    }
}

我不明白一件事:当我client.OpenRead("http://tinyurl.com/345yj7x");时,这会下载网址指向的网页?如果这个方法下载页面,我需要一些东西才能得到我的网址,所以如果有方法只获得一些标题,或只有网址,请告诉我。

2 个答案:

答案 0 :(得分:11)

您只能使用HEAD请求获取标头,如下所示:

var request = WebRequest.Create(sourceUri);
request.Method = "HEAD";

var response = request.GetResponse();
if (response != null) {
    // You can now use response.Headers to get header info
}

答案 1 :(得分:1)

创建HttpWebRequestAllowAutoRedirect属性设置为false,然后查看响应中的Location标题。

var request = (HttpWebRequest) WebRequest.Create("http://tinyurl.com/345yj7x");
request.AllowAutoRedirect = false;
var response = request.GetResponse();
var location = response.Headers[HttpResponseHeader.Location];