前端图片裁剪并上传到七牛云kodo

2024-06-13 18:48

本文主要是介绍前端图片裁剪并上传到七牛云kodo,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近项目中用到七牛云图片上传,特别记录。

我的七牛云kodo存储区域是“华南”,demo示例均为华南,为了跑demo避免问题,建议使用华南区。

一 .服务端代码(java)

(1)导入maven

<dependency><groupId>com.qiniu</groupId><artifactId>qiniu-java-sdk</artifactId><version>7.2.29</version></dependency><dependency><groupId>com.squareup.okhttp3</groupId><artifactId>okhttp</artifactId><version>3.3.1</version><scope>compile</scope></dependency>

(2)获取签名代码

package com.durian.amanager.controllers.upload;import java.util.UUID;import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;import com.durian.common.tool.ConfigUtils;
import com.qiniu.util.Auth;
import com.qiniu.util.StringMap;@Controller
@Scope("prototype")
@RequestMapping("/qiniu")
public class QiniuUploadController {/** 简单方式解决中文乱码问题,通常不采用*/
//	@RequestMapping(value = "/login2",produces = "application/json;charset=utf-8";)@RequestMapping(value = "/imageUptoken")@ResponseBodypublic QiNiu imageUptoken() {String bucket = ConfigUtils.getString("qiniu.image.bucket", "", "qiniu");return getUptoken(bucket);}@RequestMapping(value = "/attachmentUptoken")@ResponseBodypublic QiNiu attachmentUptoken() {String bucket = ConfigUtils.getString("qiniu.attachment.bucket", "", "qiniu");return getUptoken(bucket);}private QiNiu getUptoken(String bucket) {QiNiu qiNiu = new QiNiu();String accessKey = ConfigUtils.getString("qiniu.accessKey", "", "qiniu");String secretKey = ConfigUtils.getString("qiniu.secretKey", "", "qiniu");long expireSeconds = ConfigUtils.getString("qiniu.expireSeconds", 600L, "qiniu"); // 过期时间StringMap putPolicy = new StringMap();Auth auth = Auth.create(accessKey, secretKey);String upToken = auth.uploadToken(bucket, null, expireSeconds, putPolicy);qiNiu.setKey(UUID.randomUUID().toString().replaceAll("\\-", ""));qiNiu.setUptoken(upToken);return qiNiu;}
}class QiNiu {private String uptoken;private String key;public String getUptoken() {return uptoken;}public void setUptoken(String uptoken) {this.uptoken = uptoken;}public String getKey() {return key;}public void setKey(String key) {this.key = key;}
}
package com.durian.common.tool;import java.util.ResourceBundle;import org.apache.commons.lang3.StringUtils;/*** 从指定文件取值* * @author leng**/
public class ConfigUtils {/*** 从指定文件取值* * @param key* @param defaultValue* @param configName* @return*/public static String getString(String key, String defaultValue, String configName) {try {ResourceBundle rb2 = ResourceBundle.getBundle(configName);String str = rb2.getString(key).trim();if (StringUtils.isNotEmpty(str)) {return str;}} catch (Exception e) {// TODO: handle exception}return defaultValue;}/*** 从指定文件取值* * @param key* @param defaultValue* @param configName* @return*/public static Long getString(String key, Long defaultValue, String configName) {String str = getString(key, "", configName);if (StringUtils.isEmpty(str)) {return defaultValue;}return Long.parseLong(str);}
}

 

二.前端代码核心

(1)通过h5的canvas能力生成base64的图片编码

(2)获取签名

(3)将base64编码上传到七牛云(图中圈出的链接和七牛的服务器地域有关系)

这里window.opener.uploadCallback是我的页面回调。

 

前端代码:

链接:https://pan.baidu.com/s/1G6oPNwd8v2dpIcBN0QYtpg 
提取码:mvug 
复制这段内容后打开百度网盘手机App,操作更方便哦。

这篇关于前端图片裁剪并上传到七牛云kodo的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1058129

相关文章

在React中引入Tailwind CSS的完整指南

《在React中引入TailwindCSS的完整指南》在现代前端开发中,使用UI库可以显著提高开发效率,TailwindCSS是一个功能类优先的CSS框架,本文将详细介绍如何在Reac... 目录前言一、Tailwind css 简介二、创建 React 项目使用 Create React App 创建项目

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

Vue中组件之间传值的六种方式(完整版)

《Vue中组件之间传值的六种方式(完整版)》组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用,针对不同的使用场景,如何选择行之有效的通信方式... 目录前言方法一、props/$emit1.父组件向子组件传值2.子组件向父组件传值(通过事件形式)方

css中的 vertical-align与line-height作用详解

《css中的vertical-align与line-height作用详解》:本文主要介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,详细内容请阅读本文,希望能对你有所帮助... 目录vertical-ali

浅析CSS 中z - index属性的作用及在什么情况下会失效

《浅析CSS中z-index属性的作用及在什么情况下会失效》z-index属性用于控制元素的堆叠顺序,值越大,元素越显示在上层,它需要元素具有定位属性(如relative、absolute、fi... 目录1. z-index 属性的作用2. z-index 失效的情况2.1 元素没有定位属性2.2 元素处

Python实现html转png的完美方案介绍

《Python实现html转png的完美方案介绍》这篇文章主要为大家详细介绍了如何使用Python实现html转png功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 1.增强稳定性与错误处理建议使用三层异常捕获结构:try: with sync_playwright(