所以我有这个程序使用短链接获取页面(我使用了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");
时,这会下载网址指向的网页?如果这个方法下载页面,我需要一些东西才能得到我的网址,所以如果有方法只获得一些标题,或只有网址,请告诉我。
答案 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)
创建HttpWebRequest,AllowAutoRedirect属性设置为false,然后查看响应中的Location标题。
var request = (HttpWebRequest) WebRequest.Create("http://tinyurl.com/345yj7x");
request.AllowAutoRedirect = false;
var response = request.GetResponse();
var location = response.Headers[HttpResponseHeader.Location];