编码算法

  • 编码算法是将一种形式转换成等价的另外一种形式。主要是为了方便某种特定场景的处理。
  • 字母如何在计算机中表示呢
    • 用ASCII编码
  • 那中文字符如何在计算机中表示呢
    • 用Unicode编码
  • 如何同时兼容字母和中文呢
    • 用UTF-8编码

  

  • 我浏览器想给服务器发送数据,有没有什么编码方式呢

    • 用URL编码
    • 一般规则
      • A-Z, a-z, 0-9, -_.* 保持不变
      • 其他字符以%XX表示(如,中:%E4%B8%AD (UTF8:E4B8AD))
  • 发邮件的时候二进制附件怎么发送呢

    • 用Base64编码
    • 把二进制数据用文本表示的编码算法,二进制6位6位的通过映射表进行映射。
    • 比如 : 中编码之后是 "5Lit",过程如下

      

    • 点评

      • 适用于文本协议,但长度会增加1/3,如果数组长度不是3的整数倍,末尾会增加一个或两个0x00(对应的是一个或两个==)

摘要算法(哈希算法)

  • 目的是验证原始数据有没有被篡改
  • 一些基本原则
    • 输入长度不定,输出长度固定
    • 相同的输入就有相同的输出
    • 不同的输入尽量得到不同的输出
  • 会有什么问题:有可能会发生碰撞。
  • 一个好的摘要算法需要具备的安全性
    • 碰撞率低
    • 不能猜测输出
    • 输入的任意一个bit的变化都会造成输出的完全的不同
    • 很难从输出反推输入
  • 常用的摘要算法有哪些

    • MD5

      • 可以用于文件验证,存储口令,登录验证。
      • 用于存储口令的时候需要注意什么问题?
        • 需要预防彩虹表攻击:采用一些简单的字符md5加密。
        • 办法是:md5.update(salt+inputPassward) (salt是一些额外的随机数)
    • SHA-1/SHA-256/SHA-512(Secure Hash Algorithm)

      • 可以看成MD5的加强版,输出由128位变为160/256/512位。
      • 但是相应的:加解密速度比MD5要慢。
    • RipeMD 160

      • 第三方提供,非JDK自带,使用时需要先引入对应cprov-jdk15on-160.jar包
    • Hmac(Hash-based Message Authentication Code)

      • 更安全的消息摘要算法,基于秘钥
      • 加密思想类似 md5(salt+input),咱Hmac中salt是64位
      • 可以用HmacMD5/HmacSHA1/HmacSHA256/HmacSHA512几种

编码算法和摘要算法的代码如下

package TestDemo;

import java.io.UnsupportedEncodingException;
import java.math.BigInteger;
import java.net.URLEncoder;
import java.security.InvalidKeyException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.security.Security;
import java.util.Base64; import javax.crypto.KeyGenerator;
import javax.crypto.Mac;
import javax.crypto.SecretKey; import org.bouncycastle.jce.provider.BouncyCastleProvider; public class Test {
public static void main(String[] args) throws NoSuchAlgorithmException, UnsupportedEncodingException, InvalidKeyException { //URL编码
String urlBeforeEncode = "http://www.cnblogs.com/darrenqiao/";
//支持的编码格式 :US-ASCII, ISO-8859-1, UTF-8, UTF-16BE, UTF-16LE, UTF-16
String urlAfterEncode = URLEncoder.encode(urlBeforeEncode, "UTF-8");
System.out.println("url进行URL编码的链接为: " + urlBeforeEncode);
System.out.println("url进行URL编码的链接为: " + urlAfterEncode); byte[] input = new String("darrenqiao").getBytes();
//Base64编码
String urlAfterBase64Encode = Base64.getUrlEncoder().encodeToString(urlBeforeEncode.getBytes());
System.out.println("url进行Base64编码之后的文本: " + urlAfterBase64Encode);
System.out.println("Base64编码前的六进制码流: " + String.format("%032x", new BigInteger(input)));
String base64Output = Base64.getEncoder().encodeToString(input);
System.out.println("Base64编码后的文本: " + base64Output); //MD5加密
MessageDigest md5 = MessageDigest.getInstance("MD5");
System.out.println("加密前的十六进制码流: " + String.format("%032x", new BigInteger(input)));
md5.update(input);
byte[] md5Output = md5.digest();
System.out.println("md5加密后的十六进制码流: " + String.format("%032x", new BigInteger(md5Output))); //SHA-1加密
MessageDigest sha1 = MessageDigest.getInstance("SHA-1");
sha1.update(input);
byte[] sha1Output = sha1.digest();
System.out.println("SHA-1加密后的十六进制码流: " + String.format("%032x", new BigInteger(sha1Output))); //SHA-256加密
MessageDigest sha256 = MessageDigest.getInstance("SHA-256");
sha256.update(input);
byte[] sha256Output = sha256.digest();
System.out.println("SHA-256加密后的十六进制码流: " + String.format("%032x", new BigInteger(sha256Output))); //SHA-512加密
MessageDigest sha512 = MessageDigest.getInstance("SHA-512");
sha512.update(input);
byte[] sha512Output = sha512.digest();
System.out.println("SHA-512加密后的十六进制码流: " + String.format("%032x", new BigInteger(sha512Output))); //RipeMD-160加密
Security.addProvider(new BouncyCastleProvider());
MessageDigest ripeMD160 = MessageDigest.getInstance("RipeMD160");
ripeMD160.update(input);
byte[] ripeMD160Output = ripeMD160.digest();
System.out.println("RipeMD-160加密后的十六进制码流: " + String.format("%032x", new BigInteger(ripeMD160Output))); //HmacMD5加密,HmacSHA1/HmacSHA256/HmacSHA512这几种只要替换参数就可以
KeyGenerator keyGenerator = KeyGenerator.getInstance("HmacMD5");
SecretKey secretKey = keyGenerator.generateKey();
Mac mac = Mac.getInstance("HmacMD5");
mac.init(secretKey);
mac.update(input);
byte[] hmacMD5Output = mac.doFinal();
System.out.println("HmacMD5加密后的十六进制码流: " + String.format("%032x", new BigInteger(hmacMD5Output))); } }

运行结果如下

Java编码算法和摘要算法的更多相关文章

  1. Java 密码学算法

    Java 密码学算法 候捷老师在< 深入浅出MFC 2e(电子版)>中引用林语堂先生的一句话: 只用一样东西,不明白它的道理,实在不高明 只知道How,不知道Why,出了一点小问题时就无能 ...

  2. 【字符编码】字符编码 && Base64编码算法

    一.前言 在前面的解决乱码的一文中,只找到了解决办法,但是没有为什么,说白了,就是对编码还是不是太熟悉,编码问题是一个很简单的问题,计算机从业人员应该也必须弄清楚,基于编码的应用有Base64加密算法 ...

  3. 【JAVA编码专题】深入分析 Java 中的中文编码问题

    http://www.ibm.com/developerworks/cn/java/j-lo-chinesecoding/ 几种常见的编码格式 为什么要编码 不知道大家有没有想过一个问题,那就是为什么 ...

  4. Java排序算法(一)

    Java排序算法(一) 排序的基本概念和分类 1.1排序的定义 在<大话数据结构>中,排序定义为,假设含有n个记录的序列为{r1,r2,...,rn},其相应的关键字{k1,k2,..., ...

  5. Java编码安全

    目录 Java编码安全 数据校验 规则1.1:校验跨信任边界传递的不可信数据 规则1.2:禁止直接使用不可信数据来拼接SQL语句 规则1.4:禁止直接使用不可信数据来记录数据 规则1.6:验证路径前将 ...

  6. Android数据加密之Base64编码算法

    前言: 前面学习总结了平时开发中遇见的各种数据加密方式,最终都会对加密后的二进制数据进行Base64编码,起到一种二次加密的效果,其实呢Base64从严格意义上来说的话不是一种加密算法,而是一种编码算 ...

  7. java编码过滤器

    1.java编码过滤器的作用: java过滤器能够对目标资源的请求和响应进行截取,过滤信息执行的优先级高于servlet. 2.java过滤器的使用: (1)编写一个普通的java类,实现Filter ...

  8. java中文乱码解决之道(四)-----java编码转换过程

    前面三篇博客侧重介绍字符.编码问题,通过这三篇博客各位博友对各种字符编码有了一个初步的了解,要了解java的中文问题这是必须要了解的.但是了解这些仅仅只是一个开始,以下博客将侧重介绍java乱码是如何 ...

  9. 史上最全的java随机数生成算法分享(转)

    这篇文章主要介绍了史上最全的java随机数生成算法,我分享一个最全的随机数的生成算法,最代码的找回密码的随机数就是用的这个方法 String password = RandomUtil.generat ...

随机推荐

  1. 沉淀再出发:Tomcat的实现原理

    沉淀再出发:Tomcat的实现原理 一.前言 在我们接触java之后,相信大家都编写过服务器程序,这个时候就需要用到Tomcat了.Tomcat 服务器是一个开源的轻量级Web应用服务器,在中小型系统 ...

  2. December 22nd 2016 Week 52nd Thursday

    The best hearts are always the bravest. 心灵最高尚的人,往往也是最勇敢的人. Keep conscience clear, don't let too many ...

  3. HDFS Namenode&Datanode

    HDFS Namenode&Datanode HDFS 机制粗略示意图 客户端写入文件流程: NN && DN Namenode(NN)工作机制 NN是整个文件系统的管理节点. ...

  4. UML实践

    UML图一览 1.分工泳道图 使工作内容更加清晰 2.类图 更加细化了一些函数,对于之后的接口文档细节问题进行了约束 3.用例图 实现了一个玩家的整体可操作的概况 4.活动图 1)注册活动图 用于登录 ...

  5. Innodb_io_capacity 对于IO稳定性的一些研究

    背景:最近在做一台线上服务器IO负载情况的时候发现了以下现象: 24小时的IO_UTIL 的曲线看似风平浪静,毛刺较少 但当图片放大到半小时级别的时候发现IO_UTIL即磁盘使用率出现了规律性的波动, ...

  6. BZOJ2330:[SCOI2011]糖果(差分约束)

    Description 幼儿园里有N个小朋友,lxhgww老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果.但是小朋友们也有嫉妒心,总是会提出一些要求,比如小明不希望小红分到的糖果比他的 ...

  7. xss实现获取网站源码

    当网站cookie设置了httponly,xss获取不到到网站的cookie.但是我们是可以获取到网站后台的url. 这时候我们可以xss得到网站后台源码,从而找到网站后台的一些敏感操作:添加用户,删 ...

  8. Odoo权限控制

    转载请注明原文地址:https://www.cnblogs.com/cnodoo/p/9278734.html 一:Odoo中的权限设置主要有以下5种 1)菜单.报表的访问权限 Odoo可以设置菜单项 ...

  9. spring整合mongo及调用

    spring整合mongo(maven工程下): 1.web.xml文件中配置需要加载的配置文件: <listener> <listener-class>org.springf ...

  10. max函数

    无论是几维,都只返回一个最大的值 >>> a = [1,2,3] >>> np.max(a) 3 >>> a = [[2,1],[3,4]] &g ...