Android.OS.NetworkOnMainThreadException 在
Android.OS.NetworkOnMainThreadException in
我正在尝试获取用户的 facebook 个人资料图片及其缩略图,并在下载后将其添加到解析中 class。看看
@Override
protected String doInBackground(String[] Params)
{
String accessToken = AccessToken ;
String email = EMAIL;
profile = com.facebook.Profile.getCurrentProfile();
User.put("displayName", profile.getName());
User.put("facebookId", profile.getId());
User.setUsername(profile.getId());
try
{
User.put("FBaccessToken", accessToken);
User.setEmail(email);
}
catch (Exception e){
Log.e("ERROR","Failed");
}
User.setPassword(profile.getId() + profile.getId());
ParseQuery<ParseObject> query = ParseQuery.getQuery("User");
query.whereEqualTo("username", profile.getId());
query.findInBackground(new FindCallback<ParseObject>() {
@Override
public void done(List<ParseObject> list, ParseException e)
{
if (e == null)
{
//brace the lord no error
if (list == null)
{
parseSignUp() ;
}
else
{
if (list.isEmpty())
{
parseSignUp() ;
}
else
{
login(profile.getId(), (profile.getId() + profile.getId()));
}
for (ParseObject str : list)
{
Log.e("ERROR", "what ?");
}
}
}
else
{
Log.e("ERROR", "not");
}
}
});
return "done";
}
Login.java
SendFeedBackJob newJob = new SendFeedBackJob();
newJob.progressBar = progressBar ;
newJob.EMAIL = email ;
newJob.AccessToken = accessToken.getToken();
newJob.invisible = View.INVISIBLE ;
newJob.show = View.VISIBLE ;
newJob.execute();
即使 AsyncTask 中有网络内容,这段代码仍然会抛出此错误
12-04 19:02:27.773 4263-4263/com.socketmill.thisismohit.vine E/ERROR﹕android.os.NetworkOnMainThreadException
12-04 19:02:27.803 4263-4263/com.socketmill.thisismohit.vine E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.NullPointerException
at com.parse.ParseFile.<init>(ParseFile.java:188)
at com.parse.ParseFile.<init>(ParseFile.java:218)
at com.socketmill.thisismohit.vine.SendFeedBackJob.parseSignUp(SendFeedBackJob.java:207)
at com.socketmill.thisismohit.vine.SendFeedBackJob.done(SendFeedBackJob.java:90)
at com.socketmill.thisismohit.vine.SendFeedBackJob.done(SendFeedBackJob.java:75)
at com.parse.ParseTaskUtils.run(ParseTaskUtils.java:115)
at android.os.Handler.handleCallback(Handler.java:615)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4921)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1038)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:805)
at dalvik.system.NativeStart.main(Native Method)
仅仅因为它在 doInBackground 中开始,并不意味着里面的整个代码 运行 都在后台线程中。也许您正在使用的库正在使用 UI 线程发送回调。
读取documentation,query.findInBackground(new FindCallback<ParseObject>() {})
方法将运行UI线程上的public void done(List<ParseObject> list, ParseException e)
方法.
这意味着您的 parseSignUp()
方法以及您的 geByteArrayFromURL
方法也在 UI 线程上 运行ning。
事实上,考虑到 Parse 库会为您处理这一切。您可能应该从 AsyncTask 中完全删除 Parse Library。由于它将在库完成执行之前转到 onPostExecute()
(您在 doInBackground
.
中启动一个新线程
FindInBackground 的 done 回调方法在 UI 线程上运行,而不是在异步线程上运行
我正在尝试获取用户的 facebook 个人资料图片及其缩略图,并在下载后将其添加到解析中 class。看看
@Override
protected String doInBackground(String[] Params)
{
String accessToken = AccessToken ;
String email = EMAIL;
profile = com.facebook.Profile.getCurrentProfile();
User.put("displayName", profile.getName());
User.put("facebookId", profile.getId());
User.setUsername(profile.getId());
try
{
User.put("FBaccessToken", accessToken);
User.setEmail(email);
}
catch (Exception e){
Log.e("ERROR","Failed");
}
User.setPassword(profile.getId() + profile.getId());
ParseQuery<ParseObject> query = ParseQuery.getQuery("User");
query.whereEqualTo("username", profile.getId());
query.findInBackground(new FindCallback<ParseObject>() {
@Override
public void done(List<ParseObject> list, ParseException e)
{
if (e == null)
{
//brace the lord no error
if (list == null)
{
parseSignUp() ;
}
else
{
if (list.isEmpty())
{
parseSignUp() ;
}
else
{
login(profile.getId(), (profile.getId() + profile.getId()));
}
for (ParseObject str : list)
{
Log.e("ERROR", "what ?");
}
}
}
else
{
Log.e("ERROR", "not");
}
}
});
return "done";
}
Login.java
SendFeedBackJob newJob = new SendFeedBackJob();
newJob.progressBar = progressBar ;
newJob.EMAIL = email ;
newJob.AccessToken = accessToken.getToken();
newJob.invisible = View.INVISIBLE ;
newJob.show = View.VISIBLE ;
newJob.execute();
即使 AsyncTask 中有网络内容,这段代码仍然会抛出此错误
12-04 19:02:27.773 4263-4263/com.socketmill.thisismohit.vine E/ERROR﹕android.os.NetworkOnMainThreadException
12-04 19:02:27.803 4263-4263/com.socketmill.thisismohit.vine E/AndroidRuntime﹕ FATAL EXCEPTION: main
java.lang.NullPointerException
at com.parse.ParseFile.<init>(ParseFile.java:188)
at com.parse.ParseFile.<init>(ParseFile.java:218)
at com.socketmill.thisismohit.vine.SendFeedBackJob.parseSignUp(SendFeedBackJob.java:207)
at com.socketmill.thisismohit.vine.SendFeedBackJob.done(SendFeedBackJob.java:90)
at com.socketmill.thisismohit.vine.SendFeedBackJob.done(SendFeedBackJob.java:75)
at com.parse.ParseTaskUtils.run(ParseTaskUtils.java:115)
at android.os.Handler.handleCallback(Handler.java:615)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4921)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1038)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:805)
at dalvik.system.NativeStart.main(Native Method)
仅仅因为它在 doInBackground 中开始,并不意味着里面的整个代码 运行 都在后台线程中。也许您正在使用的库正在使用 UI 线程发送回调。
读取documentation,query.findInBackground(new FindCallback<ParseObject>() {})
方法将运行UI线程上的public void done(List<ParseObject> list, ParseException e)
方法.
这意味着您的 parseSignUp()
方法以及您的 geByteArrayFromURL
方法也在 UI 线程上 运行ning。
事实上,考虑到 Parse 库会为您处理这一切。您可能应该从 AsyncTask 中完全删除 Parse Library。由于它将在库完成执行之前转到 onPostExecute()
(您在 doInBackground
.
FindInBackground 的 done 回调方法在 UI 线程上运行,而不是在异步线程上运行