簡単な答え -- はい!
これとまったく同じことを行う Android アプリの市場へのプッシュが完了しました。方法は次のとおりです。
1) Eclipse 内で Cordova PhoneGap (2.2.0 が最新バージョン) をダウンロードして使用方法を学習します。これにより、いくつかの HTML と多くの Javascript だけで、全体が非常に簡単になります。
2) JS で、AJAX パラメータを使用してログイン情報をプッシュするメソッドを作成します。例:
document.addEventListener('deviceready', onDeviceReady, false);
function onDeviceReady() {
$("#login").click(function() {
$email = $("#UserEmail").val();
$pass = $("#UserPassword").val();
$.ajax({
url : yourURL + 'api/users/login',
async : false,
data : {
'email' : $email,
'password' : $pass
},
dataType : 'json',
type : 'post',
success : function(result) {
/**
* do your login redirects or
* use localStorage to store your data
* on the phone. Keep in mind the limitations of
* per domain localStorage of 5MB
*/
// you are officially "logged in"
window.location.href = "yourUrl.html";
return;
},
error : function(xhr, status, err) {
// do your stuff when the login fails
}
});
}
}
3) Cake / PHP では、Users コントローラーが AJAX 呼び出しでユーザー名とパスワードのデータを取得し、それを認証に使用します。
<?php
class UsersController extends AppController {
public $name = 'Users';
public function beforeFilter() {
parent::beforeFilter();
$this->Auth->allow('api_login');
}
public function api_login() {
$this->autoRender = false;
if ($this->request->data && isset($this->request->data['email']) && isset($this->request->data['password'])) {
$arrUser = $this->User->find('all',array(
'conditions'=>array(
'email'=> $this->request->data['email'],
'password' => $this->Auth->password($this->request->data['password']),
)
)
);
if (count($arrUser) > 0) {
$this->Session->write('Auth.User',$arrUser[0]['User']);
// Do your login functions
$arrReturn['status'] = 'SUCCESS';
$arrReturn['data'] = array( 'loginSuccess' => 1,'user_id' => $arrUser[0]['User']['id'] );
} else {
$arrReturn['status'] = 'NOTLOGGEDIN';
$arrReturn['data'] = array( 'loginSuccess' => 0 );
}
} else {
$arrReturn['status'] = 'NOTLOGGEDIN';
$arrReturn['data'] = array( 'loginSuccess' => 0 );
}
echo json_encode($arrReturn);
}
}
?>
それだけです。これで、CakePHP に対して認証されました。
「api_」を使用する必要はありません。任意の関数名を使用できますが、これにより、モバイル ユーザーと Web ユーザーの実行を区別することができました。
これらは構成要素にすぎません。基本的には、HTML と Javascript を使用して電話でサイト全体を作成する必要があるため、アプリケーションによっては、サイトにレスポンシブ デザインを作成し、モバイル ブラウジングを許可する方が簡単な場合があります。
チッ!