zoukankan      html  css  js  c++  java
  • 使用代码获得Hybris Commerce里显示的产品图片

    使用下面这个API去取Hybris Commerce系统里产品主数据的明细信息:

    https://:9002/rest/v2/electronics/products/300938?fields=FULL
    其中图片的url包含在字段images.url里,如下图所示:

    clipboard1,1

    加上全域名后,这个url是能够直接在浏览器里访问的:https://:9002/rest/v2/medias/?context=bWFzdGVyfGltYWdlc3wxMzkzNnxpbWFnZS9qcGVnfGltYWdlcy9oMGQvaDVhLzg3OTYyMTQwOTk5OTguanBnfDIwNTM4ZDc0YjQ5YjQzNGE0ZTJlMDZlNmU2NGNmOTI4MzAwOGM1Y2UwNTkyZmJkMzczMTljN2I2N2MzZmY3N2I

    只是因为我这台运行Hybris commerce的服务器证书设置有问题,因此微信里访问这个url时,报下面的错误:
    该地址为IP地址,请使用域名访问网站:

    clipboard2

    在手机浏览器里直接输入IP地址是可以访问这张图片的:

    clipboard3,3

    url里的context的值:bWFzdGVyfGltYWdlc3wxMzkzNnxpbWFnZS9qcGVnfGltYWdlcy9oMGQvaDVhLzg3OTYyMTQwOTk5OTguanBnfDIwNTM4ZDc0YjQ5YjQzNGE0ZTJlMDZlNmU2NGNmOTI4MzAwOGM1Y2UwNTkyZmJkMzczMTljN2I2N2MzZmY3N2I

    这个值是base64编码之后的值,使用常用的base64解码之后查看:

    clipboard4,4

    就是一些Hybris系统上存储图片的Administration信息。

    考虑到直接返回这个url给消费端的话,由于证书问题,前端显示这个图片不太方便,故我们决定将图片的base64编码之后的内容返回给前端,而不是url.

    故使用下面这段简单的代码,根据url获得图片的base64 encode编码值:

     RestTemplate template = new RestTemplate();
    		 String url = "https://<host>:9002/rest/v2/medias/?context=bWFzdGVyfGltYWdlc3wxMzkzNnxpbWFnZS9qcGVnfGltYWdlcy9oMGQvaDVhLzg3OTYyMTQwOTk5OTguanBnfDIwNTM4ZDc0YjQ5YjQzNGE0ZTJlMDZlNmU2NGNmOTI4MzAwOGM1Y2UwNTkyZmJkMzczMTljN2I2N2MzZmY3N2I";
    		 byte[] imageBytes = template.getForObject(url, byte[].class);
    	     System.out.println("response size: " + imageBytes.length);
    	     
    	     String base64Image = Base64.getEncoder().encodeToString(imageBytes);
    	     System.out.println("content: " + base64Image);
    

    将生成的base64编码粘贴近在线base64解码网站,可以成功还原成图片:

    clipboard5,5

    要获取更多Jerry的原创文章,请关注公众号"汪子熙":
    公众号截图

  • 相关阅读:
    component
    js的for循环中DOM变化不了,在循环结束才起效的问题
    mongodb 遇见不可行
    vue.js中$emit的理解
    最近前端关键词-模块化、前后端分离、单页面应用
    webpack的使用1
    一维数组的声明和使用
    ASP.net中的几种分页方法
    各种排序及原理
    数据结构-算法
  • 原文地址:https://www.cnblogs.com/sap-jerry/p/12038130.html
Copyright © 2011-2022 走看看