java sha256加密_如何用Sha256进行简单的加密或者解密

个人是今天第一次使用Sha256对数据进行加密操作,以往都是直接使用MD5加密最多也就是加盐之后再进行加密

不过可能是个人应用的只是简单的一个对数据的加密,所以感觉目前和MD5差距并不是很大.

1.首先要找到一个合适的加密工具类(网上一搜一大堆),我的放在最下面了

2.我目前的应用步骤

我这边先使用时候,我会根据id+key(这两个都是生成的Longl类型的串)储在数据库中

将两者拼接在一起的字符串使用工具类加密,返还给接收数据的页面

查询数据的时候,调用的地方会给我回传id,和一个密匙

我首先先通过id,查询出数据库真实的数据,之前数据在存储数据库中会存储一个key,

拿出这个ke与id按照之前的加密方式在加密一次,之后与前端页面传来的密匙进行比较,

当两者一致时候,我把正确的数据回传给调用者,不一致则提示密匙错误

因为是第一次使用sha256,所以只是简单的应用,可能与每个人的应用不一样,也可能我的使用方式错了,请您指出来,我好及时改正

import java.io.UnsupportedEncodingException;

import java.security.MessageDigest;

import java.security.NoSuchAlgorithmException;

public class Sha256Util {

/**

* 利用java原生的类实现SHA256加密

* @param str 加密后的报文

* @return

*/

public static String getSHA256(String str){

MessageDigest messageDigest;

String encodestr = &#

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用Java实现SHA256加密解密的示例代码: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class SHA256Example { public static void main(String[] args) { String password = "mypassword"; String encodedPassword = sha256(password); System.out.println("Encoded Password: " + encodedPassword); String decodedPassword = sha256(encodedPassword); System.out.println("Decoded Password: " + decodedPassword); } public static String sha256(String input) { try { MessageDigest messageDigest = MessageDigest.getInstance("SHA-256"); byte[] hash = messageDigest.digest(input.getBytes()); StringBuilder hexString = new StringBuilder(); for (byte b : hash) { String hex = Integer.toHexString(0xff & b); if (hex.length() == 1) hexString.append('0'); hexString.append(hex); } return hexString.toString(); } catch (NoSuchAlgorithmException e) { throw new RuntimeException(e); } } } ``` 在这个示例中,我们首先定义了一个字符串变量 `password`,它代表要加密的原始密码。然后我们使用 `sha256` 方法对该密码进行加密,并将结果存储在 `encodedPassword` 变量中。接着,我们再次使用 `sha256` 方法解密 `encodedPassword`,并将结果存储在 `decodedPassword` 变量中。 `sha256` 方法使用Java的 `MessageDigest` 类来计算SHA-256哈希值。该方法接受一个字符串参数 `input`,将其转换为字节数组,通过调用 `digest` 方法来计算哈希值,并将结果转换为十六进制字符串返回。如果在计算哈希值时出现异常,则抛出 `RuntimeException` 异常。 注意,SHA256是一种单向哈希函数,因此无法对哈希值进行解密。在示例中,我们只是将哈希值再次传递给 `sha256` 方法来演示这一点。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值