0

PhoneGap から Ruby アプリケーションに JSON 文字列を送信しようとしています。PhoneGap では、次のコードが JSON 文字列を送信しています。

            var location = {
                lat: position.coords.latitude,
                lng: position.coords.longitude
            }

            $.ajax({
              type: "post",
              dataType: 'json',
              data: location,
              url: 'http://localhost:3000/location/new'
            });

私の Ruby アプリには、応答を処理しようとしているコントローラーがあります。

def addlocation

    require 'json'
    json_string = params[:data]

    parsed_json = JSON.parse(json_string.to_json)

    if parsed_json["app"] == "Inrix PhoneGap"
        new_obj = Location.new
        new_obj.lat = parsed_json["lat"].to_f
        new_obj.lng = parsed_json["lng"].to_f
        new_obj.save
    end

end

パラメータがサーバー ログに表示されるため、PhoneGap からデータを取得していることはわかっています。適切なjson形式ではないように見えるため、応答を文字列に変換してからjsonに変換しようとしました。また、JSON.parse 関数の response.body と params[:data] を渡そうとしました。サーバーログに表示されるエラーは次のとおりです。

Started POST "/location/new" for 127.0.0.1 at 2013-07-23 01:14:37 -0700
Processing by LocationsController#addlocation as HTML
  Parameters: {"lat"=>"37.785834", "lng"=>"-122.406417"}
Completed 500 Internal Server Error in 0ms

JSON::ParserError (757: unexpected token at 'null'):
  app/controllers/locations_controller.rb:12:in `addlocation'


  Rendered /usr/local/rvm/gems/ruby-1.9.3-p392/gems/actionpack-3.2.13/lib/action_dispatch/middleware/templates/rescues/_trace.erb (1.1ms)
  Rendered /usr/local/rvm/gems/ruby-1.9.3-p392/gems/actionpack-3.2.13/lib/action_dispatch/middleware/templates/rescues/_request_and_response.erb (0.9ms)
  Rendered /usr/local/rvm/gems/ruby-1.9.3-p392/gems/actionpack-3.2.13/lib/action_dispatch/middleware/templates/rescues/diagnostics.erb within rescues/layout (7.5ms)

前もって感謝します。さらに情報が必要な場合はお知らせください。乾杯!

4

1 に答える 1