Java实际工作里用到的几种加密方式

2024-06-13 18:12

本文主要是介绍Java实际工作里用到的几种加密方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、Base64加密

最简单的加密方式,甚至可以说不是加密,只是一种用64个字符表示任意二进制数据的方法。Base64编码原理是将输入字符串按字节切分,取得每个字节对应的二进制值(若不足8比特则高位补0),然后将这些二进制数值串联起来,再按照6比特一组进行切分(因为2^6=64),最后一组若不足6比特则末尾补0。将每组二进制值转换成对应的字符即可得到Base64编码后的字符串 。

  安全性:低 

  是否可逆:可

  代码片段:

package com.geek.security.base64;import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;import java.io.IOException;public class Base64Demo {private static String src = "imooc security base64";public static void main(String[] args) throws IOException {jdkBase64();}private static void jdkBase64() throws IOException {BASE64Encoder encoder = new BASE64Encoder();String encode = encoder.encode(src.getBytes());System.out.println("encode = " + encode);// aW1vb2Mgc2VjdXJpdHkgYmFzZTY0BASE64Decoder decoder = new BASE64Decoder();byte[] bytes = decoder.decodeBuffer(encode);String decode = new String(bytes);System.out.println("decode = " + decode);// imooc security base64System.out.println("bytes = " + bytes);// [B@1b6d3586}}

  使用jdk自带sun包下相关类即可。

2、MD5加密

  MD5,全称为Message-Digest Algorithm 5,也称信息-摘要算法,是一种被广泛应用于信息安全领域的加密算法。它可以产生出一个128位(16字节)的散列值(hash value),用于确保信息传输的完整一致性。MD5的特性包括压缩性,即任意长度的数据算出的MD5值长度都是固定的;容易计算,即从原数据计算出MD5值很容易;抗修改性,对原数据进行任何改动,哪怕只修改1个字节,所得到的MD5值都有很大区别;以及弱抗碰撞,已知原数据和其MD5值,想找到一个具有相同MD5值的数据(即伪造数据)是非常困难的。

  MD5算法的安全性在于,的问题在于,MD5算法存在碰撞攻击的风险,即不同的输入可能会产生相同的MD5哈希值。这会导致安全性漏洞,使得攻击者可以伪造数据或签名。因此,尽管MD5的流程设计复杂且高效,通过多轮循环和非线性函数的处理,保证了生成的哈希值具有较高的随机性和安全性,但在面对现代计算能力的提升和密码学研究的深入的情况下,MD5的安全性已经不再得到保证。

  安全性:中

  是否可逆:不可逆

  代码片段:

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;public class MD5Encryption {public static String encrypt(String input) {try {MessageDigest md = MessageDigest.getInstance("MD5");byte[] messageDigest = md.digest(input.getBytes());StringBuilder sb = new StringBuilder();for (byte b : messageDigest) {String hex = Integer.toHexString(0xff & b);if (hex.length() == 1) {sb.append('0');}sb.append(hex);}return sb.toString();} catch (NoSuchAlgorithmException e) {throw new RuntimeException(e);}}public static void main(String[] args) {String input = "Hello, World!";String encryptedString = encrypt(input);System.out.println("Original string: " + input);System.out.println("Encrypted string: " + encryptedString);}
}

  使用java自带的security包中相关类。

3、SHA加密

  SHA加密是一种单向哈希函数,它将任意长度的数据转换为一个16字节的哈希值。这种加密方式常用于文件校验、用户身份验证等场景。

  SHA加密算法有很多版本,如SHA-0、SHA-1、SHA-2等。其中,SHA-1和SHA-2是应用最广泛的版本。

  SHA-256加密算法的工作原理如下:

  1. 首先,对输入的数据进行初始化,将其分割成大小为512位的块(如果数据长度不是512的倍数,则需要填充零以满足这一要求)。

  2. 对每个块执行哈希函数,生成一个128位的哈希值。

  3. 将所有块的哈希值连接起来,得到一个1024位的哈希值。

  4. 对得到的1024位的哈希值执行哈希函数,得到最终的128位的哈希值。

  SHA-256加密算法提供了丰富的变体,包括不同大小的块(如1024位、512位、256位等)、不同的哈希函数(如SHA-256、SHA-3等)以及不同的填充方案(如PKCS#7、ISO/IEC 10177等)。

  安全性:低 

  是否可逆:可

  代码片段:

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;public class SHA1Encrypt {public static String sha1Encrypt(String input) {try {// 创建SHA1加密对象MessageDigest sha1 = MessageDigest.getInstance("SHA-1");// 执行加密操作byte[] encrypt = sha1.digest(input.getBytes());// 将加密结果转换为十六进制字符串StringBuilder sb = new StringBuilder();for (byte b : encrypt) {sb.append(String.format("%02x", b));}return sb.toString();} catch (NoSuchAlgorithmException e) {throw new RuntimeException("SHA1加密算法未找到", e);}}public static void main(String[] args) {String input = "Hello, World!";String encrypt = sha1Encrypt(input);System.out.println("SHA1加密结果:" + encrypt);}
}

  使用java自带的security包中相关类。

文章转载自:SweetCukes

原文链接:https://www.cnblogs.com/SweetCukes/p/18242523

体验地址:引迈 - JNPF快速开发平台_低代码开发平台_零代码开发平台_流程设计器_表单引擎_工作流引擎_软件架构

这篇关于Java实际工作里用到的几种加密方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1058048

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听