我正在使用opal-jquery向我的后端发送ajax请求,但是当我尝试在后端访问它时,json有效负载格式不正确。
当我在后端执行puts @params.to_s
时,它会显示为:
{"{\"username\":\"some_user\", \"password\":\"some_password\"}"=>nil}
因此,要获取我必须执行的登录详细信息:
@params.each do |k,v|
login_details = JSON.parse(k)
end
我的前端(蛋白石)提交请求如下所示:
def handle_login_submit details
url = "/client/api/auth"
HTTP.post url, payload: details.to_json, dataType: 'json' do |response|
case response.status_code / 100
when 2
puts response.status_code
self.login_state = :return_success
puts response.json
when 4
self.login_state = :return_failed
puts response.status_code
puts response.json
when 5
self.f_message = {type: :error, message: "There was a server error" }
self.login_state = :return_failed
end
end
end
我绝对知道细节格式正确,所以这不是问题。
我想最后,归结为是否是
opal-jquery错误地发送帖子请求
sinatra不正确地解析请求。
我不确定它是哪一个,但我倾向于认为它是前者,因为它在我切换到使用react.rb作为前端之前工作正常。
答案 0 :(得分:0)
遵循this的建议,特别是我正在做的事情:
before do
request.body.rewind
req = request.body.read
puts req
puts JSON.parse(req)
end
我能够看到请求正确地按照预期到达服务器。我不知道为什么,但是sinatra在@params
出现的这样一个地方错过了回应
{"{\"username\":\"some_user\", \"password\":\"some_password\"}"=>nil}
所以,最后我正在做
before do
request.body.rewind
@request_payload = JSON.parse(request.body.read)
request.body.rewind
end
在sinatra得到任何东西之前宣读请求正文,然后从@request_payload
读出我需要的参数。