Android Room Base64 - PullRequest
       12

Android Room Base64

0 голосов
/ 09 апреля 2019

Я пытаюсь сохранить значение base64 в моей базе данных sqlite, используя Room, и по какой-то причине оно не сохраняется. Ну, я предполагаю, что это не сохранение, потому что, когда я пытаюсь прочитать таблицу со столбцом base64, он возвращает значения для всех других столбцов, кроме столбца base64. Что я делаю не так?

Моя сущность:

@Entity(tableName = "healthCareWorkerInformation",
        foreignKeys = @ForeignKey(
                entity = HealthCareWorker.class,
                parentColumns = {"id"},
                childColumns = {"hcwId"},
                onDelete = ForeignKey.CASCADE),
        indices = @Index(
                value = {"hcwId"}))
public class HealthCareWorkersInformation {
    @PrimaryKey(autoGenerate = true)
    @ColumnInfo(name = "hcwInfoId")
    private long id;
    private long hcwId;
    //@ColumnInfo(typeAffinity = ColumnInfo.BLOB)
    private String base64Image;
    private String updatedAt = new SimpleDateFormat("dd MM yyyy, HH:mm",
            Locale.getDefault()).format(Calendar.getInstance().getTime());

    public HealthCareWorkersInformation() {
    }

    @Ignore
    public HealthCareWorkersInformation(long hcwId) {
        this.hcwId = hcwId;
    }

    public long getId() {
        return id;
    }

    public void setId(long id) {
        this.id = id;
    }

    public long getHcwId() {
        return hcwId;
    }

    public void setHcwId(long hcwId) {
        this.hcwId = hcwId;
    }

    public String getBase64Image() {
        return base64Image;
    }

    public void setBase64Image(String base64Image) {
        this.base64Image = base64Image;
    }

    public String getUpdatedAt() {
        return updatedAt;
    }

    public void setUpdatedAt(String updatedAt) {
        this.updatedAt = updatedAt;
    }
}

Мой DAO:

@Insert
void insertHealthCareWorkerInformation(HealthCareWorkersInformation healthCareWorkersInformation);

@Query("SELECT * FROM HEALTHCAREWORKERINFORMATION")
LiveData<List<HealthCareWorkerInformation>> getHCWInfo();

Пример данных, которые я отправляю через:

{"consentGiven":null,"hcwId":1,"patiendId":1,"name":"Ben","lastName":"Ben","dateOfBirth":"4/9/2019","phoneNumber":"+271234567","base64Image":""}

Все остальное сохраняется, кроме столбца base64. Пожалуйста, помогите.

1 Ответ

1 голос
/ 09 апреля 2019

Проблема заключается в точке с запятой в data:image/png;base64, в сочетании с " двойными кавычками.

Самым простым будет сохранить строку base64 без этого префикса, что нарушает синтаксис и затем принимаетэто все PNG изображений (или добавьте дополнительное поле, которое указывает кодировку каждого изображения).

Эта проблема не относится только к Room, но относится только к Java с SQLiteпотому что эта точка с запятой завершает оператор (который сгенерирует Room).В Java можно использовать ' одинарные кавычки только для примитивного типа данных char, тогда как сложный тип данных String исключает " двойные кавычки.Единственный способ обойти это ограничение - не пытаться сохранить String, содержащий ;.

. В качестве примера того, что я имею в виду:

private String base64String = null;
private String base64Type = "png";

public String getBase64Image() {
    if(this.base64String != null) {
        return "data:image/" + this.base64Type + ";base64," + this.base64String;
    } else {
        return null;
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...