微信小程序之上传图片到Java Web服务器

微信小程序之上传图片到Java Web服务器


目录

1.背景

2.微信小程序部署界面

3. Java Web后台实现

4. 微信小程序&Java Web后台建立连接

5. 运行思路整理


1.背景

话说课设来了,还是在期末。嗯嗯嗯额~这就很难受,还好最后顺利完成任务,并对微信小程序上传图片到web服务器有点理解。综上:此篇博客诞生了?


2.微信小程序部署界面

  • 先看看小程序的目录结构

  • 完善pages下的微信界面

index.wxml

​​​​<!--index.wxml-->
<text>单张或多张图片上传</text>
<view wx:for="{{perImgSrc}}" wx:key="ind" wx:for-item="item">
    <view>{{ind}}</view>
	<image src="http://localhost:8080/demo/{{item.src}}"></image> 
</view> 
<button bindtap="chooseImg">选择图片</button>

index.js

//index.js
//获取应用实例
const app = getApp()
var total = [];
Page({
  data: {
    perImgSrc: []
  },
  onLoad: function (options) {
    // 页面初始化 options为页面跳转所带来的参数
  },
  onReady: function () {
    // 页面渲染完成
  },
  onShow: function () {
    // 页面显示
  },
  onHide: function () {
    // 页面隐藏
  },
  onUnload: function () {
    // 页面关闭
  },
  chooseImg: function () {
    var that = this;
    wx.chooseImage({
      count: 9, // 默认9
      sizeType: ['original'], // 可以指定是原图还是压缩图,默认二者都有
      sourceType: ['album'], // 可以指定来源是相册还是相机,默认二者都有
      success: function (res) {
        // 返回选定照片的本地文件路径列表,tempFilePath可以作为img标签的src属性显示图片
        var tempFilePaths = res.tempFilePaths;
        console.info(res.tempFilePaths.length);
        that.uploadFile2(tempFilePaths, 0);
      }
    })
  }, uploadFile: function (file, i) {//测试,没有什么屌用
    var that = this;
    wx.uploadFile({
      url: 'http://localhost:8080/demo/upload', //仅为示例,非真实的接口地址
      filePath: file,
      name: 'file',
      success: function (res) {
        var obj = new Object();
        obj.ind = i + 1;
        var data = res.data;
        console.info(data);
        obj.src = data;
        console.info("---------------------------------");
        console.info(obj);
        that.data.perImgSrc.push(obj);

      }
    })
  }, uploadFile2: function (file, i) {//递归调用
    var that = this;
    wx.uploadFile({
      url: 'http://localhost:8080/demo/upload', //仅为示例,非真实的接口地址
      filePath: file[i],
      name: 'file',
      success: function (res) {
        var obj = new Object();
        obj.ind = i + 1;
        var data = res.data;
        console.info(data);
        obj.src = data;
        console.info("---------------------------------");
        console.info(obj);

        if (!((i + 1) == file.length)) {
          total.push(obj);
          that.uploadFile2(file, i + 1);
        } else {
          total.push(obj);
          that.setData({ perImgSrc: total });
        }
      }
    })
  }
})

 


3. Java Web后台实现

  • 创建web项目,编写UploadServlet.java文件
public class UploadServlet extends HttpServlet {
	@Override
	protected void doGet(HttpServletRequest req, HttpServletResponse resp) 
            throws ServletException, IOException {
	    doPost(req,resp);
	}
	
	@Override
	protected void doPost(HttpServletRequest request, HttpServletResponse response) 
            throws ServletException, IOException {
	    request.setCharacterEncoding("utf-8"); //设置编码
	    //获得磁盘文件条目工厂
	    DiskFileItemFactory factory = new DiskFileItemFactory();
	    String str = request.getSession().getServletContext().getRealPath("");
	    //获取文件需要上传到的路径
	    String path = request.getRealPath("/upload");
	    System.out.println(path);
	    //String path =request.getSession().getServletContext().getRealPath("/upload");
	    System.out.println(path);
	    String pathStr=null;
	    System.err.println("上传的图片路径:"+path);
	    //如果没以下两行设置的话,上传大的 文件 会占用 很多内存,
	    //设置暂时存放的 存储室 , 这个存储室,可以和 最终存储文件 的目录不同
	    /**
	    * 原理 它是先存到 暂时存储室,然后在真正写到 对应目录的硬盘上,
	    * 按理来说 当上传一个文件时,其实是上传了两份,第一个是以 .tem 格式的
	    * 然后再将其真正写到 对应目录的硬盘上
	    */
	    factory.setRepository(new File(path));
	    //设置 缓存的大小,当上传文件的容量超过该缓存时,直接放到 暂时存储室
	    factory.setSizeThreshold(1024*1024);
	    //高水平的API文件上传处理
	    ServletFileUpload upload = new ServletFileUpload(factory);
	    try {
	    //可以上传多个文件
	    List<FileItem> list = (List<FileItem>)upload.parseRequest(request);
	    for(FileItem item : list){
	    //获取表单的属性名字
	    String name = item.getFieldName();
	    //如果获取的 表单信息是普通的 文本 信息
	    if(item.isFormField()){
	        //获取用户具体输入的字符串 ,名字起得挺好,因为表单提交过来的是 字符串类型的
	        String value = item.getString() ;
	    request.setAttribute(name, value);
	    }else {
	    /**
	    * 以下三步,主要获取 上传文件的名字
	    */
	    //获取路径名
	        String value = item.getName() ;
	    //索引到最后一个反斜杠
	    //int start = value.lastIndexOf("");
	    //截取 上传文件的 字符串名字,加1是 去掉反斜杠,
	        String filename = value;
	
	        request.setAttribute(name, filename);
	    //真正写到磁盘上
	    //它抛出的异常 用exception 捕捉
	    //item.write( new File(path,filename) );//第三方提供的
	    //手动写的
	        str+="upload\\"+filename;
	        pathStr="/upload/"+filename;
	        System.err.println("文件存储的路径:"+str);
	        File file=new File(str);
	        OutputStream out = new FileOutputStream(file);
	        InputStream in = item.getInputStream() ;
	        int length = 0 ;
	        byte [] buf = new byte[1024] ;
	        System.out.println("获取上传文件的总共的容量:"+item.getSize());
	    // in.read(buf) 每次读到的数据存放在 buf 数组中
	        while( (length = in.read(buf) ) != -1){
	    //在 buf 数组中 取出数据 写到 (输出流)磁盘上
	        out.write(buf, 0, length);
	    }
	        in.close();
	        out.close();
	    }
	    }
	    } catch (FileUploadException e) {
	        e.printStackTrace();
	    }
	        catch (Exception e) {
	    }
	    PrintWriter printWriter=response.getWriter();
	    // printWriter.print("{"path":""+pathStr+""}");
	    printWriter.print(pathStr);
	    printWriter.flush();
	    printWriter.close();
	}
}

注:需要引入这样两个jar包commons-io-2.5.jar、commons-fileupload-1.3.2.jar;可在https://commons.apache.org下载。

  • 更改web.xml配置文件

  • 测试后台是否正常运行

注:请以Debug模式启动后台tomcat server,如果出现request contain null错误属正常情况。


4. 微信小程序&Java Web后台建立连接

  •  更改微信小程序端的url —— 改为自己的http://localhost:8080/项目名/upload

index.wxml文件

 index.js文件

  • 点击选择图片,观察是否跳转至Java Web后台

 

注意:如果出现https证书问题,这是微信小程序默认设置无法读取本机url,更改一下配置即可

  • 如果以上所有问题都以解决,基本上就已经成功了,这里提供微信小程序端窗口输出和界面显示截图

  • 最后看看Java Web后台,可以发现在控制台输出的指定路径下有刚刚上传的图片了

 


5. 运行思路整理

  1. 微信小程序端点击选择图片
  2. 从index.wxml跳转到index.js中的chooseImg函数中
  3. 在chooseImg函数中又调用uploadFile2函数,并将选择的图片文件打包给uploadFile2
  4. uploadFile2中利用wx内部封装的uploadFile函数向指定url请求上传
  5. 跳转至Java Web后台,首先经过web.xml过滤跳转至UploadServlet.java执行对应方法实现图片上传至指定文件路径
  6. 最后微信小程序中的index.wxml中的src读取到Java Web指定路径下的上传文件,也就显示到了微信小程序界面了


微信小程序的开发还是比较舒服的,虽然过程还是麻烦不断,整套平台用起来很自然流畅,再加上微信生态的蓬勃发展,学学微信小程序开发也是很不错的一个选择。加油,学习、生活、锻炼!!!!

欢迎关注CSDN博客——知飞翀,我们一起来搞技术~~~~~

                                               谢谢阅读                  ----知飞翀

  • 0
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
要将微信小程序中的图片Java后端,可以采用如下步骤: 1. 在小程序中选择需要上图片,并将其转换为base64编码格式。 2. 通过微信小程序API将base64编码的图片数据输到后端服务器。 3. 在Java后端中接收base64编码的图片数据,并将其转换为图片文件。 4. 将转换后的图片文件存储到服务器本地或云存储中。 以下是一个简单的Java代码示例,用于将base64编码的图片数据转换为图片文件并上服务器: ``` import java.io.*; public class Base64ImageDecoder { public static void decode(String base64ImageString, String outputPath) { try { byte[] imageBytes = javax.xml.bind.DatatypeConverter.parseBase64Binary(base64ImageString); InputStream in = new ByteArrayInputStream(imageBytes); BufferedImage image = ImageIO.read(in); ImageIO.write(image, "jpg", new File(outputPath)); } catch (IOException e) { e.printStackTrace(); } } } ``` 在上述示例中,`decode`方法接收两个参数:base64编码的图片数据和图片文件输出路径。该方法会先将base64编码的图片数据解码为二进制数据,然后使用Java的`ImageIO`类将二进制数据转换为图片文件,并将其保存到指定的输出路径中。 在实际应用中,你需要将该代码集成到你的Java后端服务中,并根据具体的业务逻辑进行调用。同时,你还需要根据你的系统环境和需求选择适合的图片存储方式,例如使用本地文件系统或云存储服务。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值