我想进行简单的登录并注册应用,以便用户可以创建一个帐户。 (姓名,用户名,密码) 我使用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>";
}
?>
答案 0 :(得分:55)
这是Android中的一个错误,已在Marshmallow的更高版本中修复
我认为这是特定的棉花糖。您使用的是Marshmallow设备吗?
我注意到每次在应用程序之间切换(无关紧要)或退出它们以及活动被销毁时都会打印出这个错误。
我尝试在两个Nexus 5上运行相同的应用程序 - 一个运行Lollipop和另一个Marshmallow,这些日志打印仅出现在Marshmallow版本上 - 每个应用程序,而不仅仅是我正在构建的应用程序。
不确定为什么会这样,但我打开了一份报告here。
答案 1 :(得分:3)
我认为你在backgrounTask完成之前完成了上下文,你传递的上下文不再存在 你可以尝试:
使用appContext:new BackgroundTask(Register.this。 getApplicationContext());
或者,等待BackgroundTask完成:在.execute(...)之后删除finish()并添加finish() onPostExecute
答案 2 :(得分:3)
我没有具体问题的解决方案。但我有类似的问题。 任何遇到此类问题的人请确保您拥有以下代码。
@Override
public void onCreate(Bundle savedInstanceState, PersistableBundle persistentState) {
super.onCreate(savedInstanceState, persistentState);
setContentView(R.layout.<YOUR_XML_FILE_NAME>);
}
通过使用情报,您可能选择以下代码:
{{1}}
这对我有用
For more info on PersistentState
快乐编码:)
答案 3 :(得分:2)
将您的Android操作系统更新为6.0.1。
这是一个未解决的问题here。该问题已在最近公开发布的Android 6.0.1中修复。
答案 4 :(得分:1)
这很奇怪,但在我的情况下,我尝试在不添加
的情况下加载联系人时出现此错误 <uses-permission android:name="android.permission.READ_CONTACTS" />
进入清单。它消失了,只是我已经完成了。
所以我的猜测可能是在Marshmallow中拥有新权限的东西。
使用Android 6.0在我的Nexus 5上测试,在build.gradle中使用targetSdkVersion 23进行测试
答案 5 :(得分:1)
因为android改变了权限请求(某些权限,如 android.permission.READ_PHONE_STATE 或 android.permission.READ_CONTACTS ),所以当你在运行时请求这些权限时,不要在清单中添加权限标记( &lt; uses-permission android:name =&#34; ...&#34; /&gt; ),你会得到错误。
因此,只需使用旧版本的标记权限,并在较新版本的运行时添加请求权限。