java 加密 sha_Java加密 消息摘要算法SHA实现详解

SHA是消息摘要算法的一种实现方式,前面已经总结过MD2\4\5的实现,接下来就为大家总结一下SHA的实现。

SHA的jdk实现:

private static void SHA_JDK(){

try {

MessageDigest digest = MessageDigest.getInstance("SHA");//我们可以通过SHA\SHA-1\SHA-384\SHA-256\SHA-512来获得不同的消息摘要密钥

digest.update(src.getBytes());

System.out.println("SHA :"+Hex.encodeHexString(digest.digest()));

} catch (NoSuchAlgorithmException e) {

e.printStackTrace();

}

}

SHA的BC实现:

private static void SHA_BC(){

Digest digest = new SHA1Digest();

digest.update(src.getBytes(), 0, src.getBytes().length);

byte[] shaByte = new byte[digest.getDigestSize()];

digest.doFinal(shaByte, 0);

System.out.println("shaByte : "+Hex.encodeHexString(shaByte));

}

对于SHA224,JAVA jdk并没有提供实现,下面是利用BC实现的方法:

private static void SHA224_BC(){

Digest digest = new SHA224Digest();

digest.update(src.getBytes(), 0, src.getBytes().length);

byte[] sha224Byte = new byte[digest.getDigestSize()];

digest.doFinal(sha224Byte, 0);

System.out.println("sha224Byte : "+Hex.encodeHexString(sha224Byte));

}

对于SHA224还有一种类似JDK的实现方法:

private static void SHA224_BC_JDK(){

Security.addProvider(new BouncyCastleProvider());

try {

MessageDigest digest = MessageDigest.getInstance("SHA-224");

digest.update(src.getBytes());

System.out.println("SHA224_BC_JDK :"+Hex.encodeHexString(digest.digest()));

} catch (NoSuchAlgorithmException e) {

e.printStackTrace();

}

}

最后简单介绍一下CC的SHA实现:

private static void SHA_CC_Byte(){

System.out.println("SHA_CC_Byte_SHA1 : "+DigestUtils.sha1Hex(src.getBytes()));

System.out.println("SHA_CC_Byte_SHA256 : "+DigestUtils.sha256Hex(src.getBytes()));

System.out.println("SHA_CC_Byte_SHA384 : "+DigestUtils.sha384Hex(src.getBytes()));

System.out.println("SHA_CC_Byte_SHA512 : "+DigestUtils.sha512Hex(src.getBytes()));

}

private static void SHA_CC(){

System.out.println("SHA_CC_SHA1 : "+DigestUtils.sha1Hex(src));

System.out.println("SHA_CC_SHA256 : "+DigestUtils.sha256Hex(src));

System.out.println("SHA_CC_SHA384 : "+DigestUtils.sha384Hex(src));

System.out.println("SHA_CC_SHA512 : "+DigestUtils.sha512Hex(src));

}

到这里SHA的实现总结完毕。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持谷谷点程序。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/572454.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

monkeyrunner脚本的录制和回放

参考:http://www.cnblogs.com/android-host/p/5378996.html 需要条件: 1.android-sdk 2.monkey_recorder.py 3.monkey_playback.py 操作步骤: 1)新建monkey_recorder.py文件,复制以下代码: #!/usr/bin/env monkeyrunne…

什么是接口

概念: 接口是更加彻底的抽象,接口中全部是抽象方法。接口是不能直接创建对象的。从JDK8之后,接口中不再只是抽象方法,接口还可以有默认方法(也就是实例方法),和静态方法了,还包含了私…

php session作用,PHP中Session的作用

PHP session变量的作用是:存储用户的session信息,或者改变用户的session设置。Session变量储存了一个单一用户的信息,它可以被所有的页面使用。PHP Session变量当你在自己的计算机上运行一个应用程序时,你打开它,对他做…

Vuex核心知识(2.0)

Vuex核心知识(2.0) 转自:http://www.cnblogs.com/ghost-xyx/p/6380689.html Vuex 是一个专门为 Vue.js 应该程序开发的状态管理模式,它类似于 Redux 应用于 React 项目中,他们都是一种 Flux 架构。相比 Redux&#xff…

java带权连通图上最小权边,连通图最小生成树的算法及实现

连通图的最小生成树生成树定义:无向连通图G的极小连通子图,称为它的生成树。(n个顶点,n-1条边)考虑一下下面这个图上图是一个完全图,它的生成树不是唯一的,我们列出最特殊的两种情况上面2个图都是第一个完全图的生成树…

Android7.0,剪裁后提示“无法保存经过裁剪的图片”

今天在适配一下 7.0的拍照和选择照片,裁剪,发现拍照可以,选择图片也可以, 但是就是裁剪的时候不行,会弹出提示:无法保存经过裁剪的图片 后来才发现,在设置裁剪要保存的 intent.putExtra(MediaSt…

PHP垃圾回收机制理解

使用的是“引用计数”方式进行回收。简单地理解的话,就是每个分配的内存区域都有一个计数器,记录有多少个变量指针指向这片内存。当指向该片内存的指针数量为0,那么该片内存区域就可以被回收。 引用计数计数简单,强大,…

枚举的用法

概念: 为了间接的表示一些固定的值,Java就给提供了枚举,是指将变量的值一一列出来,变量的值只限于列举出来的值的范围内、 特点: 所有枚举类都是Enum的子类我们可以通过”枚举类名.枚举项名称”去访问指定的枚举项每一个枚举项其实…

在php中创建三个表格,创建新工作表PHPExcel

我正在尝试创建另一个工作表,一切正常.但我现在需要的是根据变量创建1.例如 :我有两个选项用于验证,一个用于结果.一切都由一个名为$resultado的布尔变量来约束.我在CakePHP中有我的组件function ExcelCargaMasivaComponent() {$this->xls new PHPExcel();$this…

java.lang.String类

复制下来的java.lang.String源码。在此基础上添加自己的注释,偷懒了,用来加深印象吧。英语不好,没有翻译,不理解的方法直接百度的。然后按照自己的理解描述。/** (#)String.java 1.205 09/02/26** Copyright 2006 Sun Microsys…

面向对象-多态

概念 多态是指同一行为,具有多个不同表现形式 多态是除封装、继承之后面向对象的第三大特征。 多态是出现在继承或者实现关系中的 使用多态有什么前提 要有继承或实现关系要有方法的重写要有父类引用指向子类对象 子类对象是可以赋值给父类类型的变量。例如Animal是…

php 区位码字符,php汉字如何转区位码

php汉字转区位码的方法:首先创建一个PHP示例文件;然后通过“sprintf("%02d%02d",ord($t1[0])-160,ord($t1[1])-160);”方法实现汉字转区位码即可。推荐:《PHP视频教程》PHP中实现汉字转区位码应用源码实例解析PHP里如何实现汉字转区…

ssh(struts,spring,hibernate)开发的初步集成01--依赖

一.概念 SSH 通常指的是 Struts2 做前端控制器,spring 管理各层的组件,hibernate 负责持久化层。 SSM 则指的是 SpringMVC 做前端控制器,Spring 管理各层的组件,MyBatis 负责持久化层。 二.构建流程 创建maven工程...在pom.xml文件…

频谱扩展 matlab,简单的直接扩展频谱通信系统仿真分析

随着通信技术的迅猛发展,扩展频谱通信技术的优点已经越来越明显并被接受,并在各个领域得到了广泛的应用。同时随着计算机技术和仿真技术的日益发展和应用,如何应用一些方便、友好的软件对通信系统进行直观的模型仿真,并进行仿真结…

内部类怎么用

内部类: 在一个类中定义一个类。 举例:在一个类A的内部定义一个类B,类B就被称为内部类 // 格式: class 外部类名{ 修饰符 class 内部类名{ } } class A{public class B {}}内部类的访问特点: 内部类可以直接访问外部类…

一个css3特效

转载于:https://www.cnblogs.com/xiongwei2017/p/6877393.html

matlab保存格式可以用cad打开文件,怎么将TXT文件导入CAD中生成图形

我们可以先把TXT文件转换成WORD或是EXCEL表格里。然后再把转换后的WORD或是EXCEL表格导入到CAD图纸中。这里以迅捷CAD编辑器为例,演示如下:步骤一:还是需要在电脑桌面上安装迅捷CAD编辑器。并进入到软件的操作界面。步骤二:双击打…

[Hnoi2006]马步距离

1285: [Hnoi2006]马步距离 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 36 Solved: 16[Submit][Status][Web Board]Description 在国际象棋和中国象棋中,马的移动规则相同,都是走“日”字,我们将这种移动方式称为马步移动。如右图所示&…

包装类(自动拆箱与自动装箱)

概念: 基本数据类型有8种.基本数据类型效率高,但是功能及其有限,只能做加减乘除运算.为了对基本数据类型进行更多的操作,Java为每种基本数据类型提供了对应的类(包装类), 作用: 用于基本数据类型与字符串之间的转换 将基本数据类型封装成对象…

php scrscriptipt,XSS挑战之旅闯关笔记

环境自己搭建~~好嚣张:1.http://127.0.0.1:8024/xss/level1.php?nametest 这是URL 看到后面name有参数传递,不多想直接尝试xss。没有任何过滤。payload :http://127.0.0.1:8024/xss/level1.php?name2.http://127.0.0.1:8024/xss/level2.ph…