【数据加密、解密】前后端数据传输的过程中,如何进行数据加密传输,保证数据的传输安全,防止被他人窃取

前端进行参数传递的时候 ,有些数据为了安全起见还是需要加密传输的,比如用户密码,比如登录的时候,注册的时候,用户输入的密码,如果明文进行传输还是不太安全的,所以一般可以进行加密后传递到后端。

那么就有这几个问题:

·前端如何进行加密

·后端如何进行解密

·用什么加密算法

一般是用3DES的加密解密方式

前端引用3DES加密库,对数据进行加密,然后传输到后端,后端通过3DES进行解密操作就可以了。

后端java代码如下:加密、解密:

代码中的 SECRECY_KEY 就是 我们用到的加密密钥。你可以改成你自己的。我这里是3DES加密,用到24位的加密密钥。
public final static String SECRECY_KEY = "123456789987654321123456"; // 24位

java 复制代码
package com.xxx.utils;

import org.apache.commons.lang3.StringUtils;
import org.apache.http.client.utils.DateUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import java.util.Date;

/**
 * 3DES加密解密工具类
 */
public class ThreeDESUtils {
    private final static Logger logger = LoggerFactory.getLogger(ThreeDESUtils.class);
    /**
     * 加解密统一编码方式
     */
    private final static String ENCODING = "utf-8";
    /**
     * 加解密方式
     */
    private final static String ALGORITHM  = "DESede";
    /**
     *加密模式及填充方式
     */
    private final static String PATTERN = "DESede/CBC/PKCS5Padding";

    public final static String SECRECY_KEY = "123456789987654321123456"; // 24位

    /**
     * 数据加密
     * @param message       待加密的数据
     * @param ivHex         加密偏移量设置
     * @return              
     * @throws Exception
     */

    public static String encrypt(String message, String ivHex) throws Exception {
        if(StringUtils.isBlank(ivHex)){
            ivHex = DateUtils.formatDate(new Date(),"yyyyMMdd");
        }
        final SecretKey key = new SecretKeySpec(SECRECY_KEY.getBytes("utf-8"), ALGORITHM);
        final IvParameterSpec iv = new IvParameterSpec(ivHex.getBytes("utf-8"));
        final Cipher cipher = Cipher.getInstance(PATTERN);
        cipher.init(Cipher.ENCRYPT_MODE, key, iv);
        final byte[] plainTextBytes = message.getBytes("utf-8");
        final byte[] cipherText = cipher.doFinal(plainTextBytes);
        return new sun.misc.BASE64Encoder().encode(cipherText);
    }

    /**
     * 3DES数据解密
     * @param message       待解密的数据。这个数据已经进行了一次Base64加密
     * @param ivHex         加密偏移量设置
     * @return
     * @throws Exception
     */
    public static String decrypt(String message, String ivHex) throws Exception {
        if(StringUtils.isBlank(ivHex)){
            ivHex = DateUtils.formatDate(new Date(),"yyyyMMdd");
        }
        final SecretKey key = new SecretKeySpec(SECRECY_KEY.getBytes("utf-8"), ALGORITHM);
        final IvParameterSpec iv = new IvParameterSpec(ivHex.getBytes("utf-8"));
        final Cipher decipher = Cipher.getInstance(PATTERN);
        decipher.init(Cipher.DECRYPT_MODE, key, iv);
        final byte[] plainText = decipher.doFinal(new sun.misc.BASE64Decoder().decodeBuffer(message));
        return new String(plainText, "UTF-8");
    }

}
相关推荐
java1234_小锋2 分钟前
Java高频面试题:Spring-AOP通知和执行顺序?
java·开发语言·spring
番茄去哪了6 分钟前
Java基础面试题day02
java·开发语言·面向对象编程
我是咸鱼不闲呀22 分钟前
力扣Hot100系列22(Java)——[图论]总结(岛屿数量,腐烂的橘子,课程表,实现Trie(前缀树))
java·leetcode·图论
1104.北光c°23 分钟前
深入浅出 Elasticsearch:从搜索框到精准排序的架构实战
java·开发语言·elasticsearch·缓存·架构·全文检索·es
MSTcheng.28 分钟前
【优选算法必修篇——位运算】『面试题 01.01. 判定字符是否唯一&面试题 17.19. 消失的两个数字』
java·算法·面试
蹦哒30 分钟前
Kotlin 与 Java 语法差异
java·python·kotlin
左左右右左右摇晃31 分钟前
Java并发——并发编程底层原理
java·开发语言
一个有温度的技术博主37 分钟前
Redis系列八:Jedis连接池在java中的使用
java·redis·bootstrap
cyforkk39 分钟前
Java 并发编程教科书级范例:深入解析 computeIfAbsent 与方法引用
java·开发语言
后青春期的诗go41 分钟前
泛微OA-E9与第三方系统集成开发企业级实战记录(八)
java·接口·金蝶·泛微·oa·集成开发·对接