我正在构建一个应用程序,使用Rails和Backbone作为我的后端,需要用户登录才能访问某些页面。在其中一个经过用户身份验证的页面上,我进行了设置,以便他们可以通过输入数据在我的数据库中创建一个条目,然后将数据发送到Google Maps API以检索纬度和经度。
通过帮助函数,我正在检查用户是否经过身份验证,但是当我向Google Maps API发送AJAX调用时,用户令牌也会被发送。这是我现在设置的代码。
在我的api js文件中,该文件在我的页面加载时首先运行
var token = $('#api-token').val();
$.ajaxSetup({
headers:{
"accept": "application/json",
"token": token
}
});
在我的users_controller.rb
中def profile
authorize!
@user = current_user
@bathrooms = Bathroom.all.sort_by { |name| name }
render layout: 'profile_layout'
end
def authorize!
redirect_to '/login' unless current_user
end
def current_user
@current_user ||= User.find(session[:user_id]) if session[:user_id]
end
这是我的AJAX电话
function getInfo(location) {
console.log('getInfo');
$.ajax({
method: 'get',
url: 'https://maps.googleapis.com/maps/api/geocode/json',
data:{address: location, key: 'API KEY GOES HERE'},
success: function(data) {
extractData(data);
}
})
}
答案 0 :(得分:4)
您可以尝试以下步骤:
function getInfo(location) {
console.log('getInfo');
delete $.ajaxSettings.headers["token"]; // Remove header before call
$.ajax({
method: 'get',
url: 'https://maps.googleapis.com/maps/api/geocode/json',
data:{address: location, key: 'API KEY GOES HERE'},
success: function(data) {
extractData(data);
}
});
$.ajaxSettings.headers["token"] = token; // Add it back immediately
}