Я работаю над проектом Spring JPA Hibernate и хочу сохранять изображения в базе данных Mysql из Image Url. Я передаю данные DTO заказов с URL-адресом изображения, взятым из службы отдыха. Как сохранить URL-адреса изображений как изображения в базе данных. Я думаю, нам нужно сначала получить изображение из URL. Пожалуйста, решите эту проблему.
OrderDO.java
@Table(name = "ORDER")
public class OrderDO implements Serializable{
@Column(name = "ORDER_NUMBER", nullable = false)
private String orderNumber;
@OneToMany(cascade = CascadeType.ALL, mappedBy = "order")
private Set<OrderItemDO> items = new HashSet<>();
}
OrderItemDO.java
@Table(name = "ORDER_ITEM")
public class OrderItemDO implements Serializable{
@Column(name = "PRODUCT_NAME",nullable = false)
private String name;
@Lob
@Column(name = "IMAGE")
private byte[] image;
@ManyToOne(cascade=CascadeType.ALL)
@JoinColumn(name = "ORDER_ID", referencedColumnName = "ID")
private OrderDO order;
}
OrderRepository.java
@Repository
public interface OrderRepository extends CrudRepository<OrderDO, Long>{
public Page<OrderDO> findAll(Pageable pageable);
}
OrderServiceImpl.java
public class OrderServiceImpl {
@Autowired
private ModelMapper modelMapper;
@Autowired
private OrderRepository orderRepository;
private OrderDO map(Order dto) {
OrderDO orderDO = modelMapper.map(dto, OrderDO.class);
Set<OrderItemDO> itemsDO = new HashSet<>();
for(OrderItem item : dto.getItems()) {
OrderItemDO itemDO = map(item);
itemDO.setOrder(orderDO);
itemsDO.add(itemDO);
}
orderDO.setItems(itemsDO);
return orderDO;
}
public OrderItemDO map(OrderItem dto) {
OrderItemDO itemDO = modelMapper.map(dto, OrderItemDO.class);
return itemDO;
}
public Order SaveOrder(Order dto) {
OrderDO entity = this.map(dto);
entity = orderRepository.save(entity);
return this.map(entity);
}
System.setProperty ("java.net.useSystemProxies", "истина"); byte [] imageBytes = IOUtils.toByteArray (новый URL ("example.com/order/images/image001.jpg") .openStream ());




Вы можете преобразовать URL-адрес изображения в изображение байта [] данных в Rest Service перед его сохранением.
public static byte[] convertImageByte(URL url) throws IOException {
ByteArrayOutputStream baos = new ByteArrayOutputStream();
InputStream is = null;
try {
is = url.openStream ();
byte[] byteChunk = new byte[4096]; // Or whatever size you want to read in at a time.
int n;
while ( (n = is.read(byteChunk)) > 0 ) {
baos.write(byteChunk, 0, n);
}
return byteChunk;
}
catch (IOException e) {
System.err.printf ("Failed while reading bytes from %s: %s", url.toExternalForm(), e.getMessage());
e.printStackTrace ();
// Perform any other exception handling that's appropriate.
}
finally {
if (is != null) { is.close(); }
}
return null;
}
Хорошо Проблема решена. Код для преобразования URL-адреса изображения в массив байтов приведен ниже. Пожалуйста, обратитесь к здесь для получения дополнительных ответов по этой проблеме
public static byte[] convertImageByte(URL url) throws IOException {
ByteArrayOutputStream baos = new ByteArrayOutputStream();
InputStream is = null;
try {
is = new BufferedInputStream(url.openStream());
byte[] byteChunk = new byte[4096];
int n;
while ( (n = is.read(byteChunk)) > 0 ) {
baos.write(byteChunk, 0, n);
}
return baos.toByteArray();
}
catch (IOException e) {e.printStackTrace ();}
finally {
if (is != null) { is.close(); }
}
return null;
}
При сохранении Dto в базу данных
if (dto.getImageUrl() != null) {
try {
URL imageUrl = new URL(dto.getImageUrl());
itemDO.setImage(convertImageByte(imageUrl));
} catch (IOException e) {
e.printStackTrace();
}
}
entity = orderItemRepository.save(itemDO);
Получить изображение из базы данных
public byte[] getImageForOrderItem(long itemId) {
Optional<OrderItemDO> option = orderItemRepository.findById(itemId);
if (option.isPresent()) {
OrderItemDO itemDO = option.get();
if (itemDO.getImage() != null) {
byte[] image = itemDO.getImage();
return image;
}
}
return null;
}
Вызов ответа изображения через Rest API
@GetMapping(path = "/orderItem/image/{itemId}")
@ResponseStatus(HttpStatus.OK)
public void getImageForOrderItem(@PathVariable("itemId") long itemId, HttpServletResponse response) {
byte[] buffer = orderServiceImpl.getImageForOrderItem(itemId);
if (buffer != null) {
response.setContentType("image/jpeg");
try {
response.getOutputStream().write(buffer);
response.getOutputStream().flush();
response.getOutputStream().close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
Используйте HTTP-клиент для загрузки изображений, а затем сохраните их в базе данных.