> 文档中心 > 使用base64对vue传递的参数进行加密,springboot解密

使用base64对vue传递的参数进行加密,springboot解密


使用base64对vue传递的参数进行加密,springboot解密

废话少说,直接上代码
vue终端执行

npm install --save js-base64

然后在使用的时候

let Base64 = require('js-base64').Base64//加密方法let oPassword =  Base64.encode(that.form.oldPassword);    let nPassword =  Base64.encode(that.form.newPassword);     //解密方法(此处我没有用到)    //let oPassword = Base64.decode(密文)

传输到后台之后,在后台创建Base64Utils工具类

package manage.util;import java.io.BufferedInputStream;import java.io.BufferedOutputStream;import java.io.BufferedReader;import java.io.BufferedWriter;import java.io.ByteArrayOutputStream;import java.io.CharArrayWriter;import java.io.File;import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.FileReader;import java.io.FileWriter;import java.io.IOException;import java.io.InputStream;import java.io.OutputStream;import java.io.Reader;import java.io.Writer;import java.util.Base64;import org.apache.commons.lang3.StringUtils;import org.springframework.web.multipart.MultipartFile;import sun.misc.BASE64Decoder;/ * @author 作者 : XJT * @version 创建时间:2020年3月3日 下午1:46:30 类说明:加密工具类 */@SuppressWarnings({ "unused"})public class Base64Utils {public Base64Utils() {}/ * 功能:加密字符串 * * @author 薛锦涛 * @date 2020年03月03日 * @param data 源字符串 * @return String */public static String encode(String data) {if (StringUtils.isNotBlank(data)) {return new String(encode(data.getBytes()));} else {return "源字符串为空";}}/ * 功能:解密字符串 * * @author  XJT * @date 2020年03月03日 * @param data 源字符串 * @return String */public static String decode(String data) {if (StringUtils.isNotBlank(data)) {return new String(decode(data.toCharArray()));} else {return "源字符串为空";}}/ * 功能:编码byte[] * * @author  XJT * @date 2020年03月03日 * @param data 源 * @return char[] */public static char[] encode(byte[] data) {char[] out = new char[((data.length + 2) / 3) * 4];for (int i = 0, index = 0; i < data.length; i += 3, index += 4) {boolean quad = false;boolean trip = false;int val = (0xFF & (int) data[i]);val <<= 8;if ((i + 1) < data.length) {val |= (0xFF & (int) data[i + 1]);trip = true;}val <<= 8;if ((i + 2) < data.length) {val |= (0xFF & (int) data[i + 2]);quad = true;}out[index + 3] = alphabet[(quad ? (val & 0x3F) : 64)];val >>= 6;out[index + 2] = alphabet[(trip ? (val & 0x3F) : 64)];val >>= 6;out[index + 1] = alphabet[val & 0x3F];val >>= 6;out[index + 0] = alphabet[val & 0x3F];}return out;}/ * 功能:解码 * * @author  XJT * @date 2020年03月03日 * @param data 编码后的字符数组 * @return byte[] */public static byte[] decode(char[] data) {int tempLen = data.length;for (int ix = 0; ix < data.length; ix++) {if ((data[ix] > 255) || codes[data[ix]] < 0) {--tempLen; // ignore non-valid chars and padding}}// calculate required length:// -- 3 bytes for every 4 valid base64 chars// -- plus 2 bytes if there are 3 extra base64 chars,// or plus 1 byte if there are 2 extra.int len = (tempLen / 4) * 3;if ((tempLen % 4) == 3) {len += 2;}if ((tempLen % 4) == 2) {len += 1;}byte[] out = new byte[len];int shift = 0; // # of excess bits stored in accumint accum = 0; // excess bitsint index = 0;// we now go through the entire array (NOT using the 'tempLen' value)for (int ix = 0; ix < data.length; ix++) {int value = (data[ix] > 255) ? -1 : codes[data[ix]];if (value >= 0) { // skip over non-codeaccum <<= 6; // bits shift up by 6 each time thrushift += 6; // loop, with new bits being put inaccum |= value; // at the bottom.if (shift >= 8) { // whenever there are 8 or more shifted in,shift -= 8; // write them out (from the top, leaving anyout[index++] = // excess at the bottom for next iteration.(byte) ((accum >> shift) & 0xff);}}}// if there is STILL something wrong we just have to throw up now!if (index != out.length) {throw new Error("Miscalculated data length (wrote " + index + " instead of " + out.length + ")");}return out;}/ * 功能:编码文件 * * @author XJT * @date 2020年03月03日 * @param file 源文件 */public static void encode(File file) throws IOException {if (!file.exists()) {System.exit(0);}else {byte[] decoded = readBytes(file);char[] encoded = encode(decoded);writeChars(file, encoded);}file = null;}/ * 功能:解码文件。 * * @author 薛锦涛 * @date 2020年03月03日 * @param file 源文件 * @throws IOException */public static void decode(File file) throws IOException {if (!file.exists()) {System.exit(0);} else {char[] encoded = readChars(file);byte[] decoded = decode(encoded);writeBytes(file, decoded);}file = null;}//// code characters for values 0..63//private static char[] alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=".toCharArray();//// lookup table for converting base64 characters to value in range 0..63//private static byte[] codes = new byte[256];static {for (int i = 0; i < 256; i++) {codes[i] = -1;// LoggerUtil.debug(i + "&" + codes[i] + " ");}for (int i = 'A'; i <= 'Z'; i++) {codes[i] = (byte) (i - 'A');// LoggerUtil.debug(i + "&" + codes[i] + " ");}for (int i = 'a'; i <= 'z'; i++) {codes[i] = (byte) (26 + i - 'a');// LoggerUtil.debug(i + "&" + codes[i] + " ");}for (int i = '0'; i <= '9'; i++) {codes[i] = (byte) (52 + i - '0');// LoggerUtil.debug(i + "&" + codes[i] + " ");}codes['+'] = 62;codes['/'] = 63;}private static byte[] readBytes(File file) throws IOException {ByteArrayOutputStream baos = new ByteArrayOutputStream();byte[] b = null;InputStream fis = null;InputStream is = null;try {fis = new FileInputStream(file);is = new BufferedInputStream(fis);int count = 0;byte[] buf = new byte[16384];while ((count = is.read(buf)) != -1) {if (count > 0) {baos.write(buf, 0, count);}}b = baos.toByteArray();} finally {try {if (fis != null)fis.close();if (is != null)is.close();if (baos != null)baos.close();} catch (Exception e) {System.out.println(e);}}return b;}private static char[] readChars(File file) throws IOException {CharArrayWriter caw = new CharArrayWriter();Reader fr = null;Reader in = null;try {fr = new FileReader(file);in = new BufferedReader(fr);int count = 0;char[] buf = new char[16384];while ((count = in.read(buf)) != -1) {if (count > 0) {caw.write(buf, 0, count);}}} finally {try {if (caw != null)caw.close();if (in != null)in.close();if (fr != null)fr.close();} catch (Exception e) {System.out.println(e);}}return caw.toCharArray();}private static void writeBytes(File file, byte[] data) throws IOException {OutputStream fos = null;OutputStream os = null;try {fos = new FileOutputStream(file);os = new BufferedOutputStream(fos);os.write(data);} finally {try {if (os != null)os.close();if (fos != null)fos.close();} catch (Exception e) {System.out.println(e);}}}private static void writeChars(File file, char[] data) throws IOException {Writer fos = null;Writer os = null;try {fos = new FileWriter(file);os = new BufferedWriter(fos);os.write(data);} finally {try {if (os != null)os.close();if (fos != null)fos.close();} catch (Exception e) {e.printStackTrace();}}}public static File base64ToFile(String base64, String fileName) {File file = null;// 创建文件目录String filePath = "C:\\file";File dir = new File(filePath);if (!dir.exists() && !dir.isDirectory()) {dir.mkdirs();}BufferedOutputStream bos = null;java.io.FileOutputStream fos = null;try {byte[] bytes = Base64.getDecoder().decode(base64);file = new File(filePath + "\\" + fileName);fos = new java.io.FileOutputStream(file);bos = new BufferedOutputStream(fos);bos.write(bytes);} catch (Exception e) {e.printStackTrace();} finally {if (bos != null) {try {bos.close();} catch (IOException e) {e.printStackTrace();}}if (fos != null) {try {fos.close();} catch (IOException e) {e.printStackTrace();}}}return file;}public static MultipartFile base64ToMultipart(String base64) { try { String replace = base64.replace(" ", "+");     String[] baseStrs = replace.split(",");     BASE64Decoder decoder = new BASE64Decoder();     byte[] b = new byte[0];     b = decoder.decodeBuffer(baseStrs[1]);     for (int i = 0; i < b.length; ++i) {  if (b[i] < 0) {      b[i] += 256;  }     }     return new BASE64DecodedMultipartFile(b, baseStrs[0]); } catch (IOException e) {     e.printStackTrace();     return null; }    }}

使用方法如下

oldPassword = Base64Utils.decode(oldPassword);newPassword = Base64Utils.decode(newPassword);

如果有什么不对的地方,欢迎指出