【SpringBoot】上传图片到图床


一、写在前面✨

大家好!我是初心,很高兴再次和大家见面。

今天跟大家分享的文章是 springboot如何实现上传图片至gitee图床 ,希望能帮助到大家!本篇文章收录于 初心安卓开发 专栏。

🏠 个人主页:初心%个人主页
🧑 个人简介:大家好,我是初心,和大家共同努力
💕欢迎大家:这里是CSDN,我记录知识的地方,喜欢的话请三连,有问题请私信😘

事情是这样的:希望将图片上传至一个图床,因为是自己学习使用,不想去付费申请一个,于是在网上了解到,可以使用Gitee作为图床。

但是,重要的事情我会在这里说清楚:

  • 使用Gitee作为图床的访问速度很慢
  • Gitee仓库必须是公开的,不能存放用户信息
  • 必须要有Gitee私人令牌,这个也是万万不可泄漏的,所以只能自己玩玩

因此,大家如果真的是在开发,生产环境中,切莫使用Gitee作为图床哦!

二、新建开源仓库✨

2.1 新建仓库

大家先去Gitee官网点我去往Gitee官网新建一个仓库,先设置为私有,因为空仓库不能是公开的。

2.2 将仓库设置为开源

进入到创建仓库成功页面后,点击初始化 readme 文件,这样仓库就不是空的了。

下面我们将仓库设置为公开,然后点击保存即可。

2.3 生产私人令牌

鼠标放在你的Gitee头像上,点击设置:

在这里插入图片描述

在安全设置中找到私人令牌,生产私人令牌,然后复制下来先保存到一个文件中:

三、代码实现😄

3.1 工具类

这里使用到了三个工具类,大体上实现了上传图片到Gitee的功能。

  • DateUtils
package com.itxiaoguo.utils;

import java.text.SimpleDateFormat;
import java.util.Date;

public class DateUtils {

    /**
     * 返回当前的年月字符串,示例:2021-08
     *
     * @return 年月字符串
     */
    public static String getYearMonth() {
        //yyyyMMdd
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM");
        return sdf.format(new Date());
    }
}

  • FileUtils
package com.itxiaoguo.utils;

public class FileUtils {

    /**
     * 获取文件名的后缀,如:changlu.jpg => .jpg
     *
     * @return 文件后缀名
     */
    public static String getFileSuffix(String fileName) {
        return fileName.contains(".") ? fileName.substring(fileName.indexOf('.')) : null;
    }
}

  • UploadGiteeImgBed
package com.itxiaoguo.utils;

import cn.hutool.core.codec.Base64;

import java.util.HashMap;
import java.util.Map;
import java.util.UUID;

/**
 * @ClassName 配置码云图床信息
 * @Author ChangLu
 * @Date 2021/7/30 21:38
 * @Description 上传Gitee图床工具类
 */
public class UploadGiteeImgBed {

    /**
     * 码云私人令牌
     */
    public static final String ACCESS_TOKEN = "";  //这里不展示我自己的了,需要你自己补充

    /**
     * 码云个人空间名,改成自己的,如果不知道个人空间名可以看下面的图片
     */
    public static final String OWNER = "guo-jing-hong";

    /**
     * 上传指定仓库,改成自己创建的图床仓库
     */
    public static final String REPO = "img";


    /**
     * 上传时指定存放图片路径
     */
    public static final String PATH = "/yuling/" + DateUtils.getYearMonth() + "/"; //使用到了日期工具类


    /**
     * 用于提交描述
     */
    public static final String ADD_MESSAGE = "add img";
    public static final String DEL_MESSAGE = "DEL img";

    //API
    /**
     * 新建(POST)、获取(GET)、删除(DELETE)文件:()中指的是使用对应的请求方式
     * %s =>仓库所属空间地址(企业、组织或个人的地址path)  (owner)
     * %s => 仓库路径(repo)
     * %s => 文件的路径(path)
     */
    public static final String API_CREATE_POST = "https://gitee.com/api/v5/repos/%s/%s/contents/%s";


    /**
     * 生成创建(获取、删除)的指定文件路径
     *
     * @param originalFilename
     * @return
     */
    public static String createUploadFileUrl(String originalFilename) {
        //获取文件后缀
        String suffix = FileUtils.getFileSuffix(originalFilename);//使用到了自己编写的FileUtils工具类
        //拼接存储的图片名称
        String fileName = System.currentTimeMillis() + "_" + UUID.randomUUID().toString() + suffix;
        //填充请求路径
        String url = String.format(UploadGiteeImgBed.API_CREATE_POST,
                UploadGiteeImgBed.OWNER,
                UploadGiteeImgBed.REPO,
                UploadGiteeImgBed.PATH + fileName);
        return url;
    }

    /**
     * 获取创建文件的请求体map集合:access_token、message、content
     *
     * @param multipartFile 文件字节数组
     * @return 封装成map的请求体集合
     */
    public static Map<String, Object> getUploadBodyMap(byte[] multipartFile) {
        HashMap<String, Object> bodyMap = new HashMap<>(3);
        bodyMap.put("access_token", UploadGiteeImgBed.ACCESS_TOKEN);
        bodyMap.put("message", UploadGiteeImgBed.ADD_MESSAGE);
        bodyMap.put("content", Base64.encode(multipartFile));
        return bodyMap;
    }

}

个人空间名的查看:

3.2 上传图片

这里使用的是SpringMVC的Controller上传,需要注意@RequestParam(“file”)的值也就是‘file’要和前端保持一致哦!

package com.itxiaoguo.controller;

import cn.hutool.http.HttpUtil;
import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil;
import com.itxiaoguo.utils.UploadGiteeImgBed;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;

import java.io.IOException;
import java.util.Map;

@RestController
@Slf4j
public class UploadController {

    /**
     * 上传图片
     *
     * @param multipartFile 文件对象
     * @return
     * @throws IOException
     */
    @PostMapping("/uploadImg")
    public String uploadImg(@RequestParam("file") MultipartFile multipartFile) throws IOException {
        //根据文件名生成指定的请求url
        String originalFilename = multipartFile.getOriginalFilename();
        if (originalFilename == null) {
            return "文件不存在";
        }
        String targetURL = UploadGiteeImgBed.createUploadFileUrl(originalFilename);
        log.info("目标url:" + targetURL);
        //请求体封装
        Map<String, Object> uploadBodyMap = UploadGiteeImgBed.getUploadBodyMap(multipartFile.getBytes());
        //借助HttpUtil工具类发送POST请求
        System.out.println(targetURL);
        String JSONResult = HttpUtil.post(targetURL, uploadBodyMap);
        //解析响应JSON字符串
        JSONObject jsonObj = JSONUtil.parseObj(JSONResult);
        //请求失败
        if (jsonObj == null || jsonObj.getObj("commit") == null) {
            return "请求失败";
        }
        //请求成功:返回下载地址
        JSONObject content = JSONUtil.parseObj(jsonObj.getObj("content"));
        System.out.println(content.getObj("download_url"));
        return "成功";
    }

}

最后启动SpringBoot项目,前端上传图片即可将图片上传至Gitee图床啦!

四、总结撒花😊

本文主要讲解了使用了SpringBoot的项目中如何上传图片到Gitee图床中,个人认为仅供娱乐一下,闲来无趣,不能用于实际开发中使用。😊

这就是今天要分享给大家的全部内容了,我们下期再见!😊

  • 38
    点赞
  • 40
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 35
    评论
#### 快速运行 ##### 准备工作 ```shell JDK >= 1.8 (推荐1.8版本) Maven >= 3.0 ``` ##### 修改配置 application.yml文件 ```shell aliyun: config: ossEndPoint: 您自己的地域节点 accessKeyId: 您阿里云的accessKeyId accessKeySecret: 您阿里云的accessKeyId sina: username: 您的新浪账户名称 password:您的新浪账号密码 ``` uploadController.java ```shell //文件存储目录 private String filedir = "***/"; // bucket名称 private String bucketName = "***"; // 外网访问http头 private String httpPath = "***"; ``` 执行ImgbedApplication的Main方法即可启动 #### Todo - 优化页面 - 增加鉴黄接口(如果找到免费接口的话) - 增加其他免费图床接口进行图片分发 #### 演示图 ![](https://webug.oss-cn-beijing.aliyuncs.com/imgBed/20190111025700461.png) #### 最新更新 - 通过SessionId进行简单的文件重复校验 - 优化调整页面 - 接入新浪图床进行图片分发 - 加入docker化部署方案 具体部署文档见:[文档](src/main/doc/docker部署.md) ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。
使用springboot做基础框架,提供简单页面做图片上传,接口直接模拟微博登陆,上传完成后返回图片保存链接 public String getSinaCookies() { String base64name = Base64Utils.encodeToString(username.getBytes()); String loginUrl = "https://login.sina.com.cn/sso/login.php?client=ssologin.js(v1.4.15)&_=1403138799543"; String params = "entry=sso&gateway=1&from=null&savestate=30&useticket=0&pagerefer;=&vsnf=1&su;=" + base64name; params += "&service=sso&sp;=" + password + "&sr=1920*1080&encoding=UTF-8&cdult=3&domain=sina.com.cn&prelt=0&returntype=TEXT"; //登录 try { URL url = new URL(loginUrl); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setDoInput(true); conn.setDoOutput(true); conn.setRequestMethod("POST"); OutputStream out = conn.getOutputStream(); out.write(params.getBytes()); out.flush(); out.close(); String sessionId = ""; String cookieVal = ""; String key = null; //取cookie for (int i = 1; (key = conn.getHeaderFieldKey(i)) != null; i++) { if (key.equalsIgnoreCase("set-cookie")) { cookieVal = conn.getHeaderField(i); cookieVal = cookieVal.substring(0, cookieVal.indexOf(";")); sessionId = sessionId + cookieVal + ";"; } } if (sessionId != null) { String[] cookiearr = sessionId.split(";"); for (int i = 0; i < cookiearr.length; i++) { if (cookiearr[i].startsWith("SUB") && !cookiearr[i].startsWith("SUBP")) { sessionId = cookiearr[i] + ";"; } } } return sessionId; } catch (Exception e) { e.printStackTrace(); return null; } }

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

向阳花花花花

感谢大佬支持,本人会继续努力哒

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值