vue引入sm-crypto通过sm4对文件进行加解密,用户输入密码

对文件加密并保存:

javascript 复制代码
import { sm4 } from 'sm-crypto'

fetch("你的文件地址") .then(response => response.blob()) .then(byteStream => {
        const reader2 = new FileReader();
        reader2.onload = function(event) {
            const arrayBuffer = event.target.result;
            let keyBytes = new Uint8Array(arrayBuffer);
            let password = stringToHex("用户输入的密码");
            let code = sm4.encrypt(keyBytes,password, {output: 'array'})  
            let byteStream1 = new Blob([code], { type: 'application/octet-stream' });
            let link = document.createElement('a');
            link.href = URL.createObjectURL(byteStream1);
            link.download = "你保存的文件名";
            document.body.appendChild(link);
            link.click();
            document.body.removeChild(link);
        };
        // 以ArrayBuffer形式读取文件
        reader2.readAsArrayBuffer(byteStream);
      })
	function stringToHex(str) {
	  let hex = '';
	  for (let i = 0; i < str.length; i++) {
	    hex += str.charCodeAt(i).toString(16);
	  }
	  // 如果转换后的16进制字符串长度不足32,则在前面填充0
	  while (hex.length < 32) {
	    hex = '0' + hex;
	  }
	  return hex;
	}

读取文件并解密:

javascript 复制代码
<input type="file" id="keyInput" accept="*" @change="readKeyFile" />

function readKeyFile() {
	    const keyInput = document.getElementById('keyInput');
	    const file = keyInput.files[0];
	    const reader = new FileReader();
	    reader.onload = function(event) {
	        const arrayBuffer = event.target.result;
	        let plainByte = JSON.parse("["+arrayBuffer+"]");
	        let password = stringToHex("用户输入的密码");
	        try{
	        	let pBytes = sm4.decrypt(plainByte,password, {output: 'array'});
	        	let prBytes = arrayToBuffer(pBytes);
	        	privateKeyBytes = new Uint8Array(prBytes);
	        }catch(e){
	        	alert('文件或密码错误');
	        	return;
	        }
			let decoder = new TextDecoder();
		    let alltext = decoder.decode(privateKeyBytes);
            console.log(alltext)//你的文件内容
	    };
	    // 读取文件
	    reader.readAsText(file);
	}
function stringToHex(str) {
    let hex = '';
    for (let i = 0; i < str.length; i++) {
      hex += str.charCodeAt(i).toString(16);
    }
    // 如果转换后的16进制字符串长度不足32,则在前面填充0
    while (hex.length < 32) {
      hex = '0' + hex;
    }
    return hex;
  }
  function arrayToBuffer(arr) {
      let buffer = new ArrayBuffer(arr.length);
      let view = new Uint8Array(buffer);
      for (let i = 0; i < arr.length; i++) {
          view[i] = arr[i];
      }
      return buffer;
  }
相关推荐
_r0bin_23 分钟前
前端面试准备-7
开发语言·前端·javascript·fetch·跨域·class
IT瘾君24 分钟前
JavaWeb:前端工程化-Vue
前端·javascript·vue.js
zhang988000024 分钟前
JavaScript 核心原理深度解析-不停留于表面的VUE等的使用!
开发语言·javascript·vue.js
potender26 分钟前
前端框架Vue
前端·vue.js·前端框架
站在风口的猪11081 小时前
《前端面试题:CSS预处理器(Sass、Less等)》
前端·css·html·less·css3·sass·html5
程序员的世界你不懂1 小时前
(9)-Fiddler抓包-Fiddler如何设置捕获Https会话
前端·https·fiddler
MoFe12 小时前
【.net core】天地图坐标转换为高德地图坐标(WGS84 坐标转 GCJ02 坐标)
java·前端·.netcore
去旅行、在路上2 小时前
chrome使用手机调试触屏web
前端·chrome
Aphasia3112 小时前
模式验证库——zod
前端·react.js
lexiangqicheng3 小时前
es6+和css3新增的特性有哪些
前端·es6·css3