當前位置: 首頁>>代碼示例>>C#>>正文


C# Uri.Split方法代碼示例

本文整理匯總了C#中System.Uri.Split方法的典型用法代碼示例。如果您正苦於以下問題:C# Uri.Split方法的具體用法?C# Uri.Split怎麽用?C# Uri.Split使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在System.Uri的用法示例。


在下文中一共展示了Uri.Split方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: ParseQueryString

        /// <summary>
        /// Get a Url's parameters leaving them url encoded
        /// </summary>
        /// <param name="urlString">The query string</param>
        /// <returns></returns>
        public static Dictionary<string, string> ParseQueryString(string urlString)
        {
            string queryString = new Uri(urlString).Query;
            Dictionary<string, string> kVParms = new Dictionary<string, string>();

            queryString.Replace("?", "");

            string[] keyValPairing = queryString.Split('&', '=');

            if ((keyValPairing.Length == 0) || (keyValPairing.Length % 2 != 0))
            {
                throw new Exception("Invalid input Url");
            }

            keyValPairing[0] = keyValPairing[0].TrimStart('?');

            for (int i = 0; i < keyValPairing.Length - 1; i++)
            {
                kVParms.Add(keyValPairing[i], keyValPairing[i + 1]);
            }

            return kVParms;
        }
開發者ID:Archetype,項目名稱:TwitterPostWP7,代碼行數:28,代碼來源:Helpers.cs

示例2: FindButton_Click

        /// <summary>
        /// Called when the user looks for their League of Legends installation
        /// </summary>
        private void FindButton_Click(object sender, RoutedEventArgs e)
        {
            //Disable patching if the user selects another league installation.
            PatchButton.IsEnabled = false;
            RemoveButton.IsEnabled = false;

            //Create a file dialog for the user to locate their league of legends installation.
            OpenFileDialog findLeagueDialog = new OpenFileDialog();
            findLeagueDialog.DefaultExt = ".exe";
            findLeagueDialog.Filter = "League of Legends Launcher|lol.launcher*.exe|Garena Launcher|lol.exe"; //Only show the league of legends executables

            string RiotPath = Path.Combine(Path.GetPathRoot(Environment.SystemDirectory), "Riot Games", "League of Legends");
            string GarenaPath = Path.Combine(Path.GetPathRoot(Environment.SystemDirectory), "Program Files (x86)", "GarenaLoL", "GameData", "Apps", "LoL");

            //If they don't have League of Legends in the default path, look for Garena.
            if (!Directory.Exists(RiotPath))
                findLeagueDialog.InitialDirectory = Path.GetFullPath(GarenaPath);
            else
                findLeagueDialog.InitialDirectory = Path.GetFullPath(RiotPath);

            bool? selectedExectuable = findLeagueDialog.ShowDialog();

            if (selectedExectuable == false || selectedExectuable == null)
                return;

            //Remove the executable from the location
            Uri Location = new Uri(findLeagueDialog.FileName);
            string SelectedLocation = Location.LocalPath.Replace(Location.Segments.Last(), string.Empty);

            //Get the executable name to check for Garena
            string LastSegment = Location.Segments.Last();

            //If the file name is lol.exe, then it's garena
            if (!LastSegment.StartsWith("lol.launcher"))
            {
                type = ServerType.GARENA;
                RemoveButton.IsEnabled = true;
                PatchButton.IsEnabled = true;
                LocationTextbox.Text = Path.Combine(SelectedLocation, "Air");
            }
            else
            {
                //Check each RADS installation to find the latest installation
                string radsLocation = Path.Combine(SelectedLocation, "RADS", "projects", "lol_air_client", "releases");

                //Compare the version text with format x.x.x.x to get the largest directory
                var versionDirectories = Directory.GetDirectories(radsLocation);

                string finalDirectory = "";
                int BiggestVersion = 0;

                //Get the biggest version in the directory
                foreach (string x in versionDirectories)
                {
                    string CurrentVersion = new Uri(x).Segments.Last();
                    string[] VersionNumbers = CurrentVersion.Split('.');
                    for (int i = 0; i < VersionNumbers.Length; i++)
                    {
                        //Ensure that numbers like 0.0.2.1 are larger than 0.0.1.999
                        VersionNumbers[i] = VersionNumbers[i].PadLeft(3, '0');
                    }

                    int Version = Convert.ToInt32(string.Join("", VersionNumbers));

                    if (Version > BiggestVersion)
                    {
                        BiggestVersion = Version;
                        finalDirectory = x;
                    }
                }

                BackupVersion = BiggestVersion.ToString();

                //If the version isn't the intended version, show a message to the user. This is just a warning and probably can be ignored
                if (!_supportedVersions.Contains(BiggestVersion) && !Debugger.IsAttached)
                {
                    string Message = "This version of LESs may not support your version of League of Legends. Continue? This could harm your installation.";
                    MessageBoxResult versionMismatchResult = MessageBox.Show(Message, "Invalid Version", MessageBoxButton.YesNo);
                    if (versionMismatchResult == MessageBoxResult.No)
                        return;
                }

                type = ServerType.NORMAL;
                PatchButton.IsEnabled = true;
                RemoveButton.IsEnabled = true;

                LocationTextbox.Text = Path.Combine(finalDirectory, "deploy");
            }

            //Create the LESsBackup directory to allow the user to uninstall if they wish to later on.
            Directory.CreateDirectory(Path.Combine(LocationTextbox.Text, "LESsBackup"));
            Directory.CreateDirectory(Path.Combine(LocationTextbox.Text, "LESsBackup", BackupVersion));
        }
開發者ID:chienhao10,項目名稱:LoLEnhancementSuite,代碼行數:96,代碼來源:MainWindow.xaml.cs

示例3: generate_rule

        public static AmbiguousRule generate_rule(string url)
        {
            /*
            to solve issue #13
            there are a lot of second level domains, e.g. domain.info.au, domain.vic.au, ...
            so we check these rules:
            if url has only two parts (e.g. x.tld or www.x.tld) choose *.x.tld
            else if url has 3 parts or more(e.g. y.x.tld) and y!=www:
                check the following rules: (x = second part after tld)
                    1.(x is part of domain)
                        if len(x) > 4: assume that x is not part of extension, and choose  *.x.tld
                    2.(x is part of extension)
                        if len(x) <=2 (e.g. y.id.au) than choose *.y.x.tld
                        if x is in exceptions (com,net,org,edu,gov,asn.sch) choose *.y.x.tld
                            because many TLD's have second level domains on these, e.g. chap.sch.ir
                        if count(parts)==4 and first part is www: e.g. www.news.com.au, choose *.y.x.tld
                if none of the rules apply, the case is ambiguous, display both options in a context menu.
                    e.g. sealake.vic.au or something.fun.ir
            */

            // needed variables
            var domain = new Uri(url).Host;
            var parts = domain.Split('.');
            var count = parts.Length;
            var tld = parts.Last();
            var x = "";
            var y = "";
            try
            {
                x = parts[count - 2]; //second-level
                y = parts[count - 3]; //third-level
            }
            catch (IndexOutOfRangeException) { } // in case domain did not have 3 parts.. (e.g. localhost, google.com)

            // creating the patterns
            var rule_tld = String.Format("*.{0}.{1}", x, tld);
            var rule_second = String.Format("*.{0}.{1}.{2}", y, x, tld);
            var mode = 0; // 0 = error, 1=use rule_tld (*.x.tld), 2=use rule_second (*.y.x.tld), 3=ambiguous

            // this conditions are based on the long comment above
            if (count == 2 || (count == 3 && y == "www"))
                mode = 1;
            else if (count >= 3)
            {
                if (x.Length > 4)
                    mode = 1;
                else if (
                    (x.Length <= 2) ||
                    ((new[] { "com", "net", "org", "edu", "gov", "asn", "sch" }).Contains(x)) ||
                    (count == 4 && parts[0] == "www")
                    )
                    mode = 2;
                else
                    mode = 3;
            }

            return new AmbiguousRule()
            {
                tld_rule = rule_tld,
                second_rule = rule_second,
                mode = mode
            };
        }
開發者ID:zumoshi,項目名稱:BrowserSelect,代碼行數:63,代碼來源:Form1.cs

示例4: AppsList_SetContent

        private void AppsList_SetContent(IEnumerable<string> sections)
        {
            Image defIcon = Resources.PortableAppsBox;
            var index = 0;
            var icoDbPath = Path.Combine(HomeDir, "Assets\\icon.db");
            byte[] icoDb = null;
            byte[] swIcoDb = null;
            try
            {
                icoDb = File.ReadAllBytes(icoDbPath);
                if (!string.IsNullOrEmpty(_swSrv) && !string.IsNullOrEmpty(_swUsr) && !string.IsNullOrEmpty(_swPwd))
                    swIcoDb = NetEx.Transfer.DownloadData($"{_swSrv}/AppIcon.db", _swUsr, _swPwd);
            }
            catch (Exception ex)
            {
                Log.Write(ex);
            }
            foreach (var section in sections)
            {
                var nam = Ini.Read(section, "Name", AppsDbPath);
                var des = Ini.Read(section, "Description", AppsDbPath);
                var cat = Ini.Read(section, "Category", AppsDbPath);
                var ver = Ini.Read(section, "Version", AppsDbPath);
                var pat = Ini.Read(section, "ArchivePath", AppsDbPath);
                var siz = Ini.ReadLong(section, "InstallSize", 1, AppsDbPath) * 1024 * 1024;
                var adv = Ini.ReadBoolean(section, "Advanced", AppsDbPath);
                var src = "si13n7.com";
                if (pat.StartsWithEx("http"))
                    try
                    {
                        var tmpHost = new Uri(pat).Host;
                        var tmpSplit = tmpHost.Split('.');
                        src = tmpSplit.Length >= 3 ? string.Join(".", tmpSplit[tmpSplit.Length - 2], tmpSplit[tmpSplit.Length - 1]) : tmpHost;
                    }
                    catch (Exception ex)
                    {
                        Log.Write(ex);
                        continue;
                    }

                // Description filter
                switch (section)
                {
                    case "LibreCADPortable":
                        des = des.LowerText("tool");
                        break;
                    case "Mp3spltPortable":
                        des = des.UpperText("mp3", "ogg");
                        break;
                    case "SumatraPDFPortable":
                        des = des.LowerText("comic", "book", "e-", "reader");
                        break;
                    case "WinCDEmuPortable":
                        des = des.UpperText("cd/dvd/bd");
                        break;
                    case "WinDjViewPortable":
                        des = des.UpperText("djvu");
                        break;
                }
                des = $"{des.Substring(0, 1).ToUpper()}{des.Substring(1)}";

                var item = new ListViewItem(nam) { Name = section };
                item.SubItems.Add(des);
                item.SubItems.Add(ver);
                item.SubItems.Add(siz.FormatDataSize(true, true, true));
                item.SubItems.Add(src);
                item.ImageIndex = index;
                if (section.EndsWith("###") && (string.IsNullOrEmpty(_swSrv) || string.IsNullOrEmpty(_swUsr) || string.IsNullOrEmpty(_swPwd)))
                    continue;
                if (!string.IsNullOrWhiteSpace(cat))
                {
                    try
                    {
                        var nameHash = (section.EndsWith("###") ? section.Substring(0, section.Length - 3) : section).EncryptToMd5();
                        if (icoDb == null)
                            throw new ArgumentNullException(nameof(icoDb));
                        foreach (var db in new[] { icoDb, swIcoDb })
                        {
                            if (db == null)
                                continue;
                            using (var stream = new MemoryStream(db))
                                try
                                {
                                    using (var archive = new ZipArchive(stream))
                                        foreach (var entry in archive.Entries)
                                        {
                                            if (entry.Name != nameHash)
                                                continue;
                                            imgList.Images.Add(nameHash, Image.FromStream(entry.Open()));
                                            break;
                                        }
                                }
                                catch (Exception ex)
                                {
                                    Log.Write(ex);
                                }
                        }
                        if (!imgList.Images.ContainsKey(nameHash))
                            throw new PathNotFoundException(icoDbPath + ":" + nameHash + ">>" + section);
                    }
//.........這裏部分代碼省略.........
開發者ID:Si13n7,項目名稱:PortableAppsSuite,代碼行數:101,代碼來源:MainForm.cs

示例5: ParseQueryString

        static NameValueCollection ParseQueryString(string url)
        {
            url = url.Replace("?", "");

            var parameters = new NameValueCollection();

            foreach (var parameter in url.Split('&').Where(p => p.Contains('=')).Select(p => p.Split('=')))
            {
                parameters.Add(parameter[0], parameter[1]);
            }

            return parameters;
        }
開發者ID:danielcor,項目名稱:faken,代碼行數:13,代碼來源:FakeHttpRequest.cs


注:本文中的System.Uri.Split方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。