SpringBoot-13-插曲之Node文件重命名+自动生成json对象

简介: 遇到的问题:图片太多,使用起来挺麻烦[1]有很多图片放服务器里,怎么能更好的管理,更方便拿到图片呢?[2]想用json 以一个对象数组的形式保存这些图片:以[{img:"图片名"},{img:"图片名"}....]形式[3]虽说想法是很好,但不可能一条一条自己写吧,好歹咱也是21世纪敲代码的人。

遇到的问题:图片太多,使用起来挺麻烦

[1]有很多图片放服务器里,怎么能更好的管理,更方便拿到图片呢?
[2]想用json 以一个对象数组的形式保存这些图片:以[{img:"图片名"},{img:"图片名"}....]形式
[3]虽说想法是很好,但不可能一条一条自己写吧,好歹咱也是21世纪敲代码的人。
[4]刚好最近学了点node,就拿来小试牛刀。
图片
const fs = require('fs');
const path = require('path');

let result = read('F:/SpringBootFiles/Image');
function read(pathName) {
    let objs = [];
    //读取路径,返回所有文件节点=文件夹+文件
    let filePath = "F:/SpringBootFiles/Image/img.json";//输出路径
    fs.readdir(pathName, (err, files) => {//读文件夹
        for (let file of files) {//遍历文件
            let oldName = path.join('F:/SpringBootFiles/Image', file);//文件旧路径
            let extname = path.extname(file);//文件后缀名
            let basename = path.basename(file,extname);//文件名除去后缀(这里没有到,提一下)
            let newName = rangeChar(16, true) + extname;//新名称,随机获取16个字符
            fs.rename(oldName, path.join('F:/SpringBootFiles/Image', newName), err => {});//重命名

            let obj = {};//定义对象
            obj.img = newName;//该对象img属性为新文件名称
            objs.push(obj);//将对象添到数组中
        }

        fs.writeFileSync(filePath, JSON.stringify(objs), {encoding: 'utf8'})//写入数据
    });

一开始想把乱七八糟的名字都给弄的整齐点,打算用时间戳,但程序跑太快,重名文件就给覆盖了,没办法,写两个函数随机生成任意字符串吧,16个任意大小写字母de组合应该差不多了。这两个函数还挺好用,生成随机字符串。

    function rangeChar(len, hasBig = false) {
        let allLen = 25;
        let chars = ["a", "b", "c", "d", "e", "f", "g",
            "h", "i", "j", "k", "l", "m", "n",
            "o", "p", "q", "r", "s", "t",
            "u", "v", "w", "x", "y", "z"];
        let charsBig = chars.map(item => item.toUpperCase());

        if (hasBig) {
            chars = chars.concat(charsBig);
            allLen = 49;
        }
        let result = [];
        for (let i = 0; i < len; i++) {
            let char = chars[rangeInt(0, allLen)];
            result.push(char);
        }
        return result.join('');
    };

    function rangeInt(s, e) {
        let max = Math.max(s, e);
        let min = Math.min(s, e) - 1;
        return min + Math.ceil(Math.random() * (max - min));
    };

我的springboot已经将访问路径定位到F:/SpringBootFiles/Image文件夹下,访问是成功的,有了json,有了图片名,Ajax拿到数据,加上域名就能用了,不管有几千张,几万张图片,执行一下命令,轻松搞定。

json数据.png
拿到图片路径.png
相关文章
|
7月前
|
XML Java Maven
springboot-多环境配置文件
本文介绍了如何创建开发和生产环境的配置文件,并在IDEA和Maven中进行配置。开发环境中,通过设置profile为`dev`来指定配置文件;生产环境中,使用Maven命令参数`-Pprod`打包并指定配置文件。公共配置可放在`application.yml`中统一管理。日志配置需确保`logback-spring.xml`中的profile正确,以保证日志正常输出。
353 4
springboot-多环境配置文件
|
8月前
|
存储 前端开发 Java
Springboot静态资源映射及文件映射
在Spring Boot项目中,为了解决前端访问后端存储的图片问题,起初尝试通过静态资源映射实现,但发现这种方式仅能访问打包时已存在的文件。对于动态上传的图片(如头像),需采用资源映射配置,将特定路径映射到服务器上的文件夹,确保新上传的图片能即时访问。例如,通过`addResourceHandler(&quot;/img/**&quot;).addResourceLocations(&quot;file:E:\\myProject\\forum_server\\&quot;)`配置,使前端可通过URL直接访问图片。
438 0
Springboot静态资源映射及文件映射
|
4月前
|
JSON IDE Java
鸿蒙开发:json转对象插件回来了
首先,我重新编译了插件,进行了上传,大家可以下载最新的安装包进行体验了,还是和以前一样,提供了在线版和IDE插件版,两个选择,最新的版本,除了升级了版本,兼容了最新的DevEco Studio ,还做了一层优化,就是针对嵌套对象和属性的生成,使用方式呢,一年前的文章中有过详细的概述,这里呢也简单介绍一下。
148 4
鸿蒙开发:json转对象插件回来了
|
7月前
|
前端开发 Cloud Native Java
Java||Springboot读取本地目录的文件和文件结构,读取服务器文档目录数据供前端渲染的API实现
博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
Java||Springboot读取本地目录的文件和文件结构,读取服务器文档目录数据供前端渲染的API实现
|
11月前
|
网络协议 Java
springboot配置hosts文件
springboot配置hosts文件
161 11
|
11月前
|
存储 前端开发 JavaScript
|
11月前
|
存储 Java API
|
10月前
|
XML 安全 Java
Spring Boot中使用MapStruct进行对象映射
本文介绍如何在Spring Boot项目中使用MapStruct进行对象映射,探讨其性能高效、类型安全及易于集成等优势,并详细说明添加MapStruct依赖的步骤。
425 0
|
JSON 数据格式 fastjson
JsonNode、JsonObject常用方法
JsonNode、JsonObject常用方法 最近项目中要用json,闲暇时间,对json进行下总结。 1.JsonNode 项目中用到的jar包 import com.
7641 0
|
3月前
|
JavaScript Unix Linux
nvm与node.js的安装指南
通过以上步骤,你可以在各种操作系统上成功安装NVM和Node.js,从而在不同的项目中灵活切换Node.js版本。这种灵活性对于管理不同项目的环境依赖而言是非常重要的。
815 11