我是Andriod编程的初学者,我使用android Studio,但我在线看到了一个使用eclipse的Http教程,我在Android工作室中解释得最好,该应用程序有一个HttpManager类,它返回如下所示的json数据
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
public class HttpManager {
public static String getData(String uri) throws IOException {
StringBuilder sb=new StringBuilder();
BufferedReader reader= null;
try {
URL url = new URL(uri);
HttpURLConnection con= (HttpURLConnection) url.openConnection();
reader= new BufferedReader(new InputStreamReader(con.getInputStream()));
String line;
while ((line=reader.readLine()) !=null) {
sb.append(line+ "\n");
}
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
return null;
}
finally {
if(reader != null){
reader.close();
}
}
return sb.toString();
}
}
主要活动特别是doInbackground方法应该获取此json数据并显示它,但应用程序在下面的onPrexecute方法代码之后崩溃
import android.net.ConnectivityManager;
import android.net.NetworkInfo;
import android.os.AsyncTask;
import android.support.v4.os.AsyncTaskCompat;
import android.support.v4.widget.TextViewCompat;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.text.method.ScrollingMovementMethod;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.ProgressBar;
import android.widget.TextView;
import android.widget.Toast;
import java.io.IOException;
import java.security.Policy;
import java.util.Objects;
public class MainActivity extends AppCompatActivity {
TextView output;
ProgressBar pb;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
output=(TextView) findViewById(R.id.textView);
output.setMovementMethod(new ScrollingMovementMethod());
pb= (ProgressBar) findViewById(R.id.progressBar);
pb.setVisibility(View.INVISIBLE);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
int id = item.getItemId();
//noinspection SimplifiableIfStatement
if (id == R.id.action_settings) {
if (isOnline()){
requestData("http://localhost/database/getInfodroid.php");
}
else {
Toast.makeText(this,"Network Unavailable",Toast.LENGTH_LONG).show();
}
return true;
}
return super.onOptionsItemSelected(item);
}
private void requestData(String uri) {
MyTask task = new MyTask();
task.execute(uri);
}
protected void updateDisplay(String message){
output.append(message +"\n");
}
protected boolean isOnline(){
ConnectivityManager cm= (ConnectivityManager) getSystemService(CONNECTIVITY_SERVICE);
NetworkInfo netinfo= cm.getActiveNetworkInfo();
if(netinfo!= null && netinfo.isConnectedOrConnecting()){
return true;
}
else {
return false;
}
}
private class MyTask extends AsyncTask {
@Override
protected void onPreExecute() {
updateDisplay("Background Task Started");
pb.setVisibility(View.VISIBLE);
}
@Override
protected Object doInBackground(Object[] objects) {
try {
String content =HttpManager.getData(objects[0].toString());
return content;
} catch (IOException e) {
e.printStackTrace();
}
return "Task Complete";
}
@Override
protected void onPostExecute(Object o) {
updateDisplay(o.toString());
pb.setVisibility(View.INVISIBLE);
}
@Override
protected void onProgressUpdate(Object[] values) {
updateDisplay(values[0].toString());
}
}
}
我再次重复我是新手,我在Android Studio中最好地解释它在eclipse中略有不同,av设置所有权限
从localhost更改为IP地址应用程序doesent崩溃但我现在得到以下异常 logcat的:
10-03 14:13:21.876 2126-9411/? W/System.err: java.net.ConnectException: failed to connect to localhost/127.0.0.1 (port 80): connect failed: ECONNREFUSED (Connection refused)
10-03 14:13:21.877 2126-9411/? W/System.err: at libcore.io.IoBridge.connect(IoBridge.java:124)
10-03 14:13:21.877 2126-9411/? W/System.err: at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:183)
10-03 14:13:21.877 2126-9411/? W/System.err: at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:452)
10-03 14:13:21.877 2126-9411/? W/System.err: at java.net.Socket.connect(Socket.java:884)
10-03 14:13:21.877 2126-9411/? W/System.err: at com.android.okhttp.internal.Platform.connectSocket(Platform.java:117)
10-03 14:13:21.877 2126-9411/? W/System.err: at com.android.okhttp.internal.http.SocketConnector.connectRawSocket(SocketConnector.java:160)
10-03 14:13:21.877 2126-9411/? W/System.err: at com.android.okhttp.internal.http.SocketConnector.connectCleartext(SocketConnector.java:67)
10-03 14:13:21.877 2126-9411/? W/System.err: at com.android.okhttp.Connection.connect(Connection.java:152)
10-03 14:13:21.877 2126-9411/? W/System.err: at com.android.okhttp.Connection.connectAndSetOwner(Connection.java:185)
10-03 14:13:21.877 2126-9411/? W/System.err: at com.android.okhttp.OkHttpClient$1.connectAndSetOwner(OkHttpClient.java:128)
10-03 14:13:21.877 2126-9411/? W/System.err: at com.android.okhttp.internal.http.HttpEngine.nextConnection(HttpEngine.java:341)
10-03 14:13:21.877 2126-9411/? W/System.err: at com.android.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:330)
10-03 14:13:21.878 2126-9411/? W/System.err: at com.android.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:248)
10-03 14:13:21.878 2126-9411/? W/System.err: at com.android.okhttp.internal.huc.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java:433)
10-03 14:13:21.878 2126-9411/? W/System.err: at com.android.okhttp.internal.huc.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:384)
10-03 14:13:21.878 2126-9411/? W/System.err: at com.android.okhttp.internal.huc.HttpURLConnectionImpl.getInputStream(HttpURLConnectionImpl.java:231)
10-03 14:13:21.878 2126-9411/? W/System.err: at hilz.myapplication.HttpManager.getData(HttpManager.java:22)
10-03 14:13:21.878 2126-9411/? W/System.err: at hilz.myapplication.MainActivity$MyTask.doInBackground(MainActivity.java:118)
10-03 14:13:21.884 2126-9411/? W/System.err: at android.os.AsyncTask$2.call(AsyncTask.java:295)
10-03 14:13:21.884 2126-9411/? W/System.err: at java.util.concurrent.FutureTask.run(FutureTask.java:237)
10-03 14:13:21.901 2126-9411/? W/System.err: at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:234)
10-03 14:13:21.901 2126-9411/? W/System.err: at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
10-03 14:13:21.901 2126-9411/? W/System.err: at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
10-03 14:13:21.902 2126-9411/? W/System.err: at java.lang.Thread.run(Thread.java:818)
10-03 14:13:21.902 2126-9411/? W/System.err: Caused by: android.system.ErrnoException: connect failed: ECONNREFUSED (Connection refused)
10-03 14:13:21.902 2126-9411/? W/System.err: at libcore.io.Posix.connect(Native Method)
10-03 14:13:21.906 2126-9411/? W/System.err: at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:111)
10-03 14:13:21.906 2126-9411/? W/System.err: at libcore.io.IoBridge.connectErrno(IoBridge.java:137)
10-03 14:13:21.908 2126-9411/? W/System.err: at libcore.io.IoBridge.connect(IoBridge.java:122)
10-03 14:13:21.908 2126-9411/? W/System.err: ... 23 more
答案 0 :(得分:0)
在onPostExecute中收到的对象为null,播放调用updateDisplay(...)它正在抛出一个NPE。
我建议您将“content”保存为属性,并在postExecute方法中检索该值。
我建议你一次小心尝试更新不在主线程中的用户界面(postexecute是在后台任务之后)。
看看:
private class MyTask extends AsyncTask {
private Activity activity;
private String content;
public MyTask(Activity activity){this.activity = activity;}
@Override
protected void onPreExecute() {
updateDisplay("Background Task Started");
pb.setVisibility(View.VISIBLE);
}
@Override
protected Object doInBackground(Object[] objects) {
try {
content =HttpManager.getData(objects[0].toString());
return content;
} catch (IOException e) {
e.printStackTrace();
}
return "Task Complete";
}
@Override
protected void onPostExecute(Object o) {
activity.runOnUiThread(new Runnable() {
@Override
public void run() {
updateDisplay(content);
pb.setVisibility(View.INVISIBLE);
}
});
}
@Override
protected void onProgressUpdate(Object[] values) {
activity.runOnUiThread(new Runnable() {
@Override
public void run() {
updateDisplay(values[0].toString());
}
});
}
}
我希望这会对你有所帮助。
答案 1 :(得分:0)
在stackoverflow上找到我正在寻找的东西,显然我应该使用10.0.2.2,而不是在我的网址代码中使用localhost
答案 2 :(得分:0)
10.0.2.2是模拟器的本地主机,这意味着如果您的PC上有一个运行模拟器的测试服务器。如果不是这样,它将无法解决您的问题。如果您非常确定它是IP,我只会探索您的网络选项并获取您的PC的IP。使IP服务器的IP也允许您从设备进行USB测试,而不仅仅是模拟器。
查看代码,如果要将数据从应用程序发送到服务器,我看不到声明的方法(POST / GET)。您发送的URL也没有参数,因此除非特定页面已经编码了您要返回的对象,否则您将收到另一个错误。
以下是我用来连接服务器的示例脚本
public class CCJson {
// left blank to aviod calls to this constructor
public CCJson(){}
// place your IP in place of the ip
public static String url = "http://102.0.0.1/appActions.php";
public static JSONObject performPostCallObj( String params) throws MalformedURLException {
URL defURL = new URL(url);
JSONObject response=null;
try {
HttpURLConnection conn = (HttpURLConnection) defURL.openConnection();
conn.setRequestMethod("POST");
conn.setDoOutput(true);
OutputStreamWriter wr = new OutputStreamWriter( conn.getOutputStream());
wr.write(params);
wr.flush();
wr.close();
String line;
StringBuilder sb= new StringBuilder();
BufferedReader br = new BufferedReader(new InputStreamReader(conn.getInputStream(), "UTF-8"));
while ((line=br.readLine()) != null) {
sb.append(line);
response =new JSONObject(sb.toString());
}
br.close();
} catch (Exception e) {
e.printStackTrace();
}
return response;
}
我从AsyncTask调用此代码并返回JSONObject