Problema com os filtros WFS (BBOX, INTERSECTS)

10

Estou tentando obter um recurso / recursos de uma pequena área usando o filtro BBOX (ou INTERSECTS) na minha consulta WFS. Eu deveria esperar apenas um pequeno conjunto de recursos ou um único recurso e, no entanto, a consulta retorna um monte considerável deles.

Eu tenho o GeoServer versão 2.2.2 com um armazenamento de dados Oracle. Desativei a seleção 'loose bbox' para que essa não seja a causa do problema.

Aqui está a consulta com um filtro BBOX:

<wfs:GetFeature
xmlns:wfs="http://www.opengis.net/wfs"
service="WFS"
version="1.1.0"
outputFormat="json"
xsi:schemaLocation="http://www.opengis.net/wfs
http://schemas.opengis.net/wfs/1.1.0/wfs.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <wfs:Query typeName="LiVi:LIIKENNE_ELEMENTTI" srsName="EPSG:3067" xmlns:LiVi="http://172.17.14.211:8080/LiVi">
    <ogc:Filter xmlns:ogc="http://www.opengis.net/ogc">
      <ogc:BBOX>
        <ogc:PropertyName>GEOMETRY</ogc:PropertyName>
        <gml:Envelope xmlns:gml="http://www.opengis.net/gml" srsName="EPSG:3067">
          <gml:lowerCorner>316600 6838986</gml:lowerCorner>
          <gml:upperCorner>327696 6844298</gml:upperCorner>
        </gml:Envelope>
      </ogc:BBOX>
    </ogc:Filter>
  </wfs:Query>
</wfs:GetFeature>

O problema persiste com o filtro INTERSECTS. O tamanho do polígono é de cerca de 10 x 10 metros.

<wfs:GetFeature
xmlns:wfs="http://www.opengis.net/wfs"
service="WFS"
version="1.1.0"
outputFormat="json"
xsi:schemaLocation="http://www.opengis.net/wfs
http://schemas.opengis.net/wfs/1.1.0/wfs.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <wfs:Query typeName="LiVi:LIIKENNE_ELEMENTTI" srsName="EPSG:3067" xmlns:LiVi="http://172.17.14.211:8080/LiVi">
    <ogc:Filter xmlns:ogc="http://www.opengis.net/ogc">
      <ogc:Intersects>
        <ogc:PropertyName>GEOMETRY</ogc:PropertyName>
        <gml:Polygon xmlns:gml="http://www.opengis.net/gml" srsName="EPSG:3067">
          <gml:exterior>
            <gml:LinearRing>
              <gml:posList>308082.07106781186 6833724.928932188 308082.07106781186 6833739.071067812 308067.92893218814 6833739.071067812 308067.92893218814 6833724.928932188 308082.07106781186 6833724.928932188</gml:posList>
            </gml:LinearRing>
          </gml:exterior>
        </gml:Polygon>
      </ogc:Intersects>
    </ogc:Filter>
  </wfs:Query>
</wfs:GetFeature>

Editar:

Aqui está outra solicitação (desta vez uma solicitação GET):

http://172.17.14.211:8080/geoserver/wfs?request=GetFeature&version=1.1.0&srsName=EPSG:3067&typeName=LiVi:LIIKENNE_ELEMENTTI&BBOX=316600,6838986,316605,6838991,EPSG:3067

Embora a área BBOX seja muito pequena, recebo 1263 recursos de volta, a maioria dos quais nem se enquadra dentro dos limites especificados na solicitação. Por exemplo, de um dos recursos na resposta:

<gml:boundedBy>
  <gml:Envelope srsDimension="2" srsName="http://www.opengis.net/gml/srs/epsg.xml#3067">
    <gml:lowerCorner>317629.69841038 6841957.478078741</gml:lowerCorner>
    <gml:upperCorner>317902.64972173725 6841987.000123474</gml:upperCorner>
  </gml:Envelope>
</gml:boundedBy>
mrLite
fonte

Respostas:

5

O problema foi resolvido configurando o valor SRID no banco de dados e usando o SRS nativo no Geoserver. Embora o código SRS declarado (e forçado) no Geoserver fosse o mesmo que o SRS nativo, aparentemente afetou os filtros espaciais.

http://172.17.14.211:8080/geoserver/wfs?request=GetFeature&version=1.1.0&srsName=EPSG:3067&typeName=LiVi:LIIKENNE_ELEMENTTI&BBOX=316600,6838986,316605,6838991,EPSG:3067

mrLite
fonte
2
Você pode adicionar um pouco mais de detalhes a esta resposta? O que você quer dizer com definir o SRID no banco de dados? Você diz que a solução foi usar o SRS nativo, mas também diz que o que estava usando era o SRS nativo, portanto não está claro para mim o que você fez para resolver isso.
ca0v