- 浏览: 1048270 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (1441)
- 软件思想&演讲 (9)
- 行业常识 (250)
- 时时疑问 (5)
- java/guava/python/php/ruby/R/scala/groovy (213)
- struct/spring/springmvc (37)
- mybatis/hibernate/JPA (10)
- mysql/oracle/sqlserver/db2/mongdb/redis/neo4j/GreenPlum/Teradata/hsqldb/Derby/sakila (268)
- js/jquery/jqueryUi/jqueryEaseyUI/extjs/angulrJs/react/es6/grunt/zepto/raphael (81)
- ZMQ/RabbitMQ/ActiveMQ/JMS/kafka (17)
- lucene/solr/nuth/elasticsearch/MG4J (167)
- html/css/ionic/nodejs/bootstrap (19)
- Linux/shell/centos (56)
- cvs/svn/git/sourceTree/gradle/ant/maven/mantis/docker/Kubernetes (26)
- sonatype nexus (1)
- tomcat/jetty/netty/jboss (9)
- 工具 (17)
- ETL/SPASS/MATLAB/RapidMiner/weka/kettle/DataX/Kylin (11)
- hadoop/spark/Hbase/Hive/pig/Zookeeper/HAWQ/cloudera/Impala/Oozie (190)
- ios/swift/android (9)
- 机器学习&算法&大数据 (18)
- Mesos是Apache下的开源分布式资源管理框架 (1)
- echarts/d3/highCharts/tableau (1)
- 行业技能图谱 (1)
- 大数据可视化 (2)
- tornado/ansible/twisted (2)
- Nagios/Cacti/Zabbix (0)
- eclipse/intellijIDEA/webstorm (5)
- cvs/svn/git/sourceTree/gradle/jira/bitbucket (4)
- jsp/jsf/flex/ZKoss (0)
- 测试技术 (2)
- splunk/flunm (2)
- 高并发/大数据量 (1)
- freemarker/vector/thymeleaf (1)
- docker/Kubernetes (2)
- dubbo/ESB/dubboX/wso2 (2)
最新评论
1、BASE64
Base64定义:Base64内容传送编码被设计用来把任意序列的8位字节描述为一种不易被人直接识别的形式。(The Base64 Content-Transfer-Encoding is designed to represent arbitrary sequences of octets in a form that need not be humanly readable.)
常见于邮件、http加密,截取http信息,你就会发现登录操作的用户名、密码字段通过BASE64加密的。
实例:
Java代码 复制代码 收藏代码
1.package cn.tzz.java.crypto;
2.
3.import java.io.IOException;
4.
5.import sun.misc.BASE64Decoder;
6.import sun.misc.BASE64Encoder;
7.
8.public class BASE64Util {
9. /**加密*/
10. public static String encrypt(byte[] key) {
11. return (new BASE64Encoder()).encodeBuffer(key);
12. }
13.
14. /**解密*/
15. public static String decrypt(String key) {
16. try {
17. return new String((new BASE64Decoder()).decodeBuffer(key),"utf-8");
18. } catch (IOException e) {
19. e.printStackTrace();
20. }
21. return null;
22. }
23.
24. public static void main(String[] args) {
25. String encryptStr = encrypt("123456".getBytes());
26. System.out.println("加密:"+encryptStr);
27. System.out.println("解密:"+decrypt(encryptStr));
28. }
29.}
2、MD5&SHA
MD5 -- message-digest algorithm 5 (信息-摘要算法)
SHA(Secure Hash Algorithm,安全散列算法)
Java代码 复制代码 收藏代码
1.package cn.tzz.java.crypto.simple;
2.
3.import java.security.MessageDigest;
4.import java.security.NoSuchAlgorithmException;
5.
6.public class MD5SHACryptoUtil {
7.
8. /**md5加密*/
9. public static String md5Encrypt(String str) {
10. String md5String = null;
11. try {
12. // 获得MD5摘要算法的 MessageDigest 对象
13. MessageDigest md = MessageDigest.getInstance("MD5");
14. // 使用指定的字节更新摘要
15. md.update(str.getBytes());
16. // 获得密文,把密文转换成十六进制的字符串形式
17. //方式一
18. md5String = byte2Hex(md.digest());
19. //方式二
20. //md5String = byteToHex(md.digest());
21. //方式三
22. //md5String = byteToString(md.digest());
23. } catch (Exception ex) {
24. ex.printStackTrace();
25. }
26. return md5String;
27. }
28.
29. /**SHA1加密*/
30. public static String shaEncrypt(String date) {
31. byte[] digest = null;
32. String rs = null;
33. try {
34. // 得到一个SHA-1的消息摘要
35. MessageDigest messageDigest = MessageDigest.getInstance("SHA-1");
36. // 添加要进行计算摘要的信息
37. messageDigest.update(date.getBytes());
38. // 得到该摘要
39. digest = messageDigest.digest();
40. // 将摘要转为字符串
41. rs = byte2Hex(digest);
42. } catch (NoSuchAlgorithmException e) {
43. e.printStackTrace();
44. }
45. return rs;
46. }
47.
48. // 1.把密文转换成十六进制的字符串形式(Integer.toHexString函数)
49. public static String byte2Hex(byte[] b) {
50. StringBuffer sb = new StringBuffer();
51. String tmp = "";
52. for (int i = 0; i < b.length; i++) {
53. tmp = Integer.toHexString(b[i] & 0XFF);
54. if (tmp.length() == 1){
55. sb.append("0");
56. }
57. sb.append(tmp);
58. }
59. return sb.toString();
60. }
61.
62. // 2.把密文转换成十六进制的字符串形式(自定义)
63. public static String byteToHex(byte[] b) {
64. // 全局数组
65. char[] hexDigits = {'0' , '1' , '2' , '3' , '4' , '5' ,'6' , '7' , '8' , '9' , 'a' , 'b' ,
66. 'c' , 'd' , 'e' , 'f'};
67. // 把密文转换成十六进制的字符串形式
68. int j = b.length;
69. char str[] = new char[j * 2];
70. int k = 0;
71. for (int i = 0; i < j; i++) {
72. byte byte0 = b[i];
73. str[k++] = hexDigits[byte0 >>> 4 & 0xf];
74. str[k++] = hexDigits[byte0 & 0xf];
75. }
76. return new String(str);
77. }
78.
79. // 3.转换字节数组为16进制字串
80. private static String byteToString(byte[] b) {
81. StringBuffer sBuffer = new StringBuffer();
82. for (int i = 0; i < b.length; i++) {
83. sBuffer.append(byteToArrayString(b[i]));
84. }
85. return sBuffer.toString();
86. }
87.
88. // 返回形式为数字跟字符串
89. private static String byteToArrayString(byte b) {
90. String[] strDigits = { "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "a", "b", "c", "d", "e", "f" };
91. int iRet = b;
92. if (iRet < 0) {
93. iRet += 256;
94. }
95. int iD1 = iRet / 16;
96. int iD2 = iRet % 16;
97. return strDigits[iD1] + strDigits[iD2];
98. }
99.
100. public static void main(String[] args) {
101. System.out.println(md5Encrypt("123456"));
102. System.out.println(shaEncrypt("123456"));
103. }
104.}
Base64定义:Base64内容传送编码被设计用来把任意序列的8位字节描述为一种不易被人直接识别的形式。(The Base64 Content-Transfer-Encoding is designed to represent arbitrary sequences of octets in a form that need not be humanly readable.)
常见于邮件、http加密,截取http信息,你就会发现登录操作的用户名、密码字段通过BASE64加密的。
实例:
Java代码 复制代码 收藏代码
1.package cn.tzz.java.crypto;
2.
3.import java.io.IOException;
4.
5.import sun.misc.BASE64Decoder;
6.import sun.misc.BASE64Encoder;
7.
8.public class BASE64Util {
9. /**加密*/
10. public static String encrypt(byte[] key) {
11. return (new BASE64Encoder()).encodeBuffer(key);
12. }
13.
14. /**解密*/
15. public static String decrypt(String key) {
16. try {
17. return new String((new BASE64Decoder()).decodeBuffer(key),"utf-8");
18. } catch (IOException e) {
19. e.printStackTrace();
20. }
21. return null;
22. }
23.
24. public static void main(String[] args) {
25. String encryptStr = encrypt("123456".getBytes());
26. System.out.println("加密:"+encryptStr);
27. System.out.println("解密:"+decrypt(encryptStr));
28. }
29.}
2、MD5&SHA
MD5 -- message-digest algorithm 5 (信息-摘要算法)
SHA(Secure Hash Algorithm,安全散列算法)
Java代码 复制代码 收藏代码
1.package cn.tzz.java.crypto.simple;
2.
3.import java.security.MessageDigest;
4.import java.security.NoSuchAlgorithmException;
5.
6.public class MD5SHACryptoUtil {
7.
8. /**md5加密*/
9. public static String md5Encrypt(String str) {
10. String md5String = null;
11. try {
12. // 获得MD5摘要算法的 MessageDigest 对象
13. MessageDigest md = MessageDigest.getInstance("MD5");
14. // 使用指定的字节更新摘要
15. md.update(str.getBytes());
16. // 获得密文,把密文转换成十六进制的字符串形式
17. //方式一
18. md5String = byte2Hex(md.digest());
19. //方式二
20. //md5String = byteToHex(md.digest());
21. //方式三
22. //md5String = byteToString(md.digest());
23. } catch (Exception ex) {
24. ex.printStackTrace();
25. }
26. return md5String;
27. }
28.
29. /**SHA1加密*/
30. public static String shaEncrypt(String date) {
31. byte[] digest = null;
32. String rs = null;
33. try {
34. // 得到一个SHA-1的消息摘要
35. MessageDigest messageDigest = MessageDigest.getInstance("SHA-1");
36. // 添加要进行计算摘要的信息
37. messageDigest.update(date.getBytes());
38. // 得到该摘要
39. digest = messageDigest.digest();
40. // 将摘要转为字符串
41. rs = byte2Hex(digest);
42. } catch (NoSuchAlgorithmException e) {
43. e.printStackTrace();
44. }
45. return rs;
46. }
47.
48. // 1.把密文转换成十六进制的字符串形式(Integer.toHexString函数)
49. public static String byte2Hex(byte[] b) {
50. StringBuffer sb = new StringBuffer();
51. String tmp = "";
52. for (int i = 0; i < b.length; i++) {
53. tmp = Integer.toHexString(b[i] & 0XFF);
54. if (tmp.length() == 1){
55. sb.append("0");
56. }
57. sb.append(tmp);
58. }
59. return sb.toString();
60. }
61.
62. // 2.把密文转换成十六进制的字符串形式(自定义)
63. public static String byteToHex(byte[] b) {
64. // 全局数组
65. char[] hexDigits = {'0' , '1' , '2' , '3' , '4' , '5' ,'6' , '7' , '8' , '9' , 'a' , 'b' ,
66. 'c' , 'd' , 'e' , 'f'};
67. // 把密文转换成十六进制的字符串形式
68. int j = b.length;
69. char str[] = new char[j * 2];
70. int k = 0;
71. for (int i = 0; i < j; i++) {
72. byte byte0 = b[i];
73. str[k++] = hexDigits[byte0 >>> 4 & 0xf];
74. str[k++] = hexDigits[byte0 & 0xf];
75. }
76. return new String(str);
77. }
78.
79. // 3.转换字节数组为16进制字串
80. private static String byteToString(byte[] b) {
81. StringBuffer sBuffer = new StringBuffer();
82. for (int i = 0; i < b.length; i++) {
83. sBuffer.append(byteToArrayString(b[i]));
84. }
85. return sBuffer.toString();
86. }
87.
88. // 返回形式为数字跟字符串
89. private static String byteToArrayString(byte b) {
90. String[] strDigits = { "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "a", "b", "c", "d", "e", "f" };
91. int iRet = b;
92. if (iRet < 0) {
93. iRet += 256;
94. }
95. int iD1 = iRet / 16;
96. int iD2 = iRet % 16;
97. return strDigits[iD1] + strDigits[iD2];
98. }
99.
100. public static void main(String[] args) {
101. System.out.println(md5Encrypt("123456"));
102. System.out.println(shaEncrypt("123456"));
103. }
104.}
发表评论
-
20180222积累
2018-02-22 09:34 4781. mybatis如何通过接口查找对应的mapper. ... -
20180208积累
2018-02-08 10:28 465临时表与永久表相似,但临时表存储在 tempdb 中,当不 ... -
行业应用
2018-01-30 16:30 485git clone的时候用上面那个IP地址,下面栏中的不能 ... -
SQLite 数据库
2018-01-29 22:57 755android: SQLite创建数据 ... -
java里面获取map的key和value的方法
2018-02-01 11:29 2159获取map的key和value的方法分为两种形式: ma ... -
Eclipse中Maven WEB工程tomcat项目添加调试以及项目发布细节记录
2018-02-23 21:11 725一、建立一个maven WEB项目 1、file-&g ... -
错误:HttpServlet was not found on the Java
2018-02-23 21:12 382我们在用Eclipse进行Java web ... -
使用 java8 实现List到Array的转换
2018-02-23 21:13 2988开发中需要调用第三方的库,有些 API 的入参要求是 do ... -
Java8 利用Lambda处理List集合
2018-01-11 09:58 5630Java 8新增的Lambda表达式,我们可以很方便地并行操 ... -
java中string与json互相转化
2018-01-11 09:40 1076在Java中socket传输数据时,数据类型往往比较难选择。 ... -
JSON 数据格式
2018-01-11 09:37 474JSON(JavaScript Object Notatio ... -
java怎么读取json格式的数据
2018-01-11 09:46 1059java可以使用JSONObject和JSONArray来操作 ... -
Java8-如何将List转变为逗号分隔的字符串
2018-01-10 10:13 1988Converting a List to a String ... -
eclipse maven 打war包的两种方式
2018-02-23 21:25 703第一种:利用pom.xml文件打包。 右键pom.xml ... -
Annotation(三)——Spring注解开发
2018-02-28 09:21 428Spring框架的核心功能IoC(Inversion o ... -
Spring自定义注解
2018-02-28 09:32 594java注解:附在代码中的一些元信息,用于在编译、运行时起 ... -
Java项目
2018-01-08 10:56 0这两种解决办法已经能完全解决问题,不过值得注意的一点是,我 ... -
解决Eclipse建立Maven项目后无法建立src/main/java资源文件夹的办法
2018-03-22 10:41 1130在Eclipse中建立好一个Maven项目后,如果Java ... -
Java @override报错的解决方法
2018-01-07 12:56 0有时候Java的Eclipse工程换一台电脑后编译总是@ove ... -
Java 8 配置Maven-javadoc-plugin
2018-01-07 09:07 1040在升级JDK至1.8之后,使用Maven-javadoc- ...
相关推荐
本文将详细介绍几种常用的Java加密算法及其应用实例,包括MD5、SHA及RSA。 #### 1. MD5加密 **简介**:MD5(Message-Digest Algorithm 5)是一种广泛使用的散列函数,能够将任意长度的数据转换成一个固定长度...
以下是对几种常见加密算法在Java中的实现的详细阐述: 1. **对称加密**: - **DES(Data Encryption Standard)**:是一种古老的对称加密算法,使用56位密钥进行64位块加密。Java中的`javax.crypto.Cipher`类提供...
首先,我们需要了解几种常见的证书格式:CRT、PEM、PFX和CER。这些格式代表了不同类型的证书存储方式: 1. CRT(Certificate)文件通常包含公钥和证书信息,是PKCS#7标准的一种编码格式。 2. PEM(Privacy Enhanced...
Java 实现文件加密和解密的步骤可以分为以下几步: 1. 读取文件:使用 FileInputStream 读取文件中的内容。 2. 加密文件:使用加密算法对文件中的内容进行加密。 3. 写入文件:使用 FileOutputStream 将加密后的...
在Java编程中,有一种常见的加密方法——异或加密(XOR Encryption)。本主题将深入探讨利用异或加密实现文件快速加密的技术细节,以及它在实际应用中的优缺点。 异或加密是一种简单而有效的加密算法,其基本原理是...
排列码是一种在信息安全领域常用的编码方式,主要用于数据的加密与解密。它的基本思想是将原始数据通过特定的算法进行编码,使得数据在传输或存储过程中不易被破解,增加了数据的安全性。在Java中实现排列码,我们...
1. **对称加密**:如AES(高级加密标准),是一种常见的加密算法。以下是一个简单的AES加密文件的步骤: - 生成随机密钥:`KeyGenerator keyGen = KeyGenerator.getInstance("AES"); keyGen.init(128); SecretKey ...
后端,Java作为一种常用的企业级开发语言,拥有丰富的安全库,例如Bouncy Castle,用于处理RSA加密解密。Java代码可能使用了`java.security`包下的`KeyPairGenerator`、`PublicKey`、`PrivateKey`等类来生成和管理...
在IT领域,数据安全至关重要,而加密技术是保护数据安全的一种常见手段。DES(Data Encryption Standard)加密算法,即数据加密标准,是一种广泛使用的对称加密算法。在Java中实现DES加密,我们可以按照以下步骤进行...
总的来说,ClassFinal作为一款Java class文件安全加密工具,为开发者提供了一种简单、高效的代码保护方案,尤其适合于那些重视代码安全但又不想改动大量代码的企业级项目。其兼容性和易用性使其在Java开发领域具有...
Java中的3DES(Triple Data Encryption Algorithm)是一种强化版的DES(Data Encryption Standard)加密算法,它通过三次应用DES算法来提高安全性。3DES是DES的一个变种,它使用了两个不同的密钥对数据进行三次加密...
在Java中,对字符串进行加密和解密是一种常见的安全措施,特别是在处理敏感数据如用户名和密码时。通过加密技术可以保护这些数据免受未经授权的访问。 #### 1.2 使用场景 - **邮箱加密**:用于保护用户邮件地址不被...
在Java中,常用的对称加密算法有DES(Data Encryption Standard)、3DES(Triple DES)、AES(Advanced Encryption Standard)等。例如,使用AES进行加密和解密可以通过`javax.crypto.Cipher`类实现,首先创建一个`...
Java中的AES(Advanced Encryption Standard)加密解密是信息安全领域中常用的一种对称加密技术。AES在数据保护、网络通信和存储安全中发挥着重要作用。它以其高效性和安全性,被广泛应用于各种软件开发中。本篇将...
在实施Java源代码加密时,开发者需要注意以下几点: - **性能影响**:某些加密技术可能会对应用的运行性能产生影响,特别是在动态解密字节码的情况下。因此,在选择加密方案时,需权衡安全与性能之间的关系。 - **...
本篇文章将主要介绍几种常见的加密方法:BASE64、MD5、SHA和HMAC。 1. **BASE64**:BASE64是一种编码方式,而非真正的加密算法。它将任意8位字节序列转换为ASCII字符集中的可视形式,主要用于在网络上传输二进制...
以上介绍了几种基本的加密解密方法及其在Java中的实现,这些技术在数据安全、网络安全、数字版权管理等领域有着广泛的应用。然而,随着技术的发展,更先进的加密算法和技术不断涌现,开发者应当持续关注最新的加密...
本文将探讨几种常见的加密算法,包括单向加密和对称及非对称加密算法。首先,我们来看基础的单向加密算法,如BASE64、MD5、SHA和HMAC。 **BASE64** 是一种编码方式,而非真正的加密算法。它将任意8位字节序列转化为...
为了使 JavaScript 和 Java 之间的 DES 加密结果可互通,必须确保以下几点一致: 1. **密钥**:两个环境都使用相同的密钥。 2. **模式**:通常选择 ECB(Electronic Codebook)模式,因为它是最简单的,但注意其...
在Java密码学中,对称加密是一种常见的数据保护方法,它涉及到使用相同的密钥进行数据的加密和解密。这个"Java密码学对称加密Demo"可能是为了展示如何在Java应用程序中实现这一过程。Java Cryptography Architecture...