проблема поиска не-ASCII символов в XML-файле с использованием linq to XML - PullRequest
0 голосов
/ 14 января 2011

Я выполняю поиск элемента в файле XML, используя следующий запрос linq to xml

XElement inspections = XElement.Load(new StreamReader( Server.MapPath(ResolveUrl(SelectInspection.InspectionFilePath)),Encoding.UTF8));

XElement inspection = (from elements in inspections.Elements("inspection")
                                       where elements.Element("inspectionid").Value == inspectionId.ToString()
                                       && elements.Element("databasename").Value == Encoding.UTF8.GetString(Request.ContentEncoding.GetBytes (Request.QueryString("DbName")))
                                       select elements).Single();

И мой XML-файл

<?xml version="1.0" encoding="utf-8"?>
<inspections>
   <inspection>
    <inspectionid>8</inspectionid>
    <databasename>Åker</databasename>
    <exported>false</exported>
  </inspection>
 </inspections>

Несмотря на то, что Request.QueryString("DbName") равно "Åker", запрос не возвращает никакого результата.

Ответы [ 2 ]

2 голосов
/ 14 января 2011

Мне это кажется неправильным:

Encoding.UTF8.GetString(Request.ContentEncoding
                               .GetBytes(Request.QueryString("DbName")))

Почему бы Request.QueryString уже не применил соответствующее декодирование в ASP.NET?

Я предлагаю вам разбить проблему на две частипополам:

  • Убедитесь, что LINQ to XML может найти строку: сделайте это в консольном приложении с жестко закодированными данными
  • Убедитесь, что вы можете получить правильную строку запроса: сделайте эторегистрируя кодовые точки Unicode в Request.QueryString("DbName") как целые числа

Я бы ожидал , что вы просто сможете использовать Request.QueryString("DbName") напрямую.

0 голосов
/ 14 января 2011

Я создал тестовую веб-страницу со следующим содержанием:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="WebForm1" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
     <a href="WebForm1.aspx?DbName=Åker">Test</a><br />
    <asp:Label runat="server" ID="lblTest"></asp:Label>
    </form>
</body>
</html>

Это код:

using System;
using System.Linq;
using System.Xml.Linq;

public partial class WebForm1 : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        var xmlStr = "<?xml version=\"1.0\" encoding=\"utf-8\"?><inspections>   <inspection>    <inspectionid>8</inspectionid>    <databasename>Åker</databasename>    <exported>false</exported>  </inspection> </inspections>";
        var inspections = XElement.Parse(xmlStr);
        XElement inspection = (from elements in inspections.Elements("inspection")
                               where elements.Element("databasename").Value == Request.QueryString["DbName"]
                               select elements).FirstOrDefault();
        lblTest.Text = (inspection != null).ToString();

    }
}

Когда я нажимаю ссылку Test, текст lblTestСтановится Истиной, поэтому запрос находит элемент как ожидалось.

В дополнение к решению Джона Скита, которое, вероятно, решает проблему, вы можете передать неверное значение inspectionId параметра, что приведет к сбою поиска.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...