欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java自定義實現(xiàn)base64編碼轉換

 更新時間:2017年02月23日 08:40:00   作者:不被女生喜歡好多年  
本文主要介紹了java 自定義實現(xiàn)base64編碼轉換的方法,具有很好的參考價值,下面跟著小編一起來看下吧

1.base64編碼轉換

所謂base64編碼,即按照規(guī)則把字符轉化為"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"這個字符集中的字符。具體規(guī)則如下:

a.把每3個字節(jié)為一組,共24bit。每6bit一小組,每組前面加00,變?yōu)?2bit。這樣3個字節(jié)被擴展成了4個節(jié),按照上面字符集編碼。

b.如果字節(jié)數(shù)不足3:

 1)當字節(jié)數(shù)為2時,共16bit。每6bit一小組,最后一組即只有4bit,則不止前面加00以外,后面也要補00,按照上面字符集編碼,末尾補=。

 2)當字節(jié)數(shù)為1時,共8bit。每6bit一小組,最后一組即只有2bit,則不止前面加00以外,后面也要補0000,按照上面字符集編碼,末尾補==.。

2.計算機如何表示負數(shù)。(以byte基本類型為例)

在java中一個byte為一個字節(jié)共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實現(xiàn)base64編碼方式

/**
 * @author zyw 2017年2月21日
 */
package test; 
import java.io.UnsupportedEncodingException;
/**
 * 1.補碼 2.位運算 3.base64
 *
 * @description 學習base64加密 第一步,將每三個字節(jié)作為一組,一共是24個二進制位。
 *  第二步,將這24個二進制位分為四組,每個組有6個二進制位。 第三步,在每組前面加兩個00,擴展成32個二進制位,即四個字節(jié)。
 *
 */
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;// 計算字符串加密后字符總個數(shù)
 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位
 }
 /**
  * 一個字節(jié)的情況:將這一個字節(jié)的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;
 }
 /**
  * 二個字節(jié)的情況:將這二個字節(jié)的一共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);
 }
}

以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!

相關文章

  • java8新特性之Optional的深入解析

    java8新特性之Optional的深入解析

    這篇文章主要給大家介紹了關于java8新特性之Optional的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-02-02
  • Java 實現(xiàn)萬年歷總結

    Java 實現(xiàn)萬年歷總結

    這篇文章主要介紹了Java 萬年歷實現(xiàn)代碼的相關資料,需要的朋友可以參考下
    2016-09-09
  • Java 定時器(Timer)及線程池里使用定時器實例代碼

    Java 定時器(Timer)及線程池里使用定時器實例代碼

    這篇文章主要介紹了Java 定時器(Timer)及線程池里使用定時器實例代碼的相關資料,需要的朋友可以參考下
    2016-12-12
  • 詳解如何在低版本的Spring中快速實現(xiàn)類似自動配置的功能

    詳解如何在低版本的Spring中快速實現(xiàn)類似自動配置的功能

    這篇文章主要介紹了詳解如何在低版本的Spring中快速實現(xiàn)類似自動配置的功能,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • 詳解 Java中日期數(shù)據(jù)類型的處理之格式轉換的實例

    詳解 Java中日期數(shù)據(jù)類型的處理之格式轉換的實例

    這篇文章主要介紹了詳解 Java中日期數(shù)據(jù)類型的處理之格式轉換的實例的相關資料,日期以及時間格式處理,在Java中時間格式一般會涉及到的數(shù)據(jù)類型包括Calendar類和Date類,需要的朋友可以參考下
    2017-08-08
  • Java Thread之Sleep()案例詳解

    Java Thread之Sleep()案例詳解

    這篇文章主要介紹了Java Thread之Sleep()案例詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下
    2021-08-08
  • Java使用x-www-form-urlencoded發(fā)請求方式

    Java使用x-www-form-urlencoded發(fā)請求方式

    在開發(fā)中經(jīng)常使用JSON格式,但遇到x-www-form-urlencoded格式時,可以通過重新封裝處理,POSTMan和APIpost工具中對此編碼的稱呼不同,分別是x-www-form-urlencoded和urlencoded,分享這些經(jīng)驗希望對他人有所幫助
    2024-09-09
  • Java使用POI實現(xiàn)excel文件的導入和導出

    Java使用POI實現(xiàn)excel文件的導入和導出

    這篇文章主要為大家詳細介紹了Java如何使用POI實現(xiàn)excel文件的導入和導出功能,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-12-12
  • Java Synchronized的偏向鎖詳細分析

    Java Synchronized的偏向鎖詳細分析

    synchronized作為Java程序員最常用同步工具,很多人卻對它的用法和實現(xiàn)原理一知半解,以至于還有不少人認為synchronized是重量級鎖,性能較差,盡量少用。但不可否認的是synchronized依然是并發(fā)首選工具,本文就來詳細講講
    2023-04-04
  • Java 非靜態(tài)初始化的例子

    Java 非靜態(tài)初始化的例子

    非靜態(tài)初始化和靜態(tài)初始化一模一樣,只不過少了static關鍵字。但是如果兩者共存的話,非靜態(tài)初始化是比靜態(tài)初始化慢一拍的。下邊我們舉兩個例子來看一下。
    2020-09-09

最新評論