javascript - 如何使用 hibernate、spring mvc 和 angular js 从后端检索图像和其他数据并显示在屏幕上?

标签 javascript java angularjs spring hibernate

我正在为我的应用程序使用 hibernate、html、spring mvc 和 angular js。从 hibernate 我正在构建将与前端 html 页面绑定(bind)的 View 模型。上传和保存我没有问题。但是在使用 hibernate 从数据库中检索相同的图像时,我只收到一个字节数组。如何获取“tab.namePRAttch”中的文件组件(见下面的代码)。

如何从byte[]中获取与我上传的文件相同的文件?

下面给出了字节数组组件映射到 View 模型的 java 代码。我使用 byte[] 作为图像数据类型。

感谢您的帮助。

提前致谢。

Set<NamePageAttchModel> atchList = result.get(i).getNameAttachments();
        List<byte []> attbyArr = new ArrayList<byte[]>();
        for(NamePageAttchModel m : atchList){
            byte [] a = m.getAttachFile();
            attbyArr.add(a);
        }
        viewModel.setNamePRAttch(attbyArr);

$scope.retrieveName = function() {
    if (SearchService.getAdvflagNm()) {
      $http({
          params: {
            "mainId": $scope.mainPR.mainInfoId
          },
          method: 'GET',
          url: 'namePage/retrieveNamePge'
        })
        .then(
          function mySuccess(response) {
            $scope.showSuggestions = false;
            $scope.disOthrSec = false;
            if (response.data !== "" && response.data !== undefined) {
              $scope.namePageTabs = response.data;
            }
            SearchService.setAdvflagNm();
            if (response.status == 500) {

            },
            function myError(response) {});
        }
    };
<div class="col-md-3">
  <input type="file" ng-image-model file-model="tab.namePRFile" multiple />
</div>

<div ng-repeat="file in tab.namePRAttch.file track by $index">
  <a ng-src="{{file}}" ng-click="openImage(this)">{{file.name}}</a><i ng-click="removePRNameFile(file)" class="btn btn-md fa fa-trash" aria-hidden="true"></i>
</div>

最佳答案

要访问图像,您必须将其转换为 b64 格式,为此创建一个实体并将变量 imagePath 声明为 String 类型。让实体名称为 ImagePath 假设您从 dao 层获取列表,如 list = dao.getList。应用 for 循环访问图像并将其转换为 base64Binary,如:
String b64 = javax.xml.bind.DatatypeConverter.printBase64Binary(m.getImage());
在 for 循环内实例化您的 ImagePath 实体并将 imagePath 设置为 imagePath.setPath(b64); 以及您希望与图像一起发送的所有其他属性。
现在将它添加到你的列表 attbyArr.add(a); 并将它添加到你的 viewModel viewModel.setNamePRAttch(attbyArr);

ImageClass 为:

@Entity
public class ImageClass implements Serializable {

private static final long serialVersionUID = -4978144559787934722L;

@Id
@GeneratedValue(strategy=GenerationType.AUTO)
@Column(name="image_id")
private int image_id;

@Lob
@Column(name="image_content", nullable=false, columnDefinition="mediumblob")
private byte[] image;  
}

然后 ImagePath 类 应该是这样的:

public class ImagePath {

private int id;
private String imagePath;
} //generate getter setter and parametriced constructor  

Controller 类 将具有:

List<ImageClass> list = dao.getList();
List<ImagePath> imageList = new ArrayList<ImagePath>();
for (ImageClass m : list) {
        String b64 = javax.xml.bind.DatatypeConverter.printBase64Binary(m.getImage());
        ImagePath imagepath = new ImagePath();
        imagepath.setId(m.getImage_id());
        imagepath.setImagePath(b64);
        imageList .add(imagepath);
        model.addAttribute("imageList", imageList); //Or you can return it as a list that can be used in Angular

关于javascript - 如何使用 hibernate、spring mvc 和 angular js 从后端检索图像和其他数据并显示在屏幕上?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41281099/

相关文章:

java - rdf :id 的 sparql 查询

javascript - Http post没有返回响应并且Angular js中的请求没有错误?

angularjs - 可以按行定义 UI 网格编辑吗?

javascript - 如何通过 gridComplete 方法获取单元格值

javascript - 每 x 秒迭代一次状态中的对象

java - FlexJson 和 @JSON 注释 - @JSON(name = "") 不工作

java - 如何在另一个线程上运行 RxJava 观察者

ruby-on-rails - 如何使用 coffeescript 获取当前年份

javascript - 从可观察同步获取数据。 Angular

javascript - JS formatnumber/addcommas 不工作