首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将imageUri保存到数据库中

将imageUri保存到数据库中
EN

Stack Overflow用户
提问于 2016-01-05 02:09:10
回答 1查看 288关注 0票数 0

我想将图像保存到数据库中,但每当我单击“保存”应用程序时,都会崩溃。

有人能帮我弄清楚为什么吗?

保存入口法

代码语言:javascript
复制
protected void onActivityResult(int requestCode, int resultCode, final Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    if (resultCode == Activity.RESULT_OK) {
        switch (requestCode) {
            case REQUEST_CODE:
                if (data != null) {
                    int id = dbHandler.getEntriesCount();
                    long time = System.currentTimeMillis();
                    SimpleDateFormat dayTime = new SimpleDateFormat("dd-MM-yyyy hh:mm:ss");
                    String date = dayTime.format(new Date(time));
                    String title = data.getStringExtra("Title");
                    String passage = data.getStringExtra("Passage");
                    Uri imageUri = Uri.parse(data.getStringExtra("imageUri"));
                    Entry entry = new Entry(id, title, passage, imageUri, date);
                    dbHandler.createEntry(entry);
                    Entry Entry = dbHandler.getEntry(id);
                    entryList.add(Entry);
                    EntryListadapter.notifyDataSetChanged();
                }
                break;

Save.onCLickListner

代码语言:javascript
复制
 final Button SaveBtn = (Button) findViewById(R.id.btnSave);

    SaveBtn.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            Intent data = new Intent();
            data.putExtra("Title", TitleTxt.getText().toString());
            data.putExtra("Passage", WriteTxt.getText().toString());
            data.putExtra("imageUri", imageUri);
            setResult(RESULT_OK, data);
            finish();
            /*imageTest1.setText(imageUri.toString());*/
            Toast.makeText(getApplicationContext(), "Entry Added", Toast.LENGTH_SHORT).show();
        }
    });

错误日志

代码语言:javascript
复制
> 01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime: FATAL EXCEPTION: main

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime: Process: unipersonalinc.mypersonalediary, PID: 9683

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime: java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=100, result=-1, data=Intent { (has extras) }} to activity {unipersonalinc.mypersonalediary/unipersonalinc.mypersonalediary.MainActivity}: java.lang.NullPointerException: uriString

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.app.ActivityThread.deliverResults(ActivityThread.java:3699)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.app.ActivityThread.handleSendResult(ActivityThread.java:3742)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.app.ActivityThread.-wrap16(ActivityThread.java)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1393)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.os.Handler.dispatchMessage(Handler.java:102)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.os.Looper.loop(Looper.java:148)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.app.ActivityThread.main(ActivityThread.java:5417)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at java.lang.reflect.Method.invoke(Native Method)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at 
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:  Caused by: java.lang.NullPointerException: uriString

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.net.Uri$StringUri.<init>(Uri.java:475)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.net.Uri$StringUri.<init>(Uri.java)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.net.Uri.parse(Uri.java:437)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at unipersonalinc.mypersonalediary.MainActivity.onActivityResult(MainActivity.java:84)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.app.Activity.dispatchActivityResult(Activity.java:6428)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.app.ActivityThread.deliverResults(ActivityThread.java:3695)

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.app.ActivityThread.handleSendResult(ActivityThread.java:3742) 

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.app.ActivityThread.-wrap16(ActivityThread.java) 

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1393) 

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.os.Handler.dispatchMessage(Handler.java:102) 

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.os.Looper.loop(Looper.java:148) 

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at android.app.ActivityThread.main(ActivityThread.java:5417) 

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at java.lang.reflect.Method.invoke(Native Method) 

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 

>01-05 02:03:50.689 9683-9683/unipersonalinc.mypersonalediary E/AndroidRuntime:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 
EN

回答 1

Stack Overflow用户

发布于 2016-01-05 03:55:11

尝试找到"uriString“,它一定在MainActivity的某个地方。使用Ctrl+f并尝试跟踪它,可能是它没有初始化。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34603126

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档