jjzjj

javascript - PostgreSQL GeoJSON <- php -> JavaScript

coder 2024-05-05 原文

我正处于重建几乎一年前 build 的东西的阵痛中(不要问旧版本去了哪里——这很尴尬)。

核心功能使用 $.getJSON (ajax -ish) 在运行 PHP 脚本的 javascript 中调用,该脚本运行 PostgreSQL 查询,该查询构建 JSON 对象并返回它。 (暂停呼吸)。

问题在于 PostgreSQL 在轮到它大放异彩时会吐出什么。

我知道 build_json_object()build_json_array() PostgreSQL 9.4+ 中的功能,但是必须在其上运行的数据库之一尚未从 9.2 升级,我在下个月左右没有时间这样做。

现在我使用row_to_json() (以及几何图形上的 ST_AsGeoJSON())来构建我的 GeoJSON 集合,该集合通过回调返回到客户端。

this very nice post 得到我的启示(并且保持在该帖子查询结构的非常小的 epsilon 内),我运行以下查询:

select row_to_json(fc)
from (SELECT 'FeatureCollection' As type, 
      array_to_json(array_agg(f)) As features
from (SELECT 'Feature' as type,
      row_to_json((select l from (select $vars) as l)) as properties,
      ST_AsGeoJSON(ST_Transform(lg.g1,4326)) as geometry    
        from $source_table as lg   
 where g1 && ST_Transform(ST_SetSRID(ST_MakeEnvelope($bounds),4326),4283)
 ) as f ) as fc;

( $vars$source_table$bounds 由 PHP 从 POST 变量提供)。

当我fetchAll(PDO::FETCH_ASSOC)该查询到 $result , 和 json_encode($result[0]["row_to_json"]) , 返回给 javascript 的对象是一个可以是 JSON.parse() 的对象'd 给出预期(一个 Object 和一个 FeatureCollection 又包含一堆 Feature s,其中一个是 geometry )。

到目前为止,一切都很好。快速 - 获取数据并在一秒钟左右返回。

问题在于,在查询阶段,与几何相关的东西数组被双引号引起来:个人的 JSON 的相关段 Feature好像
{"type":"Feature","geometry":"{\\"type\\":\\"Polygon\\",
                              \\"coordinates\\":"[[[146.885447408,-36.143199088],
                                               [146.884964384,-36.143136232],
                                                ... etc
                                             ]]"
                              }",
                              "properties":{"address_pfi":"126546461",
                                            "address":"blah blah",
                                             ...etc }
}

如果我将 PostgreSQL 查询结果复制到文件中,这就是我得到的结果:这是在对输出进行任何错误处理之前。

请注意(双转义)双引号,仅影响几何 {type, coordinates} 的属性(在非 JSON 意义上) :“几何”位看起来像
"geometry":"{stuff}"

代替
"geometry":{stuff}

如果 PostgreSQL 生成的 JSON 通过 GeoJSONLint 的解析器/检查器,它会死在一个尖叫的堆中(它应该——它绝对不是“规范”)——当然它永远不会渲染:它吐出“无效类型” ' 如你所料。

目前,我已经通过一个 kludge (我的正常 M.O.)将它整理出来 - 当 $.getJSON返回对象,我
  • 把它变成一个字符串,然后
  • .replace(/"{/g, '{').replace(/}"/g, '}').replace(/\\/g, '') ,然后是
  • 把它变回一个物体并继续恶作剧。

  • 这不是一个好的做法(至少可以说):如果可以鼓励查询本身返回有效的 GeoJSON,那就更好了。

    问题似乎很明显是 row_to_json()阶段:它看到“几何”的属性集,并将其与“属性”的属性集区别对待——它(错误地)引用-转义“几何”(在斜线转义所有双引号之后)一个但是(正确)将“属性”保留为原样。

    所以在这本书长度的前奏之后......问题。

    我遗漏或忽略的查询是否有细微差别?我已经为相关的 PostgreSQL 命令提供了 RTFD,除了美化开关之外,我一无所知。

    当然,如果有一种简洁的方式来完成整个往返,我会接受它:唯一需要注意的是它必须保留其“实时获取”性质 - $.getJSON在 Google Map 中的“空闲”触发的监听器下运行,源表、感兴趣的变量和缩放(确定 $bounds)是用户确定的。

    (将其视为一种通过平移和缩放来更新 map 图层的方法,方法是一次仅获取约 200-300 个简单(地籍)特征 -0 远好于为缩放 10-19 的整个状态。我敢打赌,有人已经在 bl.ocks 上做过这样的事情,但我还没有找到)。

    最佳答案

    看来你错过了 json 的类型转换。
    它应该是

    ST_AsGeoJSON(ST_Transform(lg.g1,4326))::json
    

    没有强制转换,st_asgeojson 返回一个字符串,它是双重编码的。

    但是,您也可以获取属性和 geoJson,而不是使用 PHP json_decode json,使用 php 创建 geoJson 特征集合数组,最后 json_encode 整个结果。

    关于javascript - PostgreSQL GeoJSON <- php -> JavaScript,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38408633/

    有关javascript - PostgreSQL GeoJSON <- php -> JavaScript的更多相关文章

    1. ruby-on-rails - 如何从 format.xml 中删除 <hash></hash> - 2

      我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为

    2. ruby-on-rails - rspec should have_select ('cars' , :options => ['volvo' , 'saab' ] 不工作 - 2

      关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request

    3. ruby-on-rails - Nokogiri:使用 XPath 搜索 <div> - 2

      我使用Nokogiri(Rubygem)css搜索寻找某些在我的html里面。看起来Nokogiri的css搜索不喜欢正则表达式。我想切换到Nokogiri的xpath搜索,因为这似乎支持搜索字符串中的正则表达式。如何在xpath搜索中实现下面提到的(伪)css搜索?require'rubygems'require'nokogiri'value=Nokogiri::HTML.parse(ABBlaCD3"HTML_END#my_blockisgivenmy_bl="1"#my_eqcorrespondstothisregexmy_eq="\/[0-9]+\/"#FIXMEThefoll

    4. ruby-on-rails - 没有参数的 `<<`(小于两倍)是什么意思? - 2

      我在一个我想在formtasticGem中覆盖的方法中找到了这个。该方法如下所示:defto_htmlinput_wrappingdohidden_field_html是什么意思?在第三行做什么?我知道它对数组有什么作用,但在这里我不知道。 最佳答案 你可以这样读:hidden_field_htmllabel_with_nested_checkbox是连接到hidden_​​field_html末尾的参数-为了“清晰”,他们将其分成两行 关于ruby-on-rails-没有参数的`

    5. ruby-on-rails - 找不到 gem railties (>= 0.a) (Gem::GemNotFoundException) - 2

      我已经看到了一些其他的问题,尝试了他们的建议,但没有一个对我有用。我已经使用Rails大约一年了,刚刚开始一个新的Rails项目,突然遇到了问题。我卸载并尝试重新安装所有Ruby和Rails。Ruby很好,但Rails不行。当我输入railss时,我得到了can'tfindgemrailties。我当前的Ruby版本是ruby2.2.2p95(2015-04-13修订版50295)[x86_64-darwin15],尽管我一直在尝试通过rbenv设置ruby​​2.3.0。如果我尝试rails-v查看我正在运行的版本,我会得到同样的错误。我使用的是MacOSXElCapitan版本10

    6. ruby-on-rails - 使用 javascript 更改数据方法不会更改 ajax 调用用户的什么方法? - 2

      我遇到了一个非常奇怪的问题,我很难解决。在我看来,我有一个与data-remote="true"和data-method="delete"的链接。当我单击该链接时,我可以看到对我的Rails服务器的DELETE请求。返回的JS代码会更改此链接的属性,其中包括href和data-method。再次单击此链接后,我的服务器收到了对新href的请求,但使用的是旧的data-method,即使我已将其从DELETE到POST(它仍然发送一个DELETE请求)。但是,如果我刷新页面,HTML与"new"HTML相同(随返回的JS发生变化),但它实际上发送了正确的请求类型。这就是这个问题令我困惑的

    7. ruby-on-rails - 连接字符串时如何在 <%=%> block 内输出 html_safe? - 2

      考虑一下:现在这些情况:#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2我需要用其他字符串输出URL。我如何保证&符号不会被转义?由于我无法控制的原因,我无法发送&。求助!把我的头发拉到这里:\编辑:为了澄清,我实际上有一个像这样的数组:@images=[{:id=>"fooid",:url=>"http://

    8. Ruby -> 写入二维数组 - 2

      我正在处理http://prepwork.appacademy.io/mini-curriculum/array/中概述的数组问题我正在尝试创建函数my_transpose,它接受一个矩阵并返回其转置。我对写入二维数组感到很困惑!这是一个代码片段,突出了我的困惑。rows=[[0,1,2],[3,4,5],[6,7,8]]columns=Array.new(3,Array.new(3))putscolumns.to_s#Outputisa3x3arrayfilledwithnilcolumns[0][0]=0putscolumns.to_s#Outputis[[0,nil,nil],[

    9. ruby - 为什么必须明确指定 2 个参数才能 curry :> - 2

      考虑这个,它工作正常::>.to_proc.curry(2)[9][8]#=>true,because9>8然而,即使>是一个二元运算符,如果没有指定的元数,上面的代码将无法工作::>.to_proc.curry[9][8]#=>ArgumentError:wrongnumberofarguments(0for1)为什么两者不等价?注意:我特别想用提供的一个参数创建中间柯里化(Currying)函数,然后然后调用然后用第二个参数调用它。 最佳答案 curry必须知道传入的过程的数量,对吧?:-1来自arity的负值令人困惑,但基本上

    10. ruby-on-rails - 在 Ruby 或 Rails 中,hash.merge({ :order => 'asc' }) can return a new hash with a new key. 什么可以返回带有已删除键的新散列? - 2

      在Ruby(或Rails)中,我们可以做到new_params=params.merge({:order=>'asc'})现在new_params是一个带有添加键:order的散列。但是是否有一行可以返回带有已删除key的散列?线路new_params=params.delete(:order)不会工作,因为delete方法返回值,仅此而已。我们必须分3步完成吗?tmp_params=paramstmp_params.delete(:order)returntmp_params有没有更好的方法?因为我想做一个new_params=(params[:order].blank?||para

    随机推荐