繁体   English   中英

使用JPA(REST)将BLOB上载到数据库

[英]Uploading BLOB to DB using JPA(REST)

我想从文件资源管理器上传BLOB,但是对于上传Blob还是有点陌生​​,尤其是在使用JPA(Java Persistance API)时。

我以为我会向您展示一些代码,看看您能否给我一些正确方向的想法。

我的实体类如下所示

@Entity
@Table(name = "exampletable")
@XmlRootElement
@NamedQueries({
@NamedQuery(name = "Blob1337.findByTestBlob", query = "SELECT e FROM Blob1337 e WHERE e.testBlob = :testBlob")})

@Column(name = "test_blob")
private Integer testBlob;

public Integer getTestBlob() {
return testBlob;
}

public void setTestBlob(Integer testBlob) {
    this.testBlob = testBlob;
}

如您所见,我不确定在这里要为BLOB使用什么,所以现在它是一个整数。

我的外观看起来像这样:

@PUT
@Path("{id}")
@Consumes({"application/json"})
public void edit(@PathParam("id") Integer id, Blob1337 entity) {

    Blob1337 entityToMerge = find(id);

    if (entity.getTestBlob() != null) {
        entityToMerge.setTestBlob(entity.getTestBlob());
}
    super.edit(entityToMerge);

}

如何使我的外观和实体类知道这是BLOB? 我希望能够通过ajax帖子上传此文档,如果我正确的话,这应该是非常基本的。

谢谢! 任何帮助是极大的赞赏!

我终于设法通过rest / ajax上传了一个Blob

Facade应该看起来像这样(这需要一个Blob并将其流式传输到DB中):

    @POST
    @Path("upload/{id}")
    @Consumes({"application/x-www-form-urlencoded", "multipart/form-data"})

    public void addBlob(@PathParam("id") Integer id, @FormDataParam("file") InputStream uploadedInputStream) throws IOException {
        E24ClientTemp entityToMerge = find(id);
        try {
            ByteArrayOutputStream out = new ByteArrayOutputStream();
            int read = 0;
            byte[] bytes = new byte[1024];
            while ((read = uploadedInputStream.read(bytes)) != -1) {
                out.write(bytes, 0, read);
            }
            entityToMerge.setTestBlob(out.toByteArray());
            super.edit(entityToMerge);
        }
        catch (IOException e) {
            e.printStackTrace();
        }
    }

而不是上面问题中发布的blob integer ,我使用了带@Lob注释的byte[]

像这样:

@Lob
@Column(name = "test_blob")
private byte[] testBlob;

Bonus ,面向未来的访问者-这是这种情况下Ajax外观的一个示例:

    $(".uploadDocumentGeneral").on("click", function (evt) {
    IdToEdit = $(this).closest('tr').siblings().find('p.important').text();
    var url = "http://localhost:10110/MavenProject/api123/General123/upload/"+IdToEdit;
    evt.preventDefault();

    var documentData = new FormData();
    documentData.append('file', $('input#file.findDocumentOnboarding')[0].files[0]);
    $.ajax({
        url: url,
        type: 'POST',
        data: documentData,
        cache: false,
        contentType: false,
        processData: false,
        success: function (response) {
            alert("Document uploaded successfully.");
        }
    });

    return false;
});

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM