通过短链生成二维码并上传七牛云(Java)

前言

网上这种帖子其实也是很多,大部分搜出来的是CSDN的,然后点进去一看都几乎一样;所以这次给个自己实践的例子记录。

这次也是通过搜索得到的一部分能实现这个功能的代码,其实大体差不多,本地上传比较简单,但是上传服务器需要新的参数传递。

随笔最后再附上一些分享的内容


参考部分

1、首先通过传过来的长链接去生成短链,然后通过短链去生成二维码,将生成的二维码存储到七牛云,然后将图片地址存放到数据库中

2、生成二维码方式:

I.引用外部包qrcode.jar实现

II.以见最多的com.google.zxing这个包去实现

III.以Hutool这个工具包去实现(参见官网:https://www.hutool.cn/docs/#/)

3、参考文章

I.二维码生成并上传至七牛云 返回图片URL

II.Java使用QRCode.jar生成与解析二维码demo

III.Java 生成二维码上传第三方平台(详解)


长短链转换

这块的话网上解释较多实现也较为容易,在这提供一些参考内容

短链接服务系统开发:https://www.javadoop.com/post/url-shortener#toc_1

(最基本的实现方式,随机生成;具体去做这么一个模块的话,就得自己去写了,理是这么个理!)

Gitee参考开源代码:https://gitee.com/tinyframework/urlshorter


代码

生成二维码

在这里采取第二种方式实现(zxing包),当然也可以采用hutool工具包中的生成方法,它的生成方法也有很多种可以被我们使用。

pom.xml(部分代码)

   <!--七牛云-->
<dependency>
<groupId>com.qiniu</groupId>
<artifactId>qiniu-java-sdk</artifactId>
<version>7.2.9</version>
</dependency>
<!-- 二维码生成-->
<dependency>
<groupId>com.google.zxing</groupId>
<artifactId>core</artifactId>
<version>3.3.3</version>
</dependency> <dependency>
<groupId>com.google.zxing</groupId>
<artifactId>javase</artifactId>
<version>3.3.3</version>
</dependency>

QrCodeUtils.java(生成二维码)

import cn.hutool.extra.qrcode.QrCodeUtil;
import com.google.zxing.BarcodeFormat;
import com.google.zxing.EncodeHintType;
import com.google.zxing.MultiFormatWriter;
import com.google.zxing.WriterException;
import com.google.zxing.common.BitMatrix;
import net.liangyihui.shorturl.exception.ShortUrlException;
import org.apache.commons.lang3.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component; import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map; /**
* <p>
*
* </p>
*
* @author wenxin.du
* @since 2021/9/6
*/ @Component
public class QrCodeUtils { @Autowired
private static QiniuUploadUtils qiniuUploadUtils; private static final Logger logger = LoggerFactory.getLogger(QrCodeUtils.class); private static final int BLACK = 0xFF000000; private static final int WHITE = 0xFFFFFFFF; public String qrCodeCreate(String text) { Map<EncodeHintType, String> his = new HashMap<EncodeHintType, String>(); his.put(EncodeHintType.CHARACTER_SET, "utf-8");
try {
BitMatrix encode = new MultiFormatWriter().encode(text, BarcodeFormat.QR_CODE, 300, 300, his);
int codeWidth = encode.getWidth();
int codeHeight = encode.getHeight();
BufferedImage image = new BufferedImage(codeWidth, codeHeight, BufferedImage.TYPE_INT_RGB);
for (int i = 0; i < codeWidth; i++) {
for (int j = 0; j < codeHeight; j++) {
image.setRGB(i, j, encode.get(i, j) ? BLACK : WHITE);
}
}
image.flush();
ByteArrayOutputStream os = new ByteArrayOutputStream();
ImageIO.write(image, "jpg", os);
String result = qiniuUploadUtils.uploadFilesViaServer(os);
//通过七牛云工具类调用上传方法,将定义的这个流传给它
//返回结果通过定义一个参数接收,判断它是否空白,不是则返回结果给这个二维码创建方法
if (StringUtils.isNotBlank(result)) {
return result;
} else {
logger.info("QrCodeUtils.generateQrCodeThenUpload ======== 二维码生成错误,请稍后重试!========");
throw new ShortUrlException("二维码生成错误,请稍后重试!");
}
} catch (WriterException e) {
e.printStackTrace();
System.out.println("二维码生成失败");
} catch (IOException e) {
e.printStackTrace();
System.out.println("生成二维码图片失败");
}
return null;
}
}

AppConfig.java(采用配置文件方式)

import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component; @Component
public class AppConfig { @Value("${qiniu.access.key}")
private String QINIU_ACCESS_KEY; @Value("${qiniu.secret.key}")
private String QINIU_SECRET_KEY; @Value("${qiniu.bucket.key}")
private String QINIU_BUCKET_KEY; @Value("${qiniu.bucket.image.url}")
private String QINIU_BUCKET_IMAGE_URL; public String getQINIU_ACCESS_KEY() {
return QINIU_ACCESS_KEY;
} public String getQINIU_SECRET_KEY() {
return QINIU_SECRET_KEY;
} public String getQINIU_BUCKET_KEY() {
return QINIU_BUCKET_KEY;
} public String getQINIU_BUCKET_IMAGE_URL() {
return QINIU_BUCKET_IMAGE_URL;
}
}

application-dev.yml

## ---------------七牛相关配置,自行配置-----------------
qiniu:
access:
key:
secret:
key:
bucket:
key:
image.url:

QiniuUploadUtils.java(七牛云上传)

import com.google.gson.Gson;
import com.qiniu.common.QiniuException;
import com.qiniu.common.Zone;
import com.qiniu.http.Response;
import com.qiniu.storage.Configuration;
import com.qiniu.storage.UploadManager;
import com.qiniu.storage.model.DefaultPutRet;
import com.qiniu.util.Auth;
import net.liangyihui.shorturl.common.constant.AppConfig;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component; import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.InputStream;
import java.util.UUID; /**
* <p>
* 上传七牛云
* </p>
*
* @author wenxin.du
* @since 2021-09-07
*/
@Component
public class QiniuUploadUtils { @Autowired
private AppConfig appConfig; public String uploadFilesViaServer(ByteArrayOutputStream os) {
String retKey = "";
Configuration cfg = new Configuration(Zone.zone2());
UploadManager uploadManager = new UploadManager(cfg);
String uuid = UUID.randomUUID().toString();
String key = uuid.replace("-", "") + ".jpg";
Auth auth = Auth.create(appConfig.getQINIU_ACCESS_KEY(), appConfig.getQINIU_SECRET_KEY());
String upToken = auth.uploadToken(appConfig.getQINIU_BUCKET_KEY());
InputStream byteInputStream = new ByteArrayInputStream(os.toByteArray());
try {
Response response = uploadManager.put(byteInputStream, key, upToken, null, null);
DefaultPutRet putRet = new Gson().fromJson(response.bodyString(), DefaultPutRet.class);
System.out.println("key: " + appConfig.getQINIU_BUCKET_IMAGE_URL() + putRet.key);
System.out.println("hash: " + putRet.hash);
retKey = appConfig.getQINIU_BUCKET_IMAGE_URL() + putRet.key;
} catch (QiniuException ex) {
Response r = ex.response;
System.err.println(r.toString());
try {
System.err.println(r.bodyString());
} catch (QiniuException ex2) {
//ignore
}
}
return retKey;
}
}

数据库、controller层

像这两个层面就比较好办了,都是通过方法的调用去实现,不管是用的什么框架,只能说框架越流行越新,那它实现起来较为比以前的方式更为方便点。

个人感觉框架就是为了业务开发的方便性,以及解耦;但基础没打稳,框架只能是会用,但不知道原理,也体会不到框架的意义。


分享

也是在学习的时候,发现有些网站内容还不错,可以作为java学习的参考;还有就是以下没有打广告的嫌疑,毕竟人家也不需要我这种菜鸟打广告,只是单纯觉得好用!

程序员导航(有各类网站):http://tooool.org/

面试哥(各种资源贼全):http://www.mianshigee.com/

里面还有很多内容

帅地玩编程(一个比较不错面试问题集合):https://www.iamshuaidi.com/

JavaGuide(从B站上看到的,也算是自己长期看的一个网站了):https://snailclimb.gitee.io/javaguide/#/

也是一个学习网站:http://www.cyc2018.xyz/

学习网站加一:https://veal98.gitee.io/cs-wiki/#/README?id=公众号

一个人的博客(还可以):https://www.javadoop.com/

根据短链生成二维码并上传七牛云(Java)的更多相关文章

  1. PHP生成二维码并上传到七牛云

    参考资料 qr-code生成二维码    七牛云上传图片 实现步骤 //拿到插入后的id $res = DB::table('book_book')->insertGetId($data); i ...

  2. php 使用phpqrcode生成二维码并上传到OSS

    一般情况调用phpqrcode第三方插件 会把生成的二维码图片保存到服务器,不保存服务器也会以header头的形式输出到浏览器,(我们不允许把图片文件保存的liunx服务器,只能保存到阿里云OSS存储 ...

  3. 生成二维码 打上自定义logo

    private void RenderQrCode(string Code) { try { string level = "Q"; string url = ZConfig.Ge ...

  4. Java与JS生成二维码

    1.二维码概念 二维码/二维条码是用某种特定的集合图形按一定规律在平面上(二维方向上)分布的黑白相间的图形记录数据符号信息的图片. 黑线是二进制的1,空白的地方是二进制的0,通过1.0这种数据组合用于 ...

  5. java、python、golang等开发语言如何快速生成二维码?

    免费二维码生成途径非常多!比如比较有名的草料二维码,如果只是简单的使用,用它就足够了.但是如果想大规模的生成,那就不太合适了.再者很多工具都没办法在二维码中加入logo(像微信二维码一样). 接下来, ...

  6. Java中使用google.zxing快捷生成二维码(附工具类源码)

    移动互联网时代,基于手机端的各种活动扫码和收付款码层出不穷:那我们如何在Java中生成自己想要的二维码呢?下面就来讲讲在Java开发中使用 google.zxing 生成二维码. 一般情况下,Java ...

  7. Java生成二维码QRCode.jar

    所需jar包:QRCode.jar:http://download.csdn.net/detail/xuxu198899223/7717745 package ewm; import java.awt ...

  8. 使用google zxing生成二维码图片

    生成二维码工具类: 1 import java.awt.geom.AffineTransform; 2 import java.awt.image.AffineTransformOp; 3 impor ...

  9. Node.js在指定的图片模板上生成二维码图片并附带底部文字说明

    在Node.js中,我们可以通过qr-image包直接在后台生成二维码图片,使用方法很简单: var qr = require('qr-image'); exports.createQRImage = ...

随机推荐

  1. SpringData JPA 使用原生 SQL

    在实现个人博客系统的归档功能的时候,遇上这样的需求: 先把数据库中所有条目的时间按照年月分组,并查询出年月(String)的列表 根据年月字符串查询符合条件的博客,并返回博客列表 由于数据访问层使用的 ...

  2. Python 爬取 ajax 返回的数据

    1 from urllib.request import quote, unquote 2 import random 3 import requests 4 5 #quote 将单个字符串编码转化为 ...

  3. 判断Windows系统是32位或64位并执行不同脚本命令

    判断Windows系统是32位或64位并执行不同脚本命令 https://www.autoahk.com/?p=16549&preview=true https://www.cnblogs.c ...

  4. 键盘和鼠标闲置超时时关闭显示器并锁定电脑桌面的AutoHotkey脚本 2019年11月24日写

    /* 键盘和鼠标闲置超时时关闭显示器并锁定电脑桌面的AutoHotkey脚本 2019年11月24日写 在电脑桌面锁定时移动鼠标就会显示登录界面,此时即使超过电源设置的时间电脑也不会关闭显示器使得屏幕 ...

  5. Linux的链接(入门)

    Linux的链接分为两种:硬链接和软链接 硬链接:如果B是A的硬链接,那么B和A指向同一个文件,但是删除A并不会影响B->允许一个文件有多个路径 软链接:类似Windows下的快捷方式,删除原文 ...

  6. JIT in MegEngine

    作者:王彪 | 旷视框架部异构计算组工程师 一.背景 什么是天元 旷视天元(MegEngine)是一个深度学习框架,它主要包含训练和推理两方面内容.训练侧一般使用 Python 搭建网络:而推理侧考虑 ...

  7. Blazor 路由及导航开发指南

    翻译自 Waqas Anwar 2021年4月2日的文章 <A Developer's Guide To Blazor Routing and Navigation> [1] 检查传入的请 ...

  8. Windows影子用户创建与3389连接

    #当获得一条shell后,可以创建一个影子用户,通过影子用户可以行驶正常用户的所有权限与功能,并且只可在注册表中被检测出来---(应急响应注册表很重要) 1.首先需要拥有权限创建一个Administr ...

  9. STP进阶版MSTP

    一.MSTP简介 1.1.MSTP工作原理 mstp是一个公有生成树协议,在实际生产环境中得到了广泛的应用.传统的生成树只运行一个实例,且收敛速度慢,RSTP在传统的STP基础上通过改进达到了加速网络 ...

  10. Redis应用场景及缓存问题

    1.应用场景 (1)   缓存 缓存机制几乎在所有的大型网站都有使用,合理地使用缓存不仅可以加快数据的访问速度,而且能够有效地降低后端数据源的压力.Redis 提供了键值过期时间设置,并且也提供了灵活 ...