不支持在没有设置SRID的情况下调用transform()

时间:2014-01-30 11:53:45

标签: python json django postgresql geodjango

在生产服务器上,我收到附加的错误,而不是在开发服务器上出现。两个环境都是相同的(相同的Django 1.6和Python 2.7版本,使用virtualenvs相同的RDBMS版本 - 一个postgresql 9.1服务器,在本地运行,配置与生产相似)。

我认为违规代码在views.py

from djgeojson.views import GeoJSONLayerView

class FilteredMapLayer(GeoJSONLayerView):
    def get_queryset(self):
        qs = super(FilteredMapLayer, self).get_queryset()
        bbox_data = self.request.GET.get('bbox', None)
        if bbox_data is not None:
            bbox_data = ( x for x in map(float, bbox_data.split(',')))
            bbox = Polygon.from_bbox(bbox_data)
            features = qs.filter(geom__bboverlaps=bbox)
        else:
            features = qs
        return features

因为这是urlpattern定义,在请求时会触发错误

url(r'^data.geojson$', FilteredMapLayer.as_view(model=MyModelName, precision = 2, simplify = 0.5), name='myurl'),

这里是完整的追溯,但没有向我提供任何关于我做错的信息....

Traceback (most recent call last):
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/django/core/handlers/base.py", line 114, in get_response
    response = wrapped_callback(request, *callback_args, **callback_kwargs)
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/django/utils/decorators.py", line 99, in _wrapped_view
    response = view_func(request, *args, **kwargs)
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/django/views/generic/base.py", line 69, in view
    return self.dispatch(request, *args, **kwargs)
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/django/utils/decorators.py", line 29, in _wrapper
    return bound_func(*args, **kwargs)
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/django/utils/decorators.py", line 99, in _wrapped_view
    response = view_func(request, *args, **kwargs)
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/django/utils/decorators.py", line 25, in bound_func
    return func(self, *args2, **kwargs2)
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/djgeojson/views.py", line 51, in dispatch
    return super(GeoJSONLayerView, self).dispatch(*args, **kwargs)
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/django/views/generic/base.py", line 87, in dispatch
    return handler(request, *args, **kwargs)
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/django/views/generic/list.py", line 153, in get
    return self.render_to_response(context)
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/djgeojson/views.py", line 41, in render_to_response
    **options)
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/djgeojson/serializers.py", line 335, in serialize
    self.serialize_queryset(queryset)
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/djgeojson/serializers.py", line 277, in serialize_queryset
    self.handle_field(obj, self.geometry_field)
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/djgeojson/serializers.py", line 177, in handle_field
    geometry = self._handle_geom(GEOSGeometry(value))
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/djgeojson/serializers.py", line 159, in _handle_geom
    geometry.transform(self.srid)
  File "/home/m2user/webapps/enea/local/lib/python2.7/site-packages/django/contrib/gis/geos/geometry.py", line 510, in transform
    raise GEOSException("Calling transform() with no SRID set is not supported")

....因为如果我检查存储在模型中的特征,它们都定义了一个SRID(4326)并且我没有尝试调用任何变换 - 我想 - 因为我正在使用相同的SRID。而且,我在这里重复一遍,dev服务器上的相同请求可以无缝地工作。

到目前为止我尝试过:

  • 从头开始重新创建数据库,重新加载所有数据。使用Django管理员我可以看到/编辑存储的功能
  • 检查了所有软件依赖关系并更新了https://github.com/makinacorpus/django-geojson
  • 主干的代码
  • 检查了模型定义:所有都有geom = models.MultiPolygonField(srid=4326)个字段
  • 在没有任何运气的情况下搜索Google和SO的类似问题

我没有更多的想法。欢迎任何建议!

1 个答案:

答案 0 :(得分:0)

我能够通过卸载然后重新安装所有库(作为ubuntu软件包),python解释器,所有代码,通过重新生成数据库(包括重新安装postgis)然后完全重启来解决我的问题nginx(因此是gunicorn)。但是,没有库更新,所以我仍然不明白究竟发生了什么。