如何检测数据URL

时间:2018-01-26 05:18:12

标签: javascript base64 data-url

我正在开发一个角度4应用程序。我有一个base64编码的图像。我用node.js将它保存在文件系统中。

 if (body.profilepic != "") {
            let base64Data = body.profilepic.split(';base64,').pop();

            fs.writeFile("out.png", base64Data, 'base64', function(err) {
                if (!err) {
                    console.log("saved file")
                }
            });
        }

问题是我无法检测到我保存的图像的文件类型。现在它只保存pngs。

如何检测我收到的图片字符串的文件类型?

我得到的base64编码字符串是这样的:



6 个答案:

答案 0 :(得分:5)

您不需要正则表达式或任何花哨的东西。

dataUrl具有非常可预测的格式,我们知道mime将会在一开始。因此,最好停在“:”和“;”的第一个出现处。

dataUrl = ".."
dataUrl.substring(dataUrl.indexOf(":")+1, dataUrl.indexOf(";"))  // => image/png

答案 1 :(得分:1)

从完整的base64内容中提取内容(MIME)类型。



mix
  .js('resources/assets/js/app.js', 'public/js')
  .extract([
    'lodash', 'jquery', 'vue', 'query-string',
    'datatables.net', 'datatables.net-buttons', 'datatables.net-bs4', 'datatables.net-buttons-bs4', 'datatables.net-buttons/js/buttons.html5.js',
    'select2', 'axios', 'moment', 'popper.js', 'bootstrap', 'vue-chartjs', 'v-tooltip', 'moment/locale/es', 'vue-moment',
    'jszip/dist/jszip', 'pdfmake/build/pdfmake.js', 'pdfmake/build/vfs_fonts.js', 'sweetalert', 'vue-strap', 'vue-strap/dist/vue-strap-lang',
    'moment-array-dates', 'vue-toast', 'randomcolor', 'url', 'google-maps'
  ])
  .sass('resources/assets/sass/app.scss', 'public/css')
  .copy('node_modules/font-awesome/fonts', 'public/fonts/vendor/font-awesome');

if (mix.inProduction()) {
  mix.version();
}




答案 2 :(得分:0)

您可以使用RegExp /[^:]\w+\/[\w-+\d.]+(?=;|,)/来匹配前面带有:的一个或多个单词字符,然后是/,后跟字符集中的一个或多个单词字符包括-字符来处理application/octet-stream+来处理image/svg+xml\d来处理application/x-7z-compressed.来处理application/vnd.apple.mpegurl来处理; 1}}后跟,base64字符,以处理data URL

中未包含的const body = {profilepic:""}; let mimeType = body.profilepic.match(/[^:]\w+\/[\w-+\d.]+(?=;|,)/)[0]; console.log(mimeType);

{{1}}

答案 3 :(得分:0)

const obj = /data:(.*);base64,(.*)/.exec('');

console.log('Content Type: ' + obj[1]);
console.log('Base64 data: ' + obj[2]);

或来自IMG标签:

const obj = /<img.*src="data:(.*);base64,(.*?)"/.exec('<img src="" />');

console.log('Content Type: ' + obj[1]);
console.log('Base64 data: ' + obj[2]);

答案 4 :(得分:-1)

如果您想获得像(image / png),(image / jpg)这样的Mime类型,请使用此

const body = {profilepic:""};
let mimeType = body.profilepic.match(/[^:]\w+\/[\w-+\d.]+(?=;|,)/)[0];

online Demo here

=========================================

如果您只想获取它的类型,例如(png,jpg)等

const body2 = {profilepic:""};
let mimeType2 = body2.profilepic.match(/[^:/]\w+(?=;|,)/)[0];

online Demo here

答案 5 :(得分:-3)

substringindexOf

一起使用
var ex = string.substring("data:image/".length, string.indexOf(";base64"))

Demo