何らかの理由で、 $.ajax() が呼び出されていません。$("#login").submit() 関数を検出しています。そこにアラートがあり、それが呼び出されたためです。
ファイルをビルドする代わりに、 http://build.phonegap.comを使用してファイルをビルドしています。
私はこれがたくさん出てくるのを見ます。しかし、そこにある解決策はどれも私を助けませんでした。私はこのコードを持っています:
signin.js:
$(window).load(function() {
$('#login').submit(function(e){
e.preventDefault();
obj = $(this);
un = $("input[name='user']").val();
pass = $("input[name='pass']").val();
$.ajax({
url: https+"getUserDetails",
data: {
username: un,
password: pass
},
dataType: "jsonp",
crossDomain: true,
type: "POST",
jsonpCallback: "user",
success: function(response, textStatus, jqXHR){
if(response.exists){
alert(response.access_token);
window.localStorage.setItem("user", JSON.stringify({"name": response.name, "id": response.id, "token":response.access_token}, null));
runController();
}
else{
$("#er").show();
}
}
});
return false;
});
});
config.js:
addr = "domain.com"
api = "/api/v1/"
http = "http://"+addr+api
https = "https://"+addr+api
config.xml:
....
<access origin="*" subdomains="true" />
<feature name="http://api.phonegap.com/1.0/device" />
<feature name="http://api.phonegap.com/1.0/file" />
<feature name="http://api.phonegap.com/1.0/network" />
<preference name="phonegap-version" value="2.1.0" />
....
index.html:
<!DOCTYPE html>
<html>
<head>
....
<title>Sign In</title>
<script type="text/javascript" src="js/jquery-1.8.2.min.js"></script>
<script type="text/javascript" src="js/controller.js"></script>
<script type="text/javascript" src="cordova-2.2.0.js"></script>
<script type="text/javascript" src="js/signin.js"></script>
....
</head>
<body>
....
<form id="login" action="#">
<h2 class="form-signin-heading">Please sign in</h2>
<input type="text" class="input-block-level" placeholder="Email address" name="user">
<input type="password" class="input-block-level" placeholder="Password" name="pass">
<label class="checkbox">
<input type="checkbox" value="remember-me"> Remember me
</label>
<button class="btn btn-large btn-primary" type="submit">Sign in</button>
</form>
....
</body>
</html>
更新 1
サーバーログに表示される内容は次のとおりです。
Started POST "/api/v1/getUserDetails" for .... at 2012-11-29 20:38:22 -0800
Processing by Api::V1::ApiController#user_details as JSON
Parameters: {"username"=>"user", "password"=>"[FILTERED]"}
WARNING: Can't verify CSRF token authenticity
Completed 406 Not Acceptable in 15ms (ActiveRecord: 2.9ms)
更新 2
API コントローラーで CSRF トークンを無効にしたのは、不要なためです。これは、phonegap で ajax 呼び出しを実行したときにサーバー ログに表示される内容です。
Started POST "/api/v1/getUserDetails" for .... at 2012-11-30 11:38:26 -0800
Processing by Api::V1::ApiController#user_details as JSON
Parameters: {"username"=>"user", "password"=>"[FILTERED]"}
Completed 406 Not Acceptable in 27ms (ActiveRecord: 0.4ms)
それでも 406 エラーが発生します。私が次に試すべきことは何ですか?