[OpenLayers-Users] Strange
behaviour withOpenLayers.Request.POST and MapServer
christopher.schmidt at nokia.com
christopher.schmidt at nokia.com
Tue Jun 22 08:20:44 EDT 2010
On Jun 22, 2010, at 3:19 AM, ext David Alda Fernandez de Lezea wrote:
David,
Generally, the "TEMPLATE" error message means that you are not providing
enough information for MapServer to determine that the request is intended
to be a WMS or WFS request. In this case, it looks like you are not including
any of the parameters like SERVICE:WFS, version strings, etc. in your request
URL; It is possible that MapServer can therefore not determine that this is
a WFS request.
I don't know WFS well, but my recommendation would be to add additional WFS
parameters -- possibly an action, possibly a service, possibly others -- and
see if that improves the situation any.
Best of luck.
> David,
>
> Thanks for your response. The strange thing is that I've got a TEMPLATE defined at Layer level in MapServer's mapfile:
>
> LAYER
> DEBUG 5
> NAME "RecintosSigpac"
> PROJECTION
> "init=epsg:23030"
> END
> METADATA
> "wfs_title" "Recintos Sigpac 2009" ## REQUIRED
> "wfs_abstract" "Recintos"
> "wfs_name" "RecintosSigpac"
> "wfs_geometry_element_name" "MS_GEOMETRY"
> "wfs_srs" "EPSG:23030" ## Recommended
> "wfs_extent" "463506.9978541628 4702558.185239193 603185.4988525142 4811754.780732273"
> "gml_featureid" "gid" ## REQUIRED
> "gml_include_items" "all"
> END
> TYPE POLYGON
>
> CONNECTIONTYPE oraclespatial
> CONNECTION "admcarto/admcarto at ORA10GEX"
>
> DATA "GEOMETRY FROM (SELECT * FROM GT_SIGPAC_REC_2010_ED50) USING UNIQUE gid SRID 82337" #todo el sigpac
>
> DUMP TRUE ## REQUIRED
>
> CLASS
> NAME "Recintos"
> STYLE
> OUTLINECOLOR 255 255 255
> END
> TEMPLATE "ms_template.html"
> END
>
>
> STATUS ON
> END # Layer
>
> The thing is that with the following instruction:
>
> OpenLayers.Request.POST({url: this.onlineResource, callback: callbackFunction, data: filter});
>
> Having this.onlineResource = http://192.168.1.65/cgi-bin/mapserv.exe?map=../htdocs/MFD/ejemplo_wfs.map&
> data = filter for getFeature Request
>
> I don't have any troubles, I get the features correctly. But when I try to make the same request over the proxy, that's when then troubles come:
>
> OpenLayers.Request.POST({url: networkSettings.proxyURL, callback: callbackFunction, params: {url: this.onlineResource, method: "POST", data: filter}});
>
> Having:
>
> networkSettings.proxyURL = http://192.168.1.65/webproxy.php?
> filter = filter for getFeature Request
>
> I've tried, also, to use the parameter proxy but without success, in fact, I don't get anything, no error, no response, nothing at all.
>
> Apache log:
>
> 192.168.1.65 - - [22/Jun/2010:09:13:47 +0200] "POST /webproxy.php?http%3A%2F%2F192.168.1.65%2Fcgi-bin%2Fmapserv.exe%3Fmap%3D..%2Fhtdocs%2FMFD%2Fejemplo_wfs.map%26%26url%3Dhttp%253A%252F%252F192.168.1.65%252Fcgi-bin%252Fmapserv.exe%253Fmap%253D..%252Fhtdocs%252FMFD%252Fejemplo_wfs.map%2526%26method%3DPOST%26data%3D%253C%253Fxml%2520version%253D%25221.0%2522%2520%253F%253E%253Cwfs%253AGetFeature%2520service%253D%2522WFS%2522%2520version%253D%25221.1.0%2522%2520outputFormat%253D%2522text%252Fxml%253B%2520subtype%253Dgml%252F3.1.1%2522%2520xmlns%253Awfs%253D%2522http%253A%252F%252Fwww.opengis.net%252Fwfs%2522%2520xmlns%253Aogc%253D%2522http%253A%252F%252Fwww.opengis.net%252Fogc%2522%2520xmlns%253Axsi%253D%2522http%253A%252F%252Fwww.w3.org%252F2001%252FXMLSchema-instance%2522%2520xsi%253AschemaLocation%253D%2522http%253A%252F%252Fwww.opengis.net%252Fwfs%2520..%252Fwfs%252F1.1.0%252FWFS.xsd%2522%253E%253Cwfs%253AQuery%2520typeName%253D%2522RecintosSigpac%2522%253E%253CPropertyName%253EmsGeometry%253C%252FPropertyName%253E%250A%2509%2509%2509%2509%2520%253CFilter%253E%250A%2509%2509%2509%2509%2509%253COr%253E%250A%2509%2509%2509%2509%2509%2509%253CAnd%253E%250A%2509%2509%2509%2509%2509%2509%2509%253CPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%2509%253CPropertyName%253EPROVINCIA%253C%252FPropertyName%253E%253CLiteral%253E1%253C%252FLiteral%253E%250A%2509%2509%2509%2509%2509%2509%2509%253C%252FPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%253CPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%2509%253CPropertyName%253EMUNICIPIO%253C%252FPropertyName%253E%253CLiteral%253E1%253C%252FLiteral%253E%250A%2509%2509%2509%2509%2509%2509%2509%253C%252FPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%253CPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%2509%253CPropertyName%253EPOLIGONO%253C%252FPropertyName%253E%253CLiteral%253E1%253C%252FLiteral%253E%250A%2509%2509%2509%2509%2509%2509%2509%253C%252FPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%253CPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%2509%253CPropertyName%253EPARCELA%253C%252FPropertyName%253E%253CLiteral%253E1%253C%252FLiteral%253E%250A%2509%2509%2509%2509%2509%2509%2509%253C%252FPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%253CPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%2509%253CPropertyName%253ERECINTO%253C%252FPropertyName%253E%253CLiteral%253E1%253C%252FLiteral%253E%250A%2509%2509%2509%2509%2509%2509%2509%253C%252FPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%253C%252FAnd%253E%250A%2509%2509%2509%2509%2509%2509%253CAnd%253E%250A%2509%2509%2509%2509%2509%2509%2509%253CPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%2509%253CPropertyName%253EPROVINCIA%253C%252FPropertyName%253E%253CLiteral%253E1%253C%252FLiteral%253E%250A%2509%2509%2509%2509%2509%2509%2509%253C%252FPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%253CPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%2509%253CPropertyName%253EMUNICIPIO%253C%252FPropertyName%253E%253CLiteral%253E1%253C%252FLiteral%253E%250A%2509%2509%2509%2509%2509%2509%2509%253C%252FPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%253CPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%2509%253CPropertyName%253EPOLIGONO%253C%252FPropertyName%253E%253CLiteral%253E1%253C%252FLiteral%253E%250A%2509%2509%2509%2509%2509%2509%2509%253C%252FPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%253CPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%2509%253CPropertyName%253EPARCELA%253C%252FPropertyName%253E%253CLiteral%253E86%253C%252FLiteral%253E%250A%2509%2509%2509%2509%2509%2509%2509%253C%252FPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%253CPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%2509%2509%253CPropertyName%253ERECINTO%253C%252FPropertyName%253E%253CLiteral%253E1%253C%252FLiteral%253E%250A%2509%2509%2509%2509%2509%2509%2509%253C%252FPropertyIsEqualTo%253E%250A%2509%2509%2509%2509%2509%2509%253C%252FAnd%253E%250A%2509%2509%2509%2509%2509%253C%252FOr%253E%250A%2509%2509%2509%2509%253C%252FFilter%253E%2520%250A%2509%2509%2509%253C%252Fwfs%253AQuery%253E%253C%252Fwfs%253AGetFeature%253E HTTP/1.1" 200 -
>
> Maybe there is something wrong with webproxy.php???
>
> Thanks in advance.
>
> David,
>
> I just skimmed the text of post XML, but if your OpenLayers app is sending a query to MapServer, your layer will need a template. In the case of WFS, I don't think that you need a real template file. But, you still might need an entry in your LAYER that is something like TEMPLATE "dummy.html".
>
> David.
>
> -----Original Message-----
> From: mapserver-users-bounces at lists.osgeo.org [mailto:mapserver-users-bounces at lists.osgeo.org] On Behalf Of David Alda Fernandez de Lezea
> Sent: Monday, June 21, 2010 6:59 AM
> To: mapserver-users at lists.osgeo.org
> Subject: [mapserver-users] RV: [OpenLayers-Users] Strange behaviour with OpenLayers.Request.POST and MapServer
>
>
> Hi list,
>
> I posted this question in OpenLayers mailing list but without response, maybe here someone knwos what could be happening. I'm trying to load some data from a remote WFS Server (MapServer). At the beginning I used OpenLayers.Request.POST({url: this.onlineResource, callback: callbackFunction, method: 'POST', data: filter}); to load the features and it worked perfectly, but now, due to some architecture issues, I have to make the request over a proxy script made in php, but I don't get the features. I don't get any OpenLayers error but I get an error from MapServer:
>
> Error:
> mapserv(): Web application error. Traditional BROWSE mode requires a TEMPLATE in the WEB section, but none was provided.
>
> Request:
>
> OpenLayers.Request.POST({url: networkSettings.proxyURL + "?method=POST&url=" + escape(this.onlineResource) + "&data=" + filtro, callback: callbackFunction, method: 'POST', headers: {"Content-Type": "text/xml; charset=utf-8"}});
>
> Web Proxy:
>
> <?
>
> $strURL = @$_REQUEST["url"];
> $strMethod = @$_REQUEST["method"];
> $strData = @$_REQUEST["data"];
>
> $ch = curl_init();
> curl_setopt($ch, CURLOPT_URL, $strURL);
> if ($strMethod == "POST"){
> curl_setopt($ch, CURLOPT_POST, 1);
> curl_setopt($ch, CURLOPT_POSTFIELDS, $strData);
> }
>
> $data = curl_exec($ch);
> curl_close($ch);
>
> ?>
>
> In Firebug I can see all the parameters:
>
> data <?xml version="1.0" ?><wfs:GetFeature service="WFS" version="1.1.0" outputFormat="text/xml; subtype=gml/3.1.1" xmlns:wfs="http://www.opengis.net/wfs" xmlns:ogc="http://www.opengis.net/ogc" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.opengis.net/wfs ../wfs/1.1.0/WFS.xsd"><wfs:Query typeName="RecintosSigpac"><PropertyName>msGeometry</PropertyName> <Filter><Or><And><PropertyIsEqualTo><PropertyName>PROVINCIA</PropertyName><Literal>1</Literal></PropertyIsEqualTo><PropertyIsEqualTo><PropertyName>MUNICIPIO</PropertyName><Literal>1</Literal></PropertyIsEqualTo><PropertyIsEqualTo><PropertyName>POLIGONO</PropertyName><Literal>1</Literal></PropertyIsEqualTo><PropertyIsEqualTo><PropertyName>PARCELA</PropertyName><Literal>1</Literal></PropertyIsEqualTo><PropertyIsEqualTo><PropertyName>RECINTO</PropertyName><Literal>1</Literal></PropertyIsEqualTo></And><And><PropertyIsEqualTo><PropertyName>PROVINCIA</PropertyName><Literal>1</Literal></PropertyIsEqualTo><PropertyIsEqualTo><PropertyName>MUNICIPIO</PropertyName><Literal>1</Literal></PropertyIsEqualTo><PropertyIsEqualTo><PropertyName>POLIGONO</PropertyName><Literal>1</Literal></PropertyIsEqualTo><PropertyIsEqualTo><PropertyName>PARCELA</PropertyName><Literal>86</Literal></PropertyIsEqualTo><PropertyIsEqualTo><PropertyName>RECINTO</PropertyName><Literal>1</Literal></PropertyIsEqualTo></And></Or></Filter> </wfs:Query></wfs:GetFeature>
> method POST
> url http://192.168.1.65/cgi-bin/mapserv.exe?map=../htdocs/MFD/ejemplo_wfs.map&
>
> And in Apache access.log I get :
>
> 192.168.1.65 - - [21/Jun/2010:13:44:56 +0200] "POST /webproxy.php?&url=http%3A%2F%2F192.168.1.65%2Fcgi-bin%2Fmapserv.exe%3Fmap%3D..%2Fhtdocs%2FMFD%2Fejemplo_wfs.map%26&method=POST&data=%3C%3Fxml%20version%3D%221.0%22%20%3F%3E%3Cwfs%3AGetFeature%20service%3D%22WFS%22%20version%3D%221.1.0%22%20outputFormat%3D%22text%2Fxml%3B%20subtype%3Dgml%2F3.1.1%22%20xmlns%3Awfs%3D%22http%3A%2F%2Fwww.opengis.net%2Fwfs%22%20xmlns%3Aogc%3D%22http%3A%2F%2Fwww.opengis.net%2Fogc%22%20xmlns%3Axsi%3D%22http%3A%2F%2Fwww.w3.org%2F2001%2FXMLSchema-instance%22%20xsi%3AschemaLocation%3D%22http%3A%2F%2Fwww.opengis.net%2Fwfs%20..%2Fwfs%2F1.1.0%2FWFS.xsd%22%3E%3Cwfs%3AQuery%20typeName%3D%22RecintosSigpac%22%3E%3CPropertyName%3EmsGeometry%3C%2FPropertyName%3E%0A%09%09%09%09%20%3CFilter%3E%0A%09%09%09%09%09%3COr%3E%0A%09%09%09%09%09%09%3CAnd%3E%0A%09%09%09%09%09%09%09%3CPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%09%3CPropertyName%3EPROVINCIA%3C%2FPropertyName%3E%3CLiteral%3E1%3C%2FLiteral%3E%0A%09%09%09%09%09%09%09%3C%2FPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%3CPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%09%3CPropertyName%3EMUNICIPIO%3C%2FPropertyName%3E%3CLiteral%3E1%3C%2FLiteral%3E%0A%09%09%09%09%09%09%09%3C%2FPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%3CPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%09%3CPropertyName%3EPOLIGONO%3C%2FPropertyName%3E%3CLiteral%3E1%3C%2FLiteral%3E%0A%09%09%09%09%09%09%09%3C%2FPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%3CPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%09%3CPropertyName%3EPARCELA%3C%2FPropertyName%3E%3CLiteral%3E1%3C%2FLiteral%3E%0A%09%09%09%09%09%09%09%3C%2FPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%3CPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%09%3CPropertyName%3ERECINTO%3C%2FPropertyName%3E%3CLiteral%3E1%3C%2FLiteral%3E%0A%09%09%09%09%09%09%09%3C%2FPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%3C%2FAnd%3E%0A%09%09%09%09%09%09%3CAnd%3E%0A%09%09%09%09%09%09%09%3CPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%09%3CPropertyName%3EPROVINCIA%3C%2FPropertyName%3E%3CLiteral%3E1%3C%2FLiteral%3E%0A%09%09%09%09%09%09%09%3C%2FPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%3CPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%09%3CPropertyName%3EMUNICIPIO%3C%2FPropertyName%3E%3CLiteral%3E1%3C%2FLiteral%3E%0A%09%09%09%09%09%09%09%3C%2FPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%3CPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%09%3CPropertyName%3EPOLIGONO%3C%2FPropertyName%3E%3CLiteral%3E1%3C%2FLiteral%3E%0A%09%09%09%09%09%09%09%3C%2FPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%3CPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%09%3CPropertyName%3EPARCELA%3C%2FPropertyName%3E%3CLiteral%3E86%3C%2FLiteral%3E%0A%09%09%09%09%09%09%09%3C%2FPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%3CPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%09%09%3CPropertyName%3ERECINTO%3C%2FPropertyName%3E%3CLiteral%3E1%3C%2FLiteral%3E%0A%09%09%09%09%09%09%09%3C%2FPropertyIsEqualTo%3E%0A%09%09%09%09%09%09%3C%2FAnd%3E%0A%09%09%09%09%09%3C%2FOr%3E%0A%09%09%09%09%3C%2FFilter%3E%20%0A%09%09%09%3C%2Fwfs%3AQuery%3E%3C%2Fwfs%3AGetFeature%3E
>
> HTTP/1.1" 200 2508
>
> This seems to be OK, isn't it?
>
> Am I doing something wrong with the new request??
>
> Thanks in advance.
>
> Un saludo,
>
> ··················································································
>
> David Alda Fernández de Lezea
> Lurralde eta Biodibertsitate Saila / Dpto. de Territorio y Biodiversidad
>
> IKT
> Granja Modelo s/n · 01192 · Arkaute (Araba)
>
> ··················································································
> Tlfnos.: 945-00-32-95 Fax: 945-00.32.90
> ··················································································
> email: dalda at ikt.es web: www.ikt.es
> ··················································································
> _______________________________________________
> Users mailing list
> Users at openlayers.org
> http://openlayers.org/mailman/listinfo/users
> _______________________________________________
> mapserver-users mailing list
> mapserver-users at lists.osgeo.org
> http://lists.osgeo.org/mailman/listinfo/mapserver-users
> _______________________________________________
> Users mailing list
> Users at openlayers.org
> http://openlayers.org/mailman/listinfo/users
Regards,
--
Christopher Schmidt
Nokia
More information about the Users
mailing list