Skip to content

Instantly share code, notes, and snippets.

@ManfredHu
Last active July 24, 2021 07:24
Show Gist options
  • Save ManfredHu/33ac35e5ea3856f616c498d3e6d5ba2e to your computer and use it in GitHub Desktop.
Save ManfredHu/33ac35e5ea3856f616c498d3e6d5ba2e to your computer and use it in GitHub Desktop.
base64 to image,兼容各种svg,png,jpeg,jpg,webp,gif
import fs from 'fs'
// 转化Data URI scheme to image file
const typeToExtName: Record<string, string> = {
'jpeg': '.jpeg',
'jpg': '.jpg',
'png': '.png',
'svg+xml': '.svg',
'gif': '.gif',
'webp': '.webp'
}
async function main() {
// -----jpeg 格式
const strJpeg = `data:image/jpeg;base64,
/9j/4AAQSkZJRgABAQEAYABgAAD/2wBDADIiJSwlHzIsKSw4NTI7S31RS0VFS5ltc1p9tZ++u7Kf
r6zI4f/zyNT/16yv+v/9////////wfD/////////////2wBDATU4OEtCS5NRUZP/zq/O////////
////////////////////////////////////////////////////////////wAARCAAYAEADAREA
AhEBAxEB/8QAGQAAAgMBAAAAAAAAAAAAAAAAAQMAAgQF/8QAJRABAAIBBAEEAgMAAAAAAAAAAQIR
AAMSITEEEyJBgTORUWFx/8QAFAEBAAAAAAAAAAAAAAAAAAAAAP/EABQRAQAAAAAAAAAAAAAAAAAA
AAD/2gAMAwEAAhEDEQA/AOgM52xQDrjvAV5Xv0vfKUALlTQfeBm0HThMNHXkL0Lw/swN5qgA8yT4
MCS1OEOJV8mBz9Z05yfW8iSx7p4j+jA1aD6Wj7ZMzstsfvAas4UyRHvjrAkC9KhpLMClQntlqFc2
X1gUj4viwVObKrddH9YDoHvuujAEuNV+bLwFS8XxdSr+Cq3Vf+4F5RgQl6ZR2p1eAzU/HX80YBYy
JLCuexwJCO2O1bwCRidAfWBSctswbI12GAJT3yiwFR7+MBjGK2g/WAJR3FdF84E2rK5VR0YH/9k=`
const strJpg = `data:image/jpg;base64,
/9j/4AAQSkZJRgABAQEAYABgAAD/2wBDADIiJSwlHzIsKSw4NTI7S31RS0VFS5ltc1p9tZ++u7Kf
r6zI4f/zyNT/16yv+v/9////////wfD/////////////2wBDATU4OEtCS5NRUZP/zq/O////////
////////////////////////////////////////////////////////////wAARCAAYAEADAREA
AhEBAxEB/8QAGQAAAgMBAAAAAAAAAAAAAAAAAQMAAgQF/8QAJRABAAIBBAEEAgMAAAAAAAAAAQIR
AAMSITEEEyJBgTORUWFx/8QAFAEBAAAAAAAAAAAAAAAAAAAAAP/EABQRAQAAAAAAAAAAAAAAAAAA
AAD/2gAMAwEAAhEDEQA/AOgM52xQDrjvAV5Xv0vfKUALlTQfeBm0HThMNHXkL0Lw/swN5qgA8yT4
MCS1OEOJV8mBz9Z05yfW8iSx7p4j+jA1aD6Wj7ZMzstsfvAas4UyRHvjrAkC9KhpLMClQntlqFc2
X1gUj4viwVObKrddH9YDoHvuujAEuNV+bLwFS8XxdSr+Cq3Vf+4F5RgQl6ZR2p1eAzU/HX80YBYy
JLCuexwJCO2O1bwCRidAfWBSctswbI12GAJT3yiwFR7+MBjGK2g/WAJR3FdF84E2rK5VR0YH/9k=`
// -----png 格式
const strPng = ``
// -----gif 格式
const strGif = ``
// -----webp 格式(小程序暂时只支持网络资源的webp
const strWebp = ``
// -----svg 格式
const strSvg = `data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E %3Cpath fill-opacity='.9' fill-rule='evenodd' d='M5 10.25a1.75 1.75 0 1 1 0 3.5 1.75 1.75 0 0 1 0-3.5zm7 0a1.75 1.75 0 1 1 0 3.5 1.75 1.75 0 0 1 0-3.5zm7 0a1.75 1.75 0 1 1 0 3.5 1.75 1.75 0 0 1 0-3.5z'/%3E%3C/svg%3E`
const strSvgNotCharset = `data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E %3Cpath fill-opacity='.9' fill-rule='evenodd' d='M5 10.25a1.75 1.75 0 1 1 0 3.5 1.75 1.75 0 0 1 0-3.5zm7 0a1.75 1.75 0 1 1 0 3.5 1.75 1.75 0 0 1 0-3.5zm7 0a1.75 1.75 0 1 1 0 3.5 1.75 1.75 0 0 1 0-3.5z'/%3E%3C/svg%3E`
const strSvgNotEncode = `data:image/svg+xml;utf8,<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="200" height="200" viewBox="0 0 200 200"><path fill="#00A5E0" d="M145.659,68.949c-5.101-5.208-13.372-5.208-18.473,0L99.479,97.233 L71.772,68.949c-5.1-5.208-13.371-5.208-18.473,0c-5.099,5.208-5.099,13.648,0,18.857l46.18,47.14l46.181-47.14 C150.759,82.598,150.759,74.157,145.659,68.949z"/></svg>`
const strSvg2 = ``
const handleFiles = [
strJpeg,
strJpg,
strPng,
strGif,
strWebp,
strSvg,
strSvgNotCharset,
strSvgNotEncode,
strSvg2
]
const regExp = /data:image\/([^,;]+);?([^,]*),/
for (const [index, item] of handleFiles.entries()) {
const str = item.replace(/\n\s+/g, '')
console.log(`str`, str)
const matchReg = regExp.exec(str)
// console.log(`matchReg`, matchReg)
if (matchReg) {
const type = matchReg[1]
console.log(`type`, type, index)
const newContent = str.replace(matchReg[0], '')
console.log(`newContent`, newContent)
console.log(`is base64`, matchReg[2].includes('base64'))
if (matchReg[2]?.includes('base64')) {
console.log(`write file`, `./${index}${typeToExtName[type]}`, newContent)
fs.writeFileSync(`./${index}${typeToExtName[type]}`, newContent, 'base64')
} else if (typeToExtName[type]) {
console.log(`write file`, `./${index}${typeToExtName[type]}`, newContent)
fs.writeFileSync(`./${index}${typeToExtName[type]}`, decodeURI(newContent), 'utf8')
} else {
console.error('can not handle', index, newContent, type)
}
} else {
console.error(`match error`, regExp, str)
}
}
}
main()
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment