我想使用AsnycTask将图片上传到Parse服务器上。当我上传图片而不使用AsyncTask时,我成功上传并可以检索图片。我想使用AsyncTask,因为在我的应用程序中有两个活动正在使用网络权限,或者如果有人有另一个解决方案来执行此操作,请告诉。该活动的代码:使用AsynTask上传图片不成功
package com.example.faceb;
import java.io.ByteArrayOutputStream;
import java.io.File;
import com.parse.GetDataCallback;
import com.parse.ParseException;
import com.parse.ParseFile;
import com.parse.ParseObject;
import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.os.AsyncTask;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
public class ListActivity extends Activity {
ImageView image;
TextView value;
public Bitmap bm;
public byte[] bitmapdata;
public ByteArrayOutputStream data;
String s = "FileName";
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_list);
uploadTask task = new uploadTask();
task.execute(s);
}
private class uploadTask extends AsyncTask<String, Void, String>{
@Override
protected void onPostExecute(String result) {
image.setImageBitmap(bm);
}
@Override
protected String doInBackground(String... params) {
upload();
return null;
}
}
public void upload(){
bm = BitmapFactory.decodeResource(getResources(), R.drawable.back);
data = new ByteArrayOutputStream();
bm.compress(Bitmap.CompressFormat.JPEG, 40, data);
bitmapdata = data.toByteArray();
ParseFile file = new ParseFile("hai.png", bitmapdata);
file.saveInBackground();
ParseObject testObject = new ParseObject("TestObject");
testObject.put("puu", file);
testObject.saveInBackground();
}
}
以下是我的错误的logcat
一月10日至12日:10:46.944:E/ActivityThread(2233):无法找到com.facebook.katana供应商信息(2233):致命例外:main 10-12 01:11:07.604:E/AndroidRuntime(2233):java.lang.NullPointerException 10 - 01:11:07.604:E/AndroidRuntime 12 01:11:07.604:E/AndroidRuntime(2233):at com.example.faceb.ListActivity $ uploadTask.onPostExecute(ListActivity.java:44) 10-12 01:11:07.604:E/AndroidRun time(2233):at com.example.faceb.ListActivity $ uploadTask.onPostExecute(ListActivity.java:1) 10-12 01:11:07.604:E/AndroidRuntime(2233):at android.os.AsyncTask.finish( AsyncTask.java:417) 10-12 01:11:07.604:E/AndroidRuntime(2233):at android.os.AsyncTask.access $ 300(AsyncTask.java:127) 10-12 01:11:07.604:E/AndroidRuntime(2233):at android.os.AsyncTask $ InternalHandler.handleMessage(AsyncTask.java:429) 10-12 01:11:07.604:E/AndroidRuntime(2233):at android.os.Handler.dispatchMessage(Handler .java:99) 10-12 01:11:07.604:E/AndroidRuntime(2233):at android.os.Looper.loop(Looper.java:123) 10-12 01:11:07.604:E/AndroidRuntime (2233):at android.app.ActivityThread.main(ActivityThread.java:4627) 10-12 01:11:07.604:E/AndroidRuntime(2233):at java.lang.reflect.Method.i nvokeNative(Native Method) 10-12 01:11:07.604:E/AndroidRuntime(2233):at java.lang.reflect.Method.invoke(Method.java:521) 10-12 01:11:07.604:E/AndroidRuntime(2233):at com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:868) 10-12 01:11:07.604:E/AndroidRuntime(2233):at com.android.internal .os.ZygoteInit.main(ZygoteInit.java:626) 10-12 01:11:07.604:E/AndroidRuntime(2233):at dalvik.system.NativeStart.main(Native Method) 10-12 01:11: 09.014:E/ActivityThread(2274):无法找到com.facebook.katana.provider.AttributionIdProvider的提供者信息 10-12 01:48:14.084:E/ActivityThread(2313):无法找到com.facebook的提供者信息.katana.provider.AttributionIdProvider 10-12 01:48:45.323:E/ActivityThread(2334):无法找到提供呃info for com.facebook.katana.provider.AttributionIdProvider 10-12 03:19:06.184:E/ActivityThread(2371):无法找到com.facebook.katana.provider.AttributionIdProvider的提供者信息 10-12 03: 19:31.614:E/ActivityThread(2393):无法找到提供信息的com.facebook.katana.provider.AttributionIdProvider
发布您的堆栈跟踪。也发布saveInBackground。 – AedonEtLIRA
堆栈跟踪意味着logcat? saveInBackground是解析服务器提供的方法。它的内置方法不是由我创建的。另外当我开始这个活动时,我回到了之前的活动。这样做没有asynctask在一个单独的项目中一切正常。 –
我对facebook apis一无所知,但看起来你的问题来自于此。特别是无法找到apis工作所需的任何提供者。尝试验证您的库链接并刷新(清理)您的项目。 – AedonEtLIRA