图片获取、格式转换与后台存储

后端是如何存储图片的呢?

  1. 将图片以独立文件的形式存储在服务器的文件夹中,再将该文件路径存入数据库中.
  2. 将图片转化为二进制流,直接存储到数据库的Image类型字段中.

第一种方式存储,则前端可以直接将存储路径赋值给src属性显示图片.
第二种方式存储,则前端得到的是二进制流数据,需将二进制流交由blob对象处理,然后通过blob的API生成临时的URL赋值给src属性来显示图片.

个人认为第一种方式存储更好,一张图片有几M,则大量图片存储在数据库中,则会影响数据库的性能。

第二种方式生成临时URL代码如下:

createURL(blob){
    
   let img=document.createElement('img'); 
   img.onload=function(e){
   //img的onload事件销毁URL
   window.URL.revokeObjectURL(img.src);
}
   img.src=window.URL.createObjectURL(blob)//根据blob二进制流数据生成临时URL,且URL以blob开头  
   document.querySelector('.haha').appendChild(img);
}

假设服务端接口只接收url、base64、blob中的一种格式的图片数据,然而前端得到的图片对象与服务端格式不同,那前端js如何使其转换为相对应的格式呢?

图片的三种格式转换图:
在这里插入图片描述
1.url转化base64

//转化原理:利用canvas.toDataURL的API转化成base64
    urlGetBase64(url){
      
       return new Promise((resolve,reject)=>{
      
       let image=new Image();    
       image.onload=function(){
       
             let canvas=document.createElement('canvas');    
             canvas.width=100;     
             canvas.height=100;   
             canvas.getContext('2d').drawImage(image,0,0);     
             let result=canvas.toDataURL('image/png');    
             resolve(result);   
             };   
             image.setAttribute("crossOrigin",'Anonymous');     
             image.src=url;    
             image.onerror=()=>{
       
             reject(new Error('图片流异常'));   
                };   
             }) 
           }

调用方法:

let imgUrl=`http://aaa.jpg`;
	this.urlGetBase64(imgUrl).then(res=>{
   
	console.log('url转化为base64格式:',res);
})

举例子:在网上找到一张url格式的图片

https://t9.baidu.com/it/u=1761131378,1355750940&fm=79&app=86&size=h300&n=0&g=4n&f=jpeg?sec=1584854630&t=a9403a3590083ce60f15eacf1ffa589e

在vscode运行如下代码:

export class ShowImageComponent implements OnInit {
   
imgData:any="https://t9.baidu.com/it/u=1761131378,1355750940&fm=79&app=86&size=h300&n=0&g=4n&f=jpeg?sec=1584854630&t=a9403a3590083ce60f15eacf1ffa589e"

  constructor() {
    }
  ngOnInit(): void {
   </
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Java 后台程序中,你可以使用 HTTP POST 请求来接收多个图片文件和文字信息。 具体来说,你需要使用一个表单来包含你的文字信息和文件输入字段,然后使用 Java 的 Servlet 或者 Spring MVC 框架来处理 HTTP POST 请求。 例如,你可以使用如下的 HTML 表单来提交文字信息和文件: ```html <form action="/upload" method="post" enctype="multipart/form-data"> <input type="text" name="textField" value="some text"> <input type="file" name="fileField1" multiple> <input type="file" name="fileField2" multiple> <button type="submit">Submit</button> </form> ``` 然后,在 Java 后台程序中,你可以使用如下的代码来处理这个 HTTP POST 请求: ```java @PostMapping("/upload") public void handleFileUpload(@RequestParam("textField") String text, @RequestParam("fileField1") MultipartFile file1, @RequestParam("fileField2") MultipartFile file2) { // 获取文字信息 String textField = text; // 获取文件内容 byte[] file1Content = file1.getBytes(); byte[] file2Content = file2.getBytes(); // 处理文字信息和文件内容 ... } ``` 在上面的代码中,`@PostMapping("/upload")` 注解用来处理 HTTP POST 请求,`@RequestParam` 注解用来获取表单中的文字信息和文件内容。 注意:为了使用 `MultipartFile` 类来处理文件内容,你需要在你的后台程序中添加对 `commons-fileupload` 和 `commons-io` 包的依赖。 ### 回答2: 在Java后台接收多个图片文件和文字信息可以使用Multipart/form-data格式进行传输。 首先,客户端需要使用表单提交方式将图片文件和文字信息一起发送到Java后台。表单的enctype属性需要设置为"multipart/form-data",这样可以保证图片文件能够正确地通过HTTP协议传输。 然后,在Java后台,可以使用一些常用的框架如SpringMVC或Servlet来处理接收到的请求。这些框架都提供了对Multipart/form-data格式进行解析的功能。 在SpringMVC中,可以使用@RequestParam注解来接收单个文件,并使用@RequestPart注解来接收多个文件。示例代码如下: ```java @PostMapping("/upload") public String handleFileUpload(@RequestParam("file") MultipartFile file, @RequestPart("files") MultipartFile[] files, @RequestParam("text") String text) { // 处理接收到的文件和文字信息 // ... return "success"; } ``` 在Servlet中,可以通过HttpServletRequest的getPart方法来获取上传的文件对象,通过getParameter方法来获取文字信息。示例代码如下: ```java protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 获取文件上传的对象 Part filePart = request.getPart("file"); Collection<Part> fileParts = request.getParts("files"); // 获取文字信息 String text = request.getParameter("text"); // 处理接收到的文件和文字信息 // ... } ``` 在处理接收到的文件和文字信息时,可以根据实际需求进行操作,例如将文件保到磁盘上的指定位置,或者将文字信息存储到数据库中等。相关的操作可以使用Java IO或者持久化框架来完成。 总之,通过使用Multipart/form-data格式,Java后台可以接收并处理多个图片文件和文字信息。 ### 回答3: 在Java后端,可以使用MultipartHttpServletRequest来接收多个图片文件和文字信息。 首先,前端可以使用HTML的<form>标签并设置enctype为"multipart/form-data"来实现文件上传。然后在Java后端,可以使用HttpServletRequest来接收请求,然后将其转换为MultipartHttpServletRequest对象。 接下来,可以通过MultipartHttpServletRequest对象的getFiles()方法来获取所有上传的文件。可以使用该方法返回的MultipartFile数组来逐个操作每个文件。可以使用MultipartFile对象的getOriginalFilename()方法获取文件名,使用getContentType()方法获取文件类型,使用getBytes()方法获取文件内容的字节数组等。 此外,还可以通过MultipartHttpServletRequest对象的getParameter()方法来获取表单中的其他文本参数。可以通过该方法传递参数名来获取对应的值。 总结起来,可以使用MultipartHttpServletRequest对象获取多个图片文件和文字信息。对于文件,可以使用MultipartFile对象获取文件名、类型和内容。对于文字信息,可以使用MultipartHttpServletRequest对象的getParameter()方法获取表单中的其他参数值。 注意:在使用MultipartHttpServletRequest接收文件时,需要在后端的配置文件中设置合适的文件上传配置,如设置文件保路径、最大文件大小等。另外,还需要相关的依赖库来支持文件上传功能,如Apache Commons FileUpload或Spring的MultipartResolver等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值