zoukankan      html  css  js  c++  java
  • 微信小程序上传图片

    话不多说,直接上码。

    <view class="section">
      <!--放一张图片或按钮  点击时去选择图片-->
      <image class='ph' src='{{photos}}' bindtap='touchphoto' mode='aspectFit'>  </image>
      <!--循环显示选中的图片-->
      <block wx:for="{{pics}}" wx:for-index="index">
      <view class="item" data-index="{{index}}" >
       <image class='ph' src='{{item}}' bindtap='touchphoto' mode='aspectFit'>  </image>
      </view>
        </block>
    </view>
    <button bindtap='sendFile'>上传</button>

    js

    // 在需要使用的js文件中,导入js  
    var util = require('../../../utils/util.js');
    var app = getApp();
    
    Page({
      data: {
        pics:[],//存放选中图片数组
        photos: "../../../img/camera.jpg",//默认点击图片
        fileNames:""//
      },
     touchphoto: function (e) {//点击选择图片事件
        var that = this
        var pic = this.data.pics;
          wx.chooseImage({
            count: 9 - pic.length, //图片数量 默认9
            sizeType: ['original', 'compressed'], // 可以指定是原图还是压缩图,默认二者都有
            sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有
            success: function (res) {
              // 返回选定照片的本地文件路径列表,tempFilePath可以作为img标签的src属性显示图片
              var tempFilePaths = res.tempFilePaths;
              pic = pic.concat(tempFilePaths);
              that.setData({
                pics:pic,        //如果上传单张图片的话可以取消这个
           photos:tempFilePaths //如果上传单张图片的话,可以用这个 }) } }) }, sendFile:
    function (e) {//多图片上传 var paths = this.data.pics;//获取上传数组 for (var index in paths){//循环这个数组 var fileP = ""; fileP = fileP + paths[index];//获取当前循环到的图片 wx.uploadFile({ url: app.globalData.API_URL + '/uploadFileWX', filePath: fileP, name: 'file',//名称根据自己情况取 formData: {//除了要上传的附件外。其他额外要传的参数 'user': 'admin' }, success: function (res) {//上传成功方法 wx.showToast({ title: '上传成功', icon: 'success', duration: 2000 }) } }) } }, onLoad: function () { } })

    css样式

    .ph{
       200rpx;
      height: 200rpx;
      border: 1px solid #909090;
      margin-left:14%;
      border-radius: 20rpx;
    }
    .ph1{
       200rpx;
      height: 200rpx;
      border: 1px solid #909090;
      margin-left:5%;
      float: left;
      border-radius: 20rpx;
      margin-top: 5%;
      margin-bottom: 5%;
    }
    
    .btn{
        background: #335c8f;
        color: #fff;
        margin-left:40rpx;
        margin-right: 40rpx;
         90%;
    }

    java后台代码

      @RequestMapping(value = "/uploadFile", method = RequestMethod.POST)
        public @ResponseBody  Object uploadFile(HttpServletRequest request, HttpServletResponse response,
                @RequestParam(value = "file", required = false) MultipartFile file,
                @RequestParam(value = "user") String user,Model model) {
            try {
                request.setCharacterEncoding("UTF-8");
             
                if (!file.isEmpty()) {
                     System.out.println("成功获取照片");
                    String fileName = file.getOriginalFilename();
                    String path = null;
                    String type = null;
                    type = fileName.indexOf(".") != -1 ? fileName.substring(fileName.lastIndexOf(".") + 1,
                            fileName.length()) : null;
                    if (type != null) {//类型验证,如果不需要验证的话,也可以取消这一步
                        if ("GIF".equals(type.toUpperCase()) || "PNG".equals(type.toUpperCase())
                                || "JPG".equals(type.toUpperCase())) {
                            // 项目在容器中实际发布运行的根路径
                            String realPath = request.getSession().getServletContext().getRealPath("/");
                            // 自定义的文件名称
                            String trueFileName = String.valueOf(System.currentTimeMillis()) + fileName;
                            // 设置存放图片文件的路径
                            path = realPath + "/resources/wxFile/" + trueFileName;
                            file.transferTo(new File(path));
                           
                            model.addAttribute("resultCode", "200");
                        } else {
                             System.out.println("不是我们想要的文件类型,请按要求重新上传");
                            model.addAttribute("resultCode", "300");
                           
                        }
                    } else {
                         System.out.println("文件类型为空");
                        model.addAttribute("resultCode", "300");
            
                    }
                } else {
                     System.out.println("没有找到相对应的文件");
                    model.addAttribute("resultCode", "erro");
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
            return model;
        }

     

    看完是不是觉得特别简单?

  • 相关阅读:
    QB学堂济南游记
    区间质数查询 luoguP1865
    基础数据结构 ①(栈|队列|链表)
    图论算法->最短路
    小谈记忆化搜索
    Hibernate其它API
    Hibernate中Session与本地线程绑定
    Hibernate事务代码规范写法
    实体类对象的三种状态
    对实体类的CRUD操作
  • 原文地址:https://www.cnblogs.com/wushumin/p/10039700.html
Copyright © 2011-2022 走看看