0

我正在从网络表单中获取字段并尝试将输入保存到数据库中。它目前正在用“+”符号替换不间断空格(即“Test 2”=“Test+2”)正如您将在下面看到的,我有一个 hack 替换字符串中的 + 并将其替换为“ ”。

我知道这是一个短边的解决方案。我原以为 'Encoding.GetEncoding("UTF-8") 会解决这个问题。我想找到某种可以解释任何类型字符的编码。请看下面的代码:

private List<Alias> GetAliasesFromPost()
{
    List<Alias> aliases = new List<Alias>();
    using (StreamReader sr = new StreamReader(Request.InputStream, Encoding.GetEncoding("UTF-8")))
    {
        string[] postedValues = sr.ReadLine().Split('&');
        for (int i = 0; i < postedValues.Length; i++)
        {
            if (postedValues[i].StartsWith("urlAlias="))
            {
                Alias alias = new Alias();
                string active = postedValues[i - 1].Replace("active=", string.Empty);
                alias.Active = string.Compare(active, "on", true) == 0;
                alias.UrlAlias = postedValues[i].Replace("urlAlias=", string.Empty);
                alias.Notes = postedValues[i + 1].Replace("notes=", string.Empty).Replace("+", " ");
                int Id = 0;
                Int32.TryParse(postedValues[i + 2].Replace("id=", string.Empty), out Id);
                alias.Id = Id;
                aliases.Add(alias);
            }
        }
    }
    return aliases;
}
4

1 回答 1

1

要解决您提出的具体问题,请在http://msdn.microsoft.com/en-us/library/system.web.httputility.urldecode.aspx中使用 UrlDecodepostedValues

但是你真的不应该解析Request. 只需使用Request.Params,这些值就已经在那里被解析和解码了。

于 2012-11-12T19:25:17.010 回答