web-dev-qa-db-ja.com

Android studio getSlotFromBufferLocked:不明なバッファーエラー

ユーザーがアカウントを作成できるように、簡単なログインとアプリの登録を行いたいです。 (名前、ユーザー名、パスワード)アカウントを保存するWAMPとMYSQLデータベースを使用します。

登録フォームにユーザー情報を入力して[登録]をクリックすると、次のエラーが表示されます。

09-14 09:30:39.864    2624-2638/com.example.appname.appname E/Surface﹕ getSlotFromBufferLocked: unknown buffer: 0xab7115e0
09-14 09:30:48.632    2624-2638/com.example.appname.appname E/Surface﹕ getSlotFromBufferLocked: unknown buffer: 0xab7125a0
09-14 09:30:51.940    2624-2638/com.example.appname.appname E/Surface﹕ getSlotFromBufferLocked: unknown buffer: 0xab7125a0

データベースを確認すると、アカウントは保存されませんでした。

MainActivity.Java

import Android.app.Activity;
import Android.content.Intent;
import Android.support.v7.app.AppCompatActivity;
import Android.os.Bundle;
import Android.view.Menu;
import Android.view.MenuItem;
import Android.view.View;

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }
    public void userReg(View v)
    {
        startActivity(new Intent(this, Register.class));
    }
    public void userLogin(View view)
    {


    }


}

Register.Java

import Android.app.Activity;
import Android.support.v7.app.AppCompatActivity;
import Android.os.Bundle;
import Android.view.Menu;
import Android.view.MenuItem;
import Android.view.View;
import Android.widget.EditText;

public class Register extends Activity {
    EditText ET_NAME,ET_USER_NAME,ET_USER_PASS;
    String name,user_name,user_pass;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.register_layout);
        ET_NAME = (EditText) findViewById(R.id.name);
        ET_USER_NAME = (EditText) findViewById(R.id.new_user_name);
        ET_USER_PASS = (EditText) findViewById(R.id.new_user_pass);
    }

    public void userReg(View view)
    {
        name = ET_NAME.getText().toString();
        user_name = ET_USER_NAME.getText().toString();
        user_pass = ET_USER_PASS.getText().toString();
        String method = "register";
        BackgroundTask backgroundTask = new BackgroundTask(Register.this);
        backgroundTask.execute(method,name,user_name,user_pass);
        finish();
    }
}

Backgroundtask.Java

import Android.app.AlertDialog;
import Android.content.Context;
import Android.os.AsyncTask;
import Android.widget.Toast;

import Java.io.BufferedReader;
import Java.io.BufferedWriter;
import Java.io.IOException;
import Java.io.InputStream;
import Java.io.InputStreamReader;
import Java.io.OutputStream;
import Java.io.OutputStreamWriter;
import Java.net.HttpURLConnection;
import Java.net.MalformedURLException;
import Java.net.URL;
import Java.net.URLEncoder;

public class BackgroundTask extends AsyncTask<String, Void, String> {
    AlertDialog alertDialog;
    Context ctx;

    BackgroundTask(Context ctx) {
        this.ctx = ctx;

    }

    @Override
    protected void onPreExecute() {
        super.onPreExecute();
    }

    @Override
    protected String doInBackground(String... params) {
        String reg_url = "http://10.0.2.2.2/webapp/register.php";
        String login_url = "http://10.0.2.2.2/webapp/login.php";
        String method = params[0];
        if (method.equals("register")) {
            String name = params[1];
            String user_name = params[2];
            String user_pass = params[3];
            try {
                URL url = new URL(reg_url);
                HttpURLConnection httpURLConnection = (HttpURLConnection) url.openConnection();
                httpURLConnection.setRequestMethod("POST");
                httpURLConnection.setDoOutput(true);
                OutputStream OS = httpURLConnection.getOutputStream();
                BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(OS, "UTF-8"));
                String data = URLEncoder.encode("user", "UTF-8") + "=" + URLEncoder.encode(name, "UTF-8") + "&" +
                        URLEncoder.encode("user_name", "UTF-8") + "=" + URLEncoder.encode(user_name, "UTF-8") + "&" +
                        URLEncoder.encode("user_pass", "UTF-8") + "=" + URLEncoder.encode(user_pass, "UTF-8");
                bufferedWriter.write(data);
                bufferedWriter.flush();
                bufferedWriter.close();
                OS.close();
                InputStream IS = httpURLConnection.getInputStream();
                IS.close();
                return "Registration Success...";
            } catch (MalformedURLException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }

        return null;
    }

    @Override
    protected void onProgressUpdate(Void... values) {
        super.onProgressUpdate(values);
    }

    @Override
    protected void onPostExecute(String result) {
        Toast.makeText(ctx, result, Toast.LENGTH_LONG).show();
    }
}

register.php

<?php
require "init.php";
$name = $_POST["user"];
$user_name = $_POST["user_name"];
$user_pass = $_POST["user_pass"];

$sql_query = "insert into user_info values('$name','$user_name','$user_pass');";

if(mysqli_query($con,$sql_query))
{
//echo"<h3> Data insertion success...</h3>";
}
else{
//echo "Data insertion error..".mysqli_error($con);
}



?>

init.php

<?php
$db_name="myDBname";
$mysql_user = "root";
$mysql_pass = "root";
$server_name="localhost";

$con = mysqli_connect($server_name,$mysql_user,$mysql_pass,$db_name);
if(!$con)
{
//echo"Connection Error".mysqli_connect_error();
}
else
{
//echo"<h3> Database connection success.....</h3>";
}


?>
38
Rob12

編集:

これはAndroidのバグで、Marshmallowの以降のバージョンで修正されました

元の:

これはマシュマロ特有のものだと思います。マシュマロデバイスを使用していますか?

このエラーは、アプリケーションを切り替える(どちらでもかまいません)か、アプリケーションを終了するたびに、およびアクティビティが破棄されるたびに出力されることに気付きました。

2つのNexus 5で同じアプリを実行しようとしました-1つはLollipopともう1つのMarshmallowを実行し、これらのログプリントは、作成中のアプリだけでなく、すべてのアプリでMarshmallowバージョンにのみ表示されました。

なぜこれが起こるのか分かりませんが、レポートを開きました here

55
Itai Hanski

BackgrounTaskが終了する前にコンテキストを終了し、渡したコンテキストが存在しないと思います。
あなたが試すことができます:

  • AppContextを使用:new BackgroundTask(Register.this .getApplicationContext());

  • または、BackgroundTaskの終了を待つ:.execute(...)の後にfinish()を削除し、finish()を追加しますonPostExecute

3
Mario

特定の問題の解決策はありません。しかし、私は同様の問題を抱えていました。このような問題を抱えている人は、以下のコードを持っていることを確認してください。

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.<YOUR_XML_FILE_NAME>);

インテリジェンスを使用すると、以下のコードを選択できます。

@Override
public void onCreate(Bundle savedInstanceState, PersistableBundle persistentState) {
    super.onCreate(savedInstanceState, persistentState);
    setContentView(R.layout.<YOUR_XML_FILE_NAME>);
}

これは私のために働いた

PersistentStateの詳細

ハッピーコーディング:)

3
Gaurav Karia

Android OSを6.0.1に更新します。

これは未解決の問題でした こちら 。この問題は、最近公開されたAndroid 6.0.1で修正されています。

2
Nouman Rasheed

それは非常に奇妙ですが、私の場合、追加せずに連絡先をロードしようとしたときにこのエラーが発生しました

<uses-permission Android:name="Android.permission.READ_CONTACTS" />

マニフェストに。そして、私がやっただけで消えました。

だから、それはマシュマロの新しい許可を持つものかもしれないと思う。

Android 6.0およびbuild.gradleのtargetSdkVersion 23を使用してNexus 5でテスト済み

1
polis

そのAndroidが許可リクエストを変更したため(Android.permission.READ_PHONE_STATEまたはAndroid.permission.READ_CONTACTSなどの許可)、これらの許可を求めるときランタイムおよび許可タグを追加しないでください(<uses-permission Android:name = "..." />manifest、エラーが発生します。

したがって、古いバージョンのようなタグ権限を使用し、新しいバージョンでは実行時にリクエスト権限を追加します。

1