表示されない - GoogleクラウドPHPMyAdminサーバーにRESTコールを送信していませんか?



phpmyadmin 日本語 (1)

私はあなたの質問が何であるか分かりませんが、それは明らかではありません。 Is there any way I can debug whether or not my script is actually going into the PHP code? How can I debug the PHP code? Is there any way I can debug whether or not my script is actually going into the PHP code? How can I debug the PHP code? あなたの答えはここにあります:

あなたのPHPコードをこれに変更してください:

<?php
    if (isset($_POST["Token"])) {

           $_uv_Token=$_POST["Token"];
           $conn = mysqli_connect("<db link>.appspot.com","root","","fcm") or die("Error connecting");
           $q="INSERT INTO users (`Token`) VALUES ( `{$_uv_Token}`) "
              ." ON DUPLICATE KEY UPDATE `Token` = `{$_uv_Token}`;";

      mysqli_query($conn,$q) or die(mysqli_error($conn));
      mysqli_close($conn);
    } else {
        echo "Token is not set!";
    }
?>

次に、 NotificationInstanceService.javaで、 OkHttpClientコールの応答をOkHttpClientます。

...
    try {
        Response response = client.newCall(request).execute();
    } catch (IOException e) {
        e.printStackTrace();
    }

    if (!response.isSuccessful()){
        Log.w(TAG, "Unexpected response"+response.toString());
    } else {
        Log.w(TAG, "response: "+response.body().string());
    }
...

https://code.i-harness.com

このlinkたどってGoogle Cloud phpMyAdminサーバを正常に導入しました。 phpMyAdminで作成したデータベースに書き込もうとしています。 Googleがリリースした新しいFirebase Cloud Messaging基づいて通知サービスを作成しようとしています。

NotificationInstanceService.java

public class NotificationInstanceService extends FirebaseInstanceIdService {
    private static final String TAG = "NotificationInstance";

    @Override
    public void onTokenRefresh() {

        //Getting registration token
        String refreshedToken = FirebaseInstanceId.getInstance().getToken();

        //Displaying token on logcat
        Log.d(TAG, "Refreshed token: " + refreshedToken);

        sendRegistrationToServer(refreshedToken);

    }

    private void sendRegistrationToServer(String token) {
        //You can implement this method to store the token on your server
        //Not required for current project
        OkHttpClient client = new OkHttpClient();
        //Create the request body
        RequestBody body = new FormBody.Builder().add("Token", token).build();
        //Know where to send the request to
        Request request = new Request.Builder().url("<db link>.appspot.com/fcm/register.php")
                .post(body)
                .build();
        //Create
        try {
            client.newCall(request).execute();
        } catch (IOException e) {
            e.printStackTrace();
        }

    }
}

そして、私はhttps://<db link>.appspot.comように見えるファイルを展開しました。

register.php

<?php
    if (isset($_POST["Token"])) {

           $_uv_Token=$_POST["Token"];
           $conn = mysqli_connect("<db link>.appspot.com","root","","fcm") or die("Error connecting");
           $q="INSERT INTO users (Token) VALUES ( '$_uv_Token') "
              ." ON DUPLICATE KEY UPDATE Token = '$_uv_Token';";

      mysqli_query($conn,$q) or die(mysqli_error($conn));
      mysqli_close($conn);
    }
 ?>

私はphpMyAdmin上に作成されたMySQLサーバで既に作成したことがわかっているユーザと呼ばれるユーザのデータベースに何も書き込んでいないように思えるので、混乱します。 私はユーザー名とパスワードも既にregister.php.設定されていることを知っていますregister.php. 私のスクリプトが実際にPHPコードに入っているかどうかをデバッグする方法はありますか? どうすればPHPコードをデバッグできますか? また、コードのその部分でデバッグできるように、Requestが実際にビルドされていることも確認します。 どんな助けもありがとう。 ありがとう!

編集:私のサーバーを展開しようとしたときに作成した参考になるかもしれないファイル:

app.yaml:

application: <app server url>
service: default
runtime: php55
api_version: 1
version: alpha-001

handlers:

- url: /(.+\.(ico|jpg|png|gif))$
  static_files: \1
  upload: (.+\.(ico|jpg|png|gif))$
  application_readable: true

- url: /(.+\.(htm|html|css|js))$
  static_files: \1
  upload: (.+\.(htm|html|css|js))$
  application_readable: true

- url: /(.+\.php)$
  script: \1
  login: admin

- url: /.*
  script: index.php
  login: admin

- url: /.*
  script: register.php
  login: admin

config.inc.php:

<?php 
$cfg['blowfish_secret'] = '<Secret>'; /* YOU MUST FILL IN THIS FOR COOKIE AUTH! */

/*
 * Servers configuration
 */
$i = 0;

// Change this to use the project and instance that you've created.
$host = '/cloudsql/<app server url>:us-central1:<database name>-app-php';
$type = 'socket';

/*
* First server
*/
$i++;
/* Authentication type */
$cfg['Servers'][$i]['auth_type'] = 'cookie';
/* Server parameters */
$cfg['Servers'][$i]['socket'] = $host;
$cfg['Servers'][$i]['connect_type'] = $type;
$cfg['Servers'][$i]['compress'] = false;
/* Select mysql if your server does not have mysqli */
$cfg['Servers'][$i]['extension'] = 'mysqli';
$cfg['Servers'][$i]['AllowNoPassword'] = true;
/*
 * End of servers configuration
 */

/*
 * Directories for saving/loading files from server
 */
$cfg['UploadDir'] = '';
$cfg['SaveDir'] = '';

$cfg['PmaNoRelation_DisableWarning'] = true;
$cfg['ExecTimeLimit'] = 60;
$cfg['CheckConfigurationPermissions'] = false;
// [END all]

php.ini:

google_app_engine.enable_functions = "php_uname, getmypid"

編集:ブラウザのテキスト、.appspot.com / fcm / register.phpに行く

(15) "utf8_unicode_ci" ["pma_console_height"] ["pma_collie_connection"] => string(1) "5" ["pma_lang"] => "] =>ストリング(2) "92"[" SACSID "] =>列(355) "〜AJKiYcFgym76QZfbMX35ddCTdKKf-O7q5koLvNZ0coWTMvw9aNlR5fusNyLRzFyw5DB_t2ygVuTEjHwgrgBco4-wr_V3Eer_Mf0CDuGX2e4IpirCNeiGxkRvaLgRPPyZNZWKUx1mF_DChjsksTirkY5WCzlA3G3MO9bBScrLw8kNOFGnvzkev3-B2x31s_TmnDN5aJ0G3-nPueI4FPpKaaMlPsITziccvXMpiehglQOKoo1Bol3EZSF1tjI9QoJuc-6X_sHgJ0IEppg7K-cBapaEx5CmDD2kWOggnVPWnGj1SiKFUnE3DZD46bjovf5me7IdwfVX22bv5D2PJDPQEN4m3D7yP3-WDG"[" pma_console_config "] =>列(103 "[" pma_console_mode "] =>文字列(4)" show "[" "]" {"alwaysExpand":false、 "startHistory":false、 "currentQuery":true、 "enterExecutes":false、 "darkTheme" (24) "osLKZ7q6eOaXJ475Q6tzw ==" ["pma_iv-1"] => "bpnJOOBe5x0iXPbbU5Nww ==" ["pmaUser-1"] =>文字列(24) "phpMyAdmin"] =>文字列(40) "cfd814e10982d138c7ed4a3ef510c454c0e5f9b9" pmaPass-1 "] =>文字列(24)" dwKZ9gQPCoe / Uk4sWS4s2g == "}

新しいregister.php:

<?php
    if (isset($_REQUEST["Token"])) {

           $_uv_Token=$_REQUEST["Token"];
           $conn = mysqli_connect("/cloudsql/<Database ServerURL>","root","","FCM") or die("Error connecting");
           $q="INSERT INTO users (Token) VALUES ( '$_uv_Token') "
              ." ON DUPLICATE KEY UPDATE Token = '$_uv_Token';";
      var_dump(mysqli_query($conn,$q));
      mysqli_query($conn,$q) or die(mysqli_error($conn));
      mysqli_close($conn);
    } else {
        var_dump($_REQUEST);
    }
 ?>

NotificationInstanceService.java

新しいPOSTリクエスト:

    Request request = new Request.Builder().url("<Application Server>/fcm/register.php?Token=123")
            .post(body)
            .build();




phpmyadmin