文件和base64互转

文件转base64


	<body>
		<input type="file" name="" id="file" value="" />
		<script>
			$("#file").change(function(e) {
				var file = document.getElementById("file").files[0];
				reader.readAsDataURL(file);
			})
			var reader = new FileReader();
			reader.onload = function(e) {
				var base64 = e.target.result;
				console.log(base64)
			};
		</script>
	</body>

base64转文件


			/**
			 * @name: 生成下载路径
			 * @param {String} fileName 文件名称
			 * @param {String} file base64字符串
			 * @return: 下载路径url
			 */
			//将base64转换为文件
			 var filename = "1";
			 var base64 = ""// 文件转出来的base64
			function dataURLtoFile(dataurl, filename) { // 生成Blob
		 	  var arr = dataurl.split(',');
		 	  var mime = arr[0].match(/:(.*?);/)[1];
		 	  var bstr = atob(arr[1]);
		 	  var n = bstr.length;
		 	  var u8arr = new Uint8Array(n);
		 	  while (n--) {
		 	    u8arr[n] = bstr.charCodeAt(n);
		 	  }
		 	  return new Blob([u8arr], { type: mime });
		 	}
			function createDownloadFileUrl(fileName, file) {
			  const blob = this.dataURLtoFile(file, fileName); // application/zip 需要改成要下载文件的类型
			  blob.lastModifiedDate = new Date();
			  blob.name = fileName;
			  return URL.createObjectURL(blob);
			}
			console.log(createDownloadFileUrl(filename, base64))// 转出来是blob地址
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值