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)
前もって感謝します。さらに情報が必要な場合はお知らせください。乾杯!