Получение ошибки в Android ICS при создании Vcard
Хорошо работает в Android 2.1
Код
String vfile ="POContactsRestore.vcf";
String VCard = null;
File vfile = new File("/sdcard/POContactsRestore.vcf");
if(vfile.exists()){
vfile.delete();
}
FileOutputStream mFileOutputStream = null;
Cursor phones = getContentResolver().query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI, null,null, null, null);
phones.moveToFirst();
for(int i =0;i<phones.getCount();i++)
{
String lookupKey = phones.getString(phones.getColumnIndex(ContactsContract.Contacts.LOOKUP_KEY));
Uri uri = Uri.withAppendedPath(ContactsContract.Contacts.CONTENT_VCARD_URI, lookupKey);
AssetFileDescriptor fd;
try
{
fd = getContentResolver().openAssetFileDescriptor(uri, "r");
FileInputStream fis = fd.createInputStream();
byte[] buf = new byte[(int) fd.getDeclaredLength()];
fis.read(buf);
VCard = new String(buf);
String path = Environment.getExternalStorageDirectory().toString() + File.separator + vfile;
mFileOutputStream = new FileOutputStream(path, false);
phones.moveToNext();
Log.d("Vcard", VCard);
}
catch (Exception e1)
{
// TODO Auto-generated catch block
e1.printStackTrace();
}
}
try {
mFileOutputStream.write(VCard.toString().getBytes());
mFileOutputStream.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
ошибка logcat
02-14 06:03:26.724: E/AndroidRuntime(862): java.lang.NullPointerException
02-14 06:03:26.724: E/AndroidRuntime(862): at com.example.com.example.contactbackup.Contact$1.onClick(Contact.java:148)
02-14 06:55:38.183: E/AndroidRuntime(1066): FATAL EXCEPTION: main
02-14 06:55:38.183: E/AndroidRuntime(1066): java.lang.NullPointerException
02-14 06:55:38.183: E/AndroidRuntime(1066): at com.example.com.anthem.contactbackup.Contact$1.onClick(Contact.java:101)
02-14 06:55:38.183: E/AndroidRuntime(1066): at android.view.View.performClick(View.java:4084)
02-14 06:55:38.183: E/AndroidRuntime(1066): at android.view.View$PerformClick.run(View.java:16966)
02-14 06:55:38.183: E/AndroidRuntime(1066): at android.os.Handler.handleCallback(Handler.java:615)
02-14 06:55:38.183: E/AndroidRuntime(1066): at android.os.Handler.dispatchMessage(Handler.java:92)
02-14 06:55:38.183: E/AndroidRuntime(1066): at android.os.Looper.loop(Looper.java:137)
02-14 06:55:38.183: E/AndroidRuntime(1066): at android.app.ActivityThread.main(ActivityThread.java:4745)
02-14 06:55:38.183: E/AndroidRuntime(1066): at java.lang.reflect.Method.invokeNative(Native Method)
02-14 06:55:38.183: E/AndroidRuntime(1066): at java.lang.reflect.Method.invoke(Method.java:511)
02-14 06:55:38.183: E/AndroidRuntime(1066): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
02-14 06:55:38.183: E/AndroidRuntime(1066): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
02-14 06:55:38.183: E/AndroidRuntime(1066): at dalvik.system.NativeStart.main(Native Method)
1 ответ
Решение
Попробуйте это, проблема в FileInputStream fis = fd.createInputStream();
package com.example.temp;
import java.io.File;
import java.io.FileDescriptor;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.util.ArrayList;
import android.app.Activity;
import android.content.Context;
import android.content.res.AssetFileDescriptor;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.provider.ContactsContract;
import android.util.Log;
public class MainActivity extends Activity {
Cursor cursor;
ArrayList<String> vCard;
String vfile;
static Context mContext;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mContext = MainActivity.this;
getVCF();
}
public static void getVCF() {
final String vfile = "POContactsRestore.vcf";
Cursor phones = mContext.getContentResolver().query(
ContactsContract.CommonDataKinds.Phone.CONTENT_URI, null, null, null, null);
phones.moveToFirst();
for (int i = 0; i < phones.getCount(); i++) {
String lookupKey = phones.getString(phones.getColumnIndex(ContactsContract.Contacts.LOOKUP_KEY));
Uri uri = Uri.withAppendedPath(ContactsContract.Contacts.CONTENT_VCARD_URI, lookupKey);
AssetFileDescriptor fd;
try {
fd = mContext.getContentResolver().openAssetFileDescriptor(uri, "r");
FileDescriptor fdd = fd.getFileDescriptor();
InputStream in = new FileInputStream(fdd);
//FileInputStream fis = fd.createInputStream();
Log.d("BLA BLA", "Len is :: " + (int) fd.getDeclaredLength());
byte[] buf = new byte[(int) fd.getDeclaredLength()];
in.read(buf);
fd.close();
String VCard = new String(buf);
String path = Environment.getExternalStorageDirectory().toString() + File.separator + vfile;
FileOutputStream mFileOutputStream = new FileOutputStream(path, true);
mFileOutputStream.write(VCard.toString().getBytes());
mFileOutputStream.close();
in.close();
phones.moveToNext();
Log.d("Vcard", VCard);
} catch (Exception e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}
}
}