1.base64编码转换

     所谓base64编码,即按照规则把字符转化为"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"这个字符集中的字符。具体规则如下:

  a.把每3个字节为一组,共24bit。每6bit一小组,每组前面加00,变为32bit。这样3个字节被扩展成了4个节,按照上面字符集编码。

  b.如果字节数不足3:

          1)当字节数为2时,共16bit。每6bit一小组,最后一组即只有4bit,则不止前面加00以外,后面也要补00,按照上面字符集编码,末尾补=。

          2)当字节数为1时,共8bit。每6bit一小组,最后一组即只有2bit,则不止前面加00以外,后面也要补0000,按照上面字符集编码,末尾补==.。

  2.计算机如何表示负数。(以byte基本类型为例)

     在java中一个byte为一个字节共8bit,可表示范围00000000——11111111(0~255)。在计算机中把0——01111111表示为0~127,把10000000——11111111表示为-128 ~-1。那么这样如-127+127,即01111111+10000001=100000000,相加等于模(256),即互为补码。

  3.java位运算。

    在java中(加,减,乘,除,右移,左移,无符号右移,位与,位或,位异或)操作,均会是首先将byte,short,char转化为int,再进行相应运算。举例:

     

public class Test {
public static void main(String[] args) {
byte s1 = (byte) 0xFF;// -1
byte s2 = (byte) 0x80;// -128
System.out.println((byte)(s1+s2));//s1+s2=-129,强制转化为byte,此时溢出,java处理溢出(+-)256*n,256为byte类型的模,则结果为-129+256=127;
byte s5 = -28;
System.out.println(s5 << 2);// 结果为-112, 先转换为int类型,右边补0,高位舍弃
System.out.println(s5>>2);//结果为-7,先转换为int类型,高位补符号位,低位舍弃
System.out.println(s5>>>2);//结果为1073741817,先转换为int类型,高位补0,低位舍弃
System.out.println((s5&0xFC)>>2);
}
}

  4.java实现base64编码方式

    

/**
* @author zyw 2017年2月21日
*/
package test; import java.io.UnsupportedEncodingException; /**
* 1.补码 2.位运算 3.base64
*
* @description 学习base64加密 第一步,将每三个字节作为一组,一共是24个二进制位。
* 第二步,将这24个二进制位分为四组,每个组有6个二进制位。 第三步,在每组前面加两个00,扩展成32个二进制位,即四个字节。
*
*/
public class Base64 {
static private final int SIXTEENBIT = 16;
static private final int EIGHTBIT = 8;
static private final char PAD = '=';
public static void main(String[] args) throws UnsupportedEncodingException {
System.out.println(Base64.toBase64("中国fggfgfgf234234%#$%^#$$", "UTF-8"));//5Lit5Zu9ZmdnZmdmZ2YyMzQyMzQlIyQlXiMkJA==
}
/**
* base64加密
* @param str
* @param charsetName
* @return
* @throws UnsupportedEncodingException
*/
public static String toBase64(String str, String charsetName) throws UnsupportedEncodingException {
if (str.length() < 0)
return "";
byte[] text = str.getBytes(charsetName);
char[] base = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".toCharArray();// 加密
int lengthDataBits = text.length * 8;
int fewerThan24bits = lengthDataBits % 24;// 加密字符串长度是否超过24
int numberTriplets = lengthDataBits / 24;
int number = fewerThan24bits != 0 ? numberTriplets + 1 : numberTriplets;// 计算字符串加密后字符总个数
char[] toBase64Text = new char[number * 4];// 用来保存结果
byte s1, s2, s3;
int index = 0, order = 0;
for (int i = 0; i < numberTriplets; i++) {
s1 = text[index++];
s2 = text[index++];
s3 = text[index++];
toBase64Text[order++] = base[(s1 & 0xFC) >> 2];// 第一个6位
toBase64Text[order++] = base[((s1 & 0x03) << 4) + ((s2 & 0xF0) >> 4)];// 第二个6位
toBase64Text[order++] = base[((s2 & 0x0F) << 2) + ((s3 & 0xC0) >> 6)];// 第三个6位
toBase64Text[order++] = base[s3 & 0x3f];// 第四个6位
}
/**
* 一个字节的情况:将这一个字节的8个二进制位最后一组除了前面加二个0以外,后面再加4个0。这样得到一个二位的Base64编码,
* 再在末尾补上两个"="号。
*/
if (fewerThan24bits == EIGHTBIT) {
byte last = text[index++];
toBase64Text[order++] = base[(last & 0xFC) >> 2];
toBase64Text[order++] = base[((last & 0x03) << 4)];
toBase64Text[order++] = PAD;
toBase64Text[order++] = PAD;
}
/**
* 二个字节的情况:将这二个字节的一共16个二进制位,转成三组,最后一组除了前面加两个0以外,后面也要加两个0。
* 这样得到一个三位的Base64编码,再在末尾补上一个"="号。
*/
if (fewerThan24bits == SIXTEENBIT) {
s1 = text[index++];
s2 = text[index++];
toBase64Text[order++] = base[(s1 & 0xFC) >> 2];
toBase64Text[order++] = base[(s1 & 0x03) << 4 + ((s2 & 0xF0) >> 4)];
toBase64Text[order++] = base[(s2 & 0x0f) << 2];
toBase64Text[order++] = PAD;
}
return new String(toBase64Text);
}
}

  

          

java 自定义实现base64编码转换的更多相关文章

  1. Base64编码转换原理

    Base64编码,是我们程序开发中经常使用到的编码方法.它是一种基于用64个可打印字符来表示二进制数据的表示方法.它通常用作存储.传输一些二进制数据编码方法.它其实只是定义用可打印字符传输内容一种方法 ...

  2. 字符串与图片的Base64编码转换操作

    //图片 转为 base64编码的文本 private void button1_Click(object sender, EventArgs e) { OpenFileDialog dlg = ne ...

  3. java 图片处理 base64编码和图片二进制编码相互转换

    今天在弄小程序项目时,涉及上传图片的更改. 以下是代码: /** * -> base64 * @param imgFile * @return * @throws IOException */ ...

  4. 将base64编码转换图片

    /// <summary> /// 二进制Base64编码转图片 /// </summary> /// <param name="bytes"> ...

  5. java byte[]和base64互相转换

      1.方式一 import java.io.UnsupportedEncodingException; import java.util.Base64; // byte[]转base64 Strin ...

  6. Java对网络图片/本地图片转换成Base64编码和解码

    一.将本地图片转换成Base64编码字符串 /** * 将本地图片转换成Base64编码字符串 * * @param imgFile 图片目录路径 * @return */ public static ...

  7. java base64编码、解码的三种方式

      java base64编码.解码 CreationTime--2018年7月24日10点38分 Author:Marydon 1.方式一:DatatypeConverter 说明:使用jdk自带的 ...

  8. VUE Base64编码图片展示与转换图片

    图片的 base64 编码就是可以将一副图片数据编码成一串字符串,使用该字符串代替图像地址,使用 base64 传输图片文件可以节省一个 http 请求,图片的 base64 编码可以算是前端优化的一 ...

  9. Base64编码原来是这么回事儿

    鸣谢CSDN文章:https://blog.csdn.net/believesoul/article/details/84100616 一.言简意赅理解Base64编码 就是将以"字节&qu ...

随机推荐

  1. NOIP2018提高组省一冲奖班模测训练(三)

    NOIP2018提高组省一冲奖班模测训练(三) 自己按照noip的方式考,只在最后一两分钟交了一次 第一题过了,对拍拍到尾. 第二题不会.考试时往组合计数的方向想,推公式,推了一个多小时,大脑爆炸,还 ...

  2. like

    5.在WHERE中使用like做模糊查询    %符号表示0到多个任意字符    _符号表示1个任意字符     //查询名字中含有O字符的员工信息   select empno,ename   fr ...

  3. oracle用户锁定

    https://www.cnblogs.com/lostyue/archive/2011/12/06/2278063.html

  4. 关于nodejs的线程模型可以看这篇文章

    虽然还是有一些没有讲全,但是整体还是讲的很不错的. http://www.ruanyifeng.com/blog/2014/10/event-loop.html

  5. HDU 5410(2015多校10)-CRB and His Birthday(全然背包)

    题目地址:HDU 5410 题意:有M元钱,N种礼物,若第i种礼物买x件的话.会有Ai*x+Bi颗糖果,现给出每种礼物的单位价格.Ai值与Bi值.问最多能拿到多少颗糖果. 思路:全然背包问题. dp[ ...

  6. HDU 3949 XOR(高斯消元搞基)

    HDU 3949 XOR pid=3949" target="_blank" style="">题目链接 题意:给定一些数字,问任取几个异或值第 ...

  7. nyoj 585 取石子(六) 【Nim】

    取石子(六) 时间限制:1000 ms  |  内存限制:65535 KB 难度:3 描写叙述 近期TopCoder的PIAOYI和HRDV非常无聊,于是就想了一个游戏,游戏是这种:有n堆石子,两个人 ...

  8. gist.github.com

    hosts添加:192.30.253.118 gist.github.com

  9. sicily 1137 河床 (二分分治)

    <计算机算法设计与分析>啃书中... 有点看不进书,就来刷个水题吧,刚开始看错题了还. 注意:是所有测量点相差均不大于di而不是相邻两点... //1137.河床 #include < ...

  10. OC冒泡排序算法

    面试的时候很多公司会要求写一个冒泡排序算法,于是用OC写了一个,代码如下所示 需要注意的事项:oc数组只能存放oc对象,因此遍历数组输出的时候,记得通过NSString对象转换成intValue #i ...