Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/230.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
android php mysql错误_Php_Android_Mysql - Fatal编程技术网

android php mysql错误

android php mysql错误,php,android,mysql,Php,Android,Mysql,我是一名php开发人员 现在我正在学习安卓 我想连接php和android 我尝试了许多来自互联网的示例代码 所有人都面临同样的问题 不幸的是,主要活动已经停止,这就是问题所在 举个例子:当我提交登录表单时,出现了错误消息 一切都很好,但没有连接到php 我快发疯了 WAMP服务器中需要额外的设置吗 如果你有时间,请教我在eclipse中一步一步地编写android。 就像文件->新建->安卓应用程序项目…….那样的教学水平 请教我一个简单的android php mysql登录页面 下面添加了

我是一名php开发人员

现在我正在学习安卓

我想连接php和android

我尝试了许多来自互联网的示例代码

所有人都面临同样的问题

不幸的是,主要活动已经停止,这就是问题所在

举个例子:当我提交登录表单时,出现了错误消息

一切都很好,但没有连接到php

我快发疯了

WAMP服务器中需要额外的设置吗

如果你有时间,请教我在eclipse中一步一步地编写android。 就像文件->新建->安卓应用程序项目…….那样的教学水平

请教我一个简单的android php mysql登录页面

下面添加了一个示例代码,请告诉我问题:

 package com.example.listactivity;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.List;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import android.app.ListActivity;
import android.net.ParseException;
import android.os.Bundle;
import android.util.Log;
import android.widget.Toast;

public class MainActivity extends ListActivity {
private List nameValuePairs;
private JSONArray jArray;
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    String result = null;
    InputStream is = null;
    StringBuilder sb=null;


    //http post
    try{
        HttpClient httpclient = new DefaultHttpClient();
        HttpPost httppost = new HttpPost("http://localhost/food/food.php");
        httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
        HttpResponse response = httpclient.execute(httppost);
        HttpEntity entity = response.getEntity();
        is = entity.getContent();
    }catch(Exception e){
        Log.e("log_tag", "Error in http connection"+e.toString());
    }

    //convert response to string
    try{
        BufferedReader reader = new BufferedReader(new InputStreamReader(is,"iso-8859-1"),8);
        sb = new StringBuilder();
        sb.append(reader.readLine() + "\n");
        String line="0";

        while ((line = reader.readLine()) != null) {
            sb.append(line + "\n");
        }

        is.close();
        result=sb.toString();

    }catch(Exception e){
        Log.e("log_tag", "Error converting result "+e.toString());
    }

    //paring data
    int fd_id;
    String fd_name;
    try{
    jArray = new JSONArray(result);
    JSONObject json_data=null;

    for(int i=0;i<jArray.length();i++){
            json_data = jArray.getJSONObject(i);
            fd_id=json_data.getInt("FOOD_ID");
            fd_name=json_data.getString("FOOD_NAME");
    }

    }catch(JSONException e1){
        Toast.makeText(getBaseContext(), "No Food Found", Toast.LENGTH_LONG).show();
    }catch (ParseException e1){
        e1.printStackTrace();
    }
}
}
Php代码:

<?php
  mysql_connect("localhost","root","");
  mysql_select_db("FOOD");
  $sql=mysql_query("select * from FOOD");
  while($row=mysql_fetch_assoc($sql)) $output[]=$row;
  print(json_encode($output));
  mysql_close();
?>

查看您的帮助。

您需要使用10.0.2.2来引用php localhost

看看这个api->

这是您的源代码,基本上需要claenup,主要问题是NetworkONMainThread


首先,StackOverflow不是让用户教你东西的地方。它是一个获得帮助的地方,可以帮助您解决现有代码已经面临的问题

关于你的问题,互联网上有很多关于将PHP/MySQL连接到Android的优秀教程。Android Hive是一个写得很好的版本。它涵盖了从安装WAMP到编写全功能Android应用程序的所有内容。我建议你读一下,因为它和你想要的完全一样

离题建议:如果你真的想学习开发Android应用程序,你应该从阅读一本书或观看在线教程(如Lynda)开始。理解生命周期、线程、调试等基本概念非常重要。。。在进入更高层次之前,因为它将帮助你理解和解决你可能面临的问题


祝你好运。

你的本地文件在浏览器上运行吗?你必须在模拟器上使用IP地址10.0.2.2作为本地主机,如果使用电话,则使用计算机的IP地址-无论哪种方式,你都可以使用隧道传输本地主机以使其处于活动状态。重要的是,您应该将网络i/o放在后台线程上,或者使用AsyncTask。首先使用IP而不是localhost 10.0.2.2。其次,在后台而不是主线程中编写代码。这样可以工作:是的,adcom,它在浏览器中运行良好。hi Imran,我如何在backgound中使用代码?hi adcom,我使用了10.0.22、127.0.0和我的系统ip。两者都有相同的问题10.0.2.2我使用了10.0.22