Windows窗体应用程序在Web上找到链接

时间:2015-05-26 13:18:53

标签: c# regex winforms webclient-download

我需要创建一个方法,在网站(Hudson服务器)上找到最新版本的应用程序并允许下载它。

到现在为止我使用正则表达式扫描所有HTML并找到href标签并搜索我想要的字符串。

我想知道是否有最简单的方法。 我附上了今天使用的代码:

namespace SDKGui
{
    public struct LinkItem
    {
        public string Href;
        public string Text;

    public override string ToString()
    {
        return Href;
    }
}

static class LinkFinder
{
    public static string Find(string file)
    {
        string t=null;
        List<LinkItem> list = new List<LinkItem>();

        // 1.
        // Find all matches in file.
        MatchCollection m1 = Regex.Matches(file, @"(<a.*?>.*?</a>)",
            RegexOptions.Singleline);


        // 2.
        // Loop over each match.
        foreach (Match m in m1)
        {
            string value = m.Groups[1].Value;
            LinkItem i = new LinkItem();

            // 3.
            // Get href attribute.
            Match m2 = Regex.Match(value, @"href=\""(.*?)\""",
            RegexOptions.Singleline);
            if (m2.Success)
            {
                i.Href = m2.Groups[1].Value;
            }

            // 4.
            // Remove inner tags from text.
            t = Regex.Replace(value, @"\s*<.*?>\s*", "",
            RegexOptions.Singleline);

            if (t.Contains("hms_sdk_tool_"))
            {
                i.Text = t;
                list.Add(i);
                break;
            }



        }
        return t;
    }

}
}

1 个答案:

答案 0 :(得分:0)

使用HtmlAgilityPack收集所有href值并过滤任何条件都很容易。以下方法显示了如何访问网页,获取所有<a>代码,并返回包含href的所有hms_sdk_tool_值的列表:

private List<string> HtmlAgilityCollectHrefs(string url)
{
    var webGet = new HtmlAgilityPack.HtmlWeb();
    var doc = webGet.Load(url);
    var a_nodes = doc.DocumentNode.SelectNodes("//a");
    return a_nodes.Select(p => p.GetAttributeValue("href", "")).Where(n => n.Contains("hms_sdk_tool_")).ToList();
}

或者,如果您对1个返回字符串感兴趣,请使用

private string GetLink(string url)
{
    var webGet = new HtmlAgilityPack.HtmlWeb();
    var doc = webGet.Load(url);
    var a_nodes = doc.DocumentNode.SelectNodes("//a");
    return a_nodes.Select(p => p.GetAttributeValue("href", "")).Where(n => n.Contains("hms_sdk_tool_")).FirstOrDefault();
}