4

AndroidアプリケーションをcakePhpWebサイトと通信し、データを共有することは可能ですか?可能であれば、Webサイトにログインできるアプリケーションを作成したいと思います。私の疑問は:

  1. アプリケーションからcakephpウェブサイトのログインページにユーザー名とパスワードを渡す方法は?誰かが私にサンプルプログラムを見せてもらえますか?

  2. Cakephpコントローラーはこのリクエストをどのように処理し、このリクエストに応答しますか?サンプルプログラムを見せてください。

(私はandroidとcakephpの初心者です。)

4

3 に答える 3

7

簡単な答え -- はい!

これとまったく同じことを行う 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 を使用して電話でサイト全体を作成する必要があるため、アプリケーションによっては、サイトにレスポンシブ デザインを作成し、モバイル ブラウジングを許可する方が簡単な場合があります。

チッ!

于 2013-01-12T11:28:40.887 に答える
2

Admad JWT Auth プラグインを使用する

Cakephp3 を使用している場合は、ログイン機能を次のように変更します。

public function token() {

        $user = $this->Auth->identify();


        if (!$user) {

            throw new UnauthorizedException('Invalid username (email) or password');
        }

        $this->set([
            'success' => true,
            'data' => [
                'token' => JWT::encode([
                    'sub' => $user['id'],
                    'exp' =>  time() + 604800
                ],
                Security::salt())
            ],
            '_serialize' => ['success', 'data']
        ]);
}

REST Api と JWT Auth の実装に関するこのチュートリアルを読むことができます

http://www.bravo-kernel.com/2015/04/how-to-add-jwt-authentication-to-a-cakephp-3-rest-api/

于 2016-10-27T19:12:49.207 に答える
-1

Cakephp のほとんどのビュー ページを ajax に再構築すると、cakephp をそのまま使用する目的が失われるように思われます。

于 2014-06-05T01:03:56.487 に答える