java前端传base64,后台转成文件并存储的实现

 更新时间:2026年02月04日 17:28:54   作者:果仁栗子糕  
文章介绍了如何实现一个单独的H5页面用于手绘签名并上传服务器,包括如何从扫码跳转的链接中截取参数以及如何将字节码转换为文件上传

需求

单独的H5页面实现手绘签名,然后上传服务器,并修改数据,首先项目中是扫码跳转到H5页面,那链接中需要带参数,怎么截取参数?

下面是截取路径,获得值

var varurl = window.location.search; //获取url中"?"符后的字串
                if (varurl.indexOf("?") != -1) { //判断是否有参数
                    varstr = varurl.substr(1); //从第一个字符开始 因为第0个是?号 获取所有除问号的所有符串
                    var strs = varstr.split("="); //用等号进行分隔 (因为知道只有一个参数 所以直接用等号进分隔 如果有多个参数 要用&号分隔 再用等号进行分隔)
                    console.log(strs[1]); //直接弹出第一个参数 (如果有多个参数 还要进行循环的)
                    id = strs[1];
                }

后台接受字节码并转换成文件上传

@RequestMapping(value = "/uploadBase64", method = {RequestMethod.POST})
    @ResponseBody
    public Object uploadBase64(HttpServletRequest request, HttpServletResponse response) throws Exception {
        String base64String = request.getParameter("signatureBase64");
        if (StringUtils.isBlank(base64String)) {
            return new JsonResult(false, "上传失败", "");
        }
        logger.info("======开始上传图片======");
        String imgUrl = "";
        String msg = "";
        Boolean result = false;
        MultipartFile file = Base64DecodMultipartFileUtil.base64ToMultipart(base64String);
        if (Objects.nonNull(file)) {
            try {
                String path = getCompleteImgPath(request, file);
                imgUrl = path.replace("\\", "/");
                result = true;
                msg = SysCode.SUCCESS.getDesc();
                logger.info("======图片上传成功,路径======" + path.replace("\\", "/"));
            } catch (Exception e) {
                logger.error("图片上传失败:" + e.getMessage(), e);
                e.printStackTrace();
                msg = "上传失败!";
            }
        } else {
            logger.error("图片上传失败");
        }
        logger.info("======图片上传结束======");
        return new JsonResult(result, msg, imgUrl);

    }

//base64转文件
public static MultipartFile base64ToMultipart(String base64) {
   try {
      String[] baseStrs = base64.split(",");
      BASE64Decoder decoder = new BASE64Decoder();
      byte[] b = new byte[0];
      b = decoder.decodeBuffer(baseStrs[1]);
      for (int i = 0; i < b.length; ++i) {
         if (b[i] < 0) {
            b[i] += 256;
         }
      }
      return new Base64DecodMultipartFileUtil(b, baseStrs[0]);
   } catch (IOException e) {
      e.printStackTrace();
      return null;
   }
}
//获取文件路径
public static String getCompleteFilePath(HttpServletRequest request, MultipartFile uploadFile) throws Exception {
    String logoPathDir = SysConstants.TOMCAT_FILE_URL;
    /**
     * 得到文件保存目录的真实路径
     */
    String logoRealPathDir = request.getSession().getServletContext().getRealPath(logoPathDir);
    /**
     * 根据真实路径创建目录
     */
    File logoSaveFile = new File(logoRealPathDir);
    if (!logoSaveFile.exists()) {
        logoSaveFile.mkdirs();
    }
    /**
     * 获取文件的后缀
     */
    System.out.println(uploadFile.getOriginalFilename());
    String suffix = uploadFile.getOriginalFilename().substring(uploadFile.getOriginalFilename().lastIndexOf("."));
    /**
     * 使用UUID生成文件名称
     */
    String imageName = RandomUtil.getUuid() + suffix;// 构建文件名称
    /**
     * 拼成完整的文件保存路径加文件
     */
    String fileName = logoRealPathDir + File.separator + imageName;
    File file = new File(fileName);
    uploadFile.transferTo(file);

    FileChannel in = null;
    FileChannel out = null;
    FileInputStream inStream = null;
    FileOutputStream outStream = null;
    try {
        inStream = new FileInputStream(file);
        outStream = new FileOutputStream(PathUtil.getImgBasePath() + File.separator + imageName);
        in = inStream.getChannel();
        out = outStream.getChannel();
        in.transferTo(0, in.size(), out);
    } catch (IOException e) {
        e.printStackTrace();
    } finally {
        inStream.close();
        in.close();
        outStream.close();
        out.close();
    }
    return PathUtil.getImgPath(imageName);
}

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • java获取linux服务器上的IP操作

    java获取linux服务器上的IP操作

    这篇文章主要介绍了java获取linux服务器上的IP操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • java项目如何引入其他jar包

    java项目如何引入其他jar包

    通常在lib文件夹中存放从外部引入的jar包,所以把JAR文件复制进去。 然后修改编译脚本,不需要去编译tool文件夹里面的java类,直接把jar包添加到classpath,下文将详细介绍
    2021-10-10
  • Java 什么是注解及注解原理详细介绍

    Java 什么是注解及注解原理详细介绍

    这篇文章主要介绍了Java 注解的原理实例详解的相关资料,需要的朋友可以参考下
    2016-12-12
  • Java 反射修改类的常量值、静态变量值、属性值实例详解

    Java 反射修改类的常量值、静态变量值、属性值实例详解

    在本篇文章里小编给大家整理的是一篇关于Java 反射修改类的常量值、静态变量值、属性值实例详解内容,有兴趣的读者们可以跟着学习下。
    2021-01-01
  • 详解mybatis 批量更新数据两种方法效率对比

    详解mybatis 批量更新数据两种方法效率对比

    这篇文章主要介绍了详解mybatis 批量更新数据两种方法效率对比,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-02-02
  • Java实现本地缓存的常用方案介绍

    Java实现本地缓存的常用方案介绍

    本地缓存的代表技术主要有HashMap,Guava Cache,Caffeine和Encahche,这篇文章主要来和大家聊聊java利用这些技术分别实现本地缓存的方法,有需要的可以了解下
    2025-05-05
  • Java Spring事务的隔离级别详解

    Java Spring事务的隔离级别详解

    这篇文章主要介绍了Java Spring事务的隔离级别,分享了相关代码示例,小编觉得还是挺不错的,具有一定借鉴价值,需要的朋友可以参考下
    2021-10-10
  • Maven的国内镜像(快速解决jar下载过慢的问题)

    Maven的国内镜像(快速解决jar下载过慢的问题)

    下面小编就为大家带来一篇Maven的国内镜像(快速解决jar下载过慢的问题)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • Spring使用@responseBody与序列化详解

    Spring使用@responseBody与序列化详解

    这篇文章主要介绍了Spring使用@responseBody与序列化详解,@responseBody注解的作用是将controller的方法返回的对象通过适当的转换器转换为指定的格式之后,写入到response对象的body区,通常用来返回JSON数据或者是XML数据,需要的朋友可以参考下
    2023-08-08
  • JAVA StringBuffer类与StringTokenizer类代码解析

    JAVA StringBuffer类与StringTokenizer类代码解析

    这篇文章主要介绍了JAVA StringBuffer类与StringTokenizer类代码解析,具有一定借鉴价值,需要的朋友可以参考下
    2018-01-01

最新评论