微信小程序上传图片解决方案+oss+后端代码

微信小程序上传图片解决方案+oss+后端代码

目的

最近需要整合小程序作一个图片上传至阿里云oss存储里。故以此来记录此解决方案。

实践

小程序

本次前端采用的是小程序的lin-ui框架的图片选择器(lin-ui框架不做阐述)

<l-image-picker count="9" bind:linchange="onChangeTap" size="3" id="imagePicker" />
<l-message />

图片上传函数

async wxPostPicture() {
        let that = this
        // lin-ui的开放函数
        const imagePicker = this.selectComponent('#imagePicker');
        let urls = imagePicker.linGetValue();
        for (let i = 0; i < urls.length; i++) {
            wx.uploadFile({
                url: "你的图片上传服务地址",
                filePath: urls[i],
                name: "files",
                header: {
                    "Content-Type": "multipart/form-data",
                },
                success: function (res) {
                    let datas = JSON.parse(res.data)
                    if (datas.code === 200) {
                        that.data.imgLists.push(datas.data)
                        that.setData({
                            imgLists: that.data.imgLists,
                        })
                    } else {
                        wx.lin.showMessage({
                            content: '上传图片失败'
                        })
                    }
                }
            })
        }
    }

注意:wx.uploadFile的是采用异步的形式,故需要先统一等待时间,才能获取完整的图片,你可以在调用图片地址之前先sleep一段时间。如下

   // 异步暂停时间
    delay: function (milSec) {
        return new Promise(resolve => {
            setTimeout(resolve, milSec)
        })
    },

java后端

依赖

        <!--OSS-->
        <dependency>
            <groupId>com.aliyun.oss</groupId>
            <artifactId>aliyun-sdk-oss</artifactId>
            <version>2.4.0</version>
        </dependency>
        <dependency>
            <groupId>commons-fileupload</groupId>
            <artifactId>commons-fileupload</artifactId>
            <version>1.3.1</version>
        </dependency>
        <dependency>
            <groupId>org.jdom</groupId>
            <artifactId>jdom</artifactId>
            <version>1.1.3</version>
        </dependency>

配置文件

aliyun:
  oss:
    file:
      endPoint: "你的阿里云oss存储公网地址"
      keyid: "在oss中创建用户并创建key"
      keysecret: "在oss中创建用户并创建key"
      bucketname: "你创建的bucket名字"

参数类


import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

@Component
public class OssConstant implements InitializingBean {
    @Value("${aliyun.oss.file.endPoint}")
    private String oss_file_endpoint;

    @Value("${aliyun.oss.file.keyid}")
    private String oss_file_keyid;

    @Value("${aliyun.oss.file.keysecret}")
    private String oss_file_keysecret;

    @Value("${aliyun.oss.file.bucketname}")
    private String oss_file_bucketname;

    public static String OSS_END_POINT_IM;
    public static String OSS_BUCKET_IM;
    public static String OSS_ACCESS_KEY_ID_IM;
    public static String OSS_ACCESS_KEY_SECRET_IM;

    @Override
    public void afterPropertiesSet() throws Exception {
        OSS_END_POINT_IM = oss_file_endpoint;
        OSS_BUCKET_IM = oss_file_bucketname;
        OSS_ACCESS_KEY_ID_IM = oss_file_keyid;
        OSS_ACCESS_KEY_SECRET_IM = oss_file_keysecret;
    }
}


上传文件类



import cn.dev33.satoken.stp.StpUtil;
import com.aliyun.oss.ClientException;
import com.aliyun.oss.OSSClient;
import com.aliyun.oss.OSSException;
import com.aliyun.oss.model.CannedAccessControlList;
import com.aliyun.oss.model.CreateBucketRequest;
import com.aliyun.oss.model.PutObjectRequest;
import com.aliyun.oss.model.PutObjectResult;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import org.springframework.web.multipart.MultipartFile;

import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;

/**
 * @version 1.0
 * @date 2021/5/29 21:48
 */
@Component
public class AliyunOSSUtil {
    private static final String accessKeyId = OssConstant.OSS_ACCESS_KEY_ID_IM;
    private static final String accessKeySecret = OssConstant.OSS_ACCESS_KEY_SECRET_IM;
    private static final String endpoint = OssConstant.OSS_END_POINT_IM;
    private static final String bucket = OssConstant.OSS_BUCKET_IM;
    // oss水印
    private static final String tag = "oss图片路径的参数,例如水印等参数,自行查询";
    private static final Logger logger = LoggerFactory.getLogger(AliyunOSSUtil.class);

    public static String OSSUploadFile(MultipartFile file) {
        SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd : hh:mm:ss");
        OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
        try {
            //容器不存在,就创建
            if (!ossClient.doesBucketExist(bucket)) {
                ossClient.createBucket(bucket);
                CreateBucketRequest createBucketRequest = new CreateBucketRequest(bucket);
                createBucketRequest.setCannedACL(CannedAccessControlList.Default);
                ossClient.createBucket(createBucketRequest);
            }
			// 在file.getOriginalFilename()之前的“/”为你bucket的文件夹,请自行修改。
            String fileUrl = "img" + "/" + StpUtil.getLoginId() + "-" + format.format(new Date()) + "-" + file.getOriginalFilename();

            //上传文件
            PutObjectResult result = null;
            try {
                result = ossClient.putObject(new PutObjectRequest(bucket, fileUrl, new ByteArrayInputStream(file.getBytes())));
            } catch (IOException e) {
                e.printStackTrace();
            }
            //设置权限 这里是公有权限读写
            ossClient.setBucketAcl(bucket, CannedAccessControlList.PublicRead);
            if (null != result) {
                logger.info("==========>OSS文件上传成功,OSS地址:" + fileUrl);
                return "fileUrl + tag;
            }
        } catch (OSSException oe) {
            logger.error(oe.getMessage());
        } catch (ClientException ce) {
            logger.error(ce.getMessage());
        } finally {
            //关闭
            ossClient.shutdown();
        }
        return null;
    }
}


controller类


/**
 * @Description:
 * @Author: chenzexiong
 * @Date: 2021/12/23 9:17
 * @Version 1.0:
 */

@RestController()
@RequestMapping("/test")
public class TbCommonController {

    @PostMapping(value = "picture/url/get")
    TbResult getPictureUrl(@RequestParam("files") MultipartFile files) {
        String url = AliyunOSSUtil.OSSUploadFile(files);
        return TbResult.success(url,"ok");
    }
}

总结

后端借鉴一篇博客,但找不到出处了,在此说明一下。
为了下次方便使用,仅以此来作记录。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值