我有一个IntentService,它可以执行网络操作(HTTP POST),但是它显示了NetworkOnMainThreadException。如果我是对的,那么IntentService将在单独的线程上运行。谁能说出为什么会抛出该异常?我的代码是:
public class UpdateService extends IntentService {
public static final int UPDATE_PROGRESS = 8344;
BroadcastReceiver broadcastReceiver;
public UpdateService() {
super("UpdateService");
}
@Override
protected void onHandleIntent(Intent intent) {
if (broadcastReceiver == null) {
broadcastReceiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
Bundle extras = intent.getExtras();
NetworkInfo info = (NetworkInfo) extras.getParcelable("networkInfo");
State state = info.getState();
if (state == State.CONNECTED) {
onNetworkUp();
} else {
}
}
};
final IntentFilter intentFilter = new IntentFilter();
intentFilter.addAction(ConnectivityManager.CONNECTIVITY_ACTION);
registerReceiver(broadcastReceiver, intentFilter);
}
}
@Override
public void onDestroy(){
unregisterReceiver(broadcastReceiver);
}
void onNetworkUp(){
String aDataRow = "";
try {
File myFile = new File( Environment.getExternalStorageDirectory().getPath() + "/myFile.txt");
FileReader fr = new FileReader(myFile);
BufferedReader myReader = new BufferedReader(fr);
while ((aDataRow = myReader.readLine()) != null)
updateLyne(aDataRow); //
fr.close();
} catch (Exception e) {
Log.e("onNetworkUp",e.toString());
}
void updateLyne(String aDataRow){
JSONParser jsonParser = new JSONParser();
String[] words = aDataRow.split(" ");
pid = words[1];
String rtime = aDataRow;
List<NameValuePair> params = new ArrayList<NameValuePair>();
params.add(new BasicNameValuePair(TAG_PID, pid));
params.add(new BasicNameValuePair(TAG_TIME, rtime));
JSONObject json = null;
if (words[0].equalsIgnoreCase("cancel")){
json = jsonParser.makeHttpRequest(url_cancel, "POST", params);
}
else{
Log.d("empty","file empty!!");
}
try {
int success = json.getInt("success");
if (success == 1) {
delLine(aDataRow); // delete the line
} else {
Log.d("pid="+pid+" not on board", "failed in deleting");
}
} catch (JSONException e) {
e.printStackTrace();
}
}
}
JSONParser.java如下
public class JSONParser {
static InputStream is = null;
static JSONObject jObj = null;
static String json = "";
// constructor
public JSONParser() {
}
// function get json from url
public JSONObject makeHttpRequest(String url, String method,
List<NameValuePair> params) {
// Making HTTP request
try {
// check for request method
if(method == "POST"){
DefaultHttpClient httpClient = new DefaultHttpClient();
HttpPost httpPost = new HttpPost(url);
httpPost.setEntity(new UrlEncodedFormEntity(params));
HttpResponse httpResponse = httpClient.execute(httpPost);
HttpEntity httpEntity = httpResponse.getEntity();
is = httpEntity.getContent();
}
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
} catch (ClientProtocolException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
try {
BufferedReader reader = new BufferedReader(new InputStreamReader(
is, "iso-8859-1"), 8);
StringBuilder sb = new StringBuilder();
String line = null;
while ((line = reader.readLine()) != null) {
sb.append(line + "\n");
}
is.close();
json = sb.toString();
} catch (Exception e) {
Log.e("Buffer Error", "Error converting result " + e.toString());
}
// try parse the string to a JSON object
try {
jObj = new JSONObject(json);
} catch (JSONException e) {
Log.e("JSON Parser", "Error parsing data " + e.toString());
}
// return JSON String
return jObj;
}
}
最佳答案
问题是您没有在onHandleIntent()
中运行网络请求,而只是在创建BroadcastReceiver
实例并进行注册。实际的网络请求不会在此处运行。它会在BroadcastReceiver
收到消息时运行,该消息发生在UI线程上。正确的方案是在其他地方创建您的BroadcastReceiver
,并在收到消息后启动IntentService
,该onHandleIntent()
在内部执行网络调用-实际上,它将在工作线程上运行。希望这可以帮助。
关于android - IntetentService中的NetworkOnMainThreadException,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/14935317/