iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >在Java中怎么将 Base64编码与String字符串进行转换
  • 508
分享到

在Java中怎么将 Base64编码与String字符串进行转换

javastringbase64 2023-05-31 08:05:21 508人浏览 安东尼
摘要

这篇文章给大家介绍在Java中怎么将 Base64编码与String字符串进行转换,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。具体方法如下:package com.duanlian.daimengmusic

这篇文章给大家介绍在Java中怎么将 Base64编码与String字符串进行转换,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

具体方法如下:

package com.duanlian.daimengmusic.utils;public final class Base64Util {  private static final int BASELENGTH = 128;  private static final int LOOKUPLENGTH = 64;  private static final int TWENTYFOURBITGROUP = 24;  private static final int EIGHTBIT = 8;  private static final int SIXTEENBIT = 16;  private static final int FOURBYTE = 4;  private static final int SIGN = -128;  private static char PAD = '=';  private static byte[] base64Alphabet = new byte[BASELENGTH];  private static char[] lookUpBase64Alphabet = new char[LOOKUPLENGTH];  static {    for (int i = 0; i < BASELENGTH; ++i) {      base64Alphabet[i] = -1;    }    for (int i = 'Z'; i >= 'A'; i--) {      base64Alphabet[i] = (byte) (i - 'A');    }    for (int i = 'z'; i >= 'a'; i--) {      base64Alphabet[i] = (byte) (i - 'a' + 26);    }    for (int i = '9'; i >= '0'; i--) {      base64Alphabet[i] = (byte) (i - '0' + 52);    }    base64Alphabet['+'] = 62;    base64Alphabet['/'] = 63;    for (int i = 0; i <= 25; i++) {      lookUpBase64Alphabet[i] = (char) ('A' + i);    }    for (int i = 26, j = 0; i <= 51; i++, j++) {      lookUpBase64Alphabet[i] = (char) ('a' + j);    }    for (int i = 52, j = 0; i <= 61; i++, j++) {      lookUpBase64Alphabet[i] = (char) ('0' + j);    }    lookUpBase64Alphabet[62] = (char) '+';    lookUpBase64Alphabet[63] = (char) '/';  }  private static boolean isWhiteSpace(char octect) {    return (octect == 0x20 || octect == 0xd || octect == 0xa || octect == 0x9);  }  private static boolean isPad(char octect) {    return (octect == PAD);  }  private static boolean isData(char octect) {    return (octect < BASELENGTH && base64Alphabet[octect] != -1);  }    public static String encode(byte[] binaryData) {    if (binaryData == null) {      return null;    }    int lengthDataBits = binaryData.length * EIGHTBIT;    if (lengthDataBits == 0) {      return "";    }    int fewerThan24bits = lengthDataBits % TWENTYFOURBITGROUP;    int numberTriplets = lengthDataBits / TWENTYFOURBITGROUP;    int numberQuartet = fewerThan24bits != 0 ? numberTriplets + 1        : numberTriplets;    char encodedData[] = null;    encodedData = new char[numberQuartet * 4];    byte k = 0, l = 0, b1 = 0, b2 = 0, b3 = 0;    int encodedIndex = 0;    int dataIndex = 0;    for (int i = 0; i < numberTriplets; i++) {      b1 = binaryData[dataIndex++];      b2 = binaryData[dataIndex++];      b3 = binaryData[dataIndex++];      l = (byte) (b2 & 0x0f);      k = (byte) (b1 & 0x03);      byte val1 = ((b1 & SIGN) == 0) ? (byte) (b1 >> 2)          : (byte) ((b1) >> 2 ^ 0xc0);      byte val2 = ((b2 & SIGN) == 0) ? (byte) (b2 >> 4)          : (byte) ((b2) >> 4 ^ 0xf0);      byte val3 = ((b3 & SIGN) == 0) ? (byte) (b3 >> 6)          : (byte) ((b3) >> 6 ^ 0xfc);      encodedData[encodedIndex++] = lookUpBase64Alphabet[val1];      encodedData[encodedIndex++] = lookUpBase64Alphabet[val2 | (k << 4)];      encodedData[encodedIndex++] = lookUpBase64Alphabet[(l << 2) | val3];      encodedData[encodedIndex++] = lookUpBase64Alphabet[b3 & 0x3f];    }    // fORM integral number of 6-bit groups    if (fewerThan24bits == EIGHTBIT) {      b1 = binaryData[dataIndex];      k = (byte) (b1 & 0x03);      byte val1 = ((b1 & SIGN) == 0) ? (byte) (b1 >> 2)          : (byte) ((b1) >> 2 ^ 0xc0);      encodedData[encodedIndex++] = lookUpBase64Alphabet[val1];      encodedData[encodedIndex++] = lookUpBase64Alphabet[k << 4];      encodedData[encodedIndex++] = PAD;      encodedData[encodedIndex++] = PAD;    } else if (fewerThan24bits == SIXTEENBIT) {      b1 = binaryData[dataIndex];      b2 = binaryData[dataIndex + 1];      l = (byte) (b2 & 0x0f);      k = (byte) (b1 & 0x03);      byte val1 = ((b1 & SIGN) == 0) ? (byte) (b1 >> 2)          : (byte) ((b1) >> 2 ^ 0xc0);      byte val2 = ((b2 & SIGN) == 0) ? (byte) (b2 >> 4)          : (byte) ((b2) >> 4 ^ 0xf0);      encodedData[encodedIndex++] = lookUpBase64Alphabet[val1];      encodedData[encodedIndex++] = lookUpBase64Alphabet[val2 | (k << 4)];      encodedData[encodedIndex++] = lookUpBase64Alphabet[l << 2];      encodedData[encodedIndex++] = PAD;    }    return new String(encodedData);  }    public static byte[] decode(String encoded) {    if (encoded == null) {      return null;    }    char[] base64Data = encoded.toCharArray();    // remove white spaces    int len = removeWhiteSpace(base64Data);    if (len % FOURBYTE != 0) {      return null;// should be divisible by four    }    int numberQuadruple = (len / FOURBYTE);    if (numberQuadruple == 0) {      return new byte[0];    }    byte decodedData[] = null;    byte b1 = 0, b2 = 0, b3 = 0, b4 = 0;    char d1 = 0, d2 = 0, d3 = 0, d4 = 0;    int i = 0;    int encodedIndex = 0;    int dataIndex = 0;    decodedData = new byte[(numberQuadruple) * 3];    for (; i < numberQuadruple - 1; i++) {      if (!isData((d1 = base64Data[dataIndex++]))          || !isData((d2 = base64Data[dataIndex++]))          || !isData((d3 = base64Data[dataIndex++]))          || !isData((d4 = base64Data[dataIndex++]))) {        return null;      }// if found "no data" just return null      b1 = base64Alphabet[d1];      b2 = base64Alphabet[d2];      b3 = base64Alphabet[d3];      b4 = base64Alphabet[d4];      decodedData[encodedIndex++] = (byte) (b1 << 2 | b2 >> 4);      decodedData[encodedIndex++] = (byte) (((b2 & 0xf) << 4) | ((b3 >> 2) & 0xf));      decodedData[encodedIndex++] = (byte) (b3 << 6 | b4);    }    if (!isData((d1 = base64Data[dataIndex++]))        || !isData((d2 = base64Data[dataIndex++]))) {      return null;// if found "no data" just return null    }    b1 = base64Alphabet[d1];    b2 = base64Alphabet[d2];    d3 = base64Data[dataIndex++];    d4 = base64Data[dataIndex++];    if (!isData((d3)) || !isData((d4))) {// Check if they are PAD characters      if (isPad(d3) && isPad(d4)) {        if ((b2 & 0xf) != 0)// last 4 bits should be zero        {          return null;        }        byte[] tmp = new byte[i * 3 + 1];        System.arraycopy(decodedData, 0, tmp, 0, i * 3);        tmp[encodedIndex] = (byte) (b1 << 2 | b2 >> 4);        return tmp;      } else if (!isPad(d3) && isPad(d4)) {        b3 = base64Alphabet[d3];        if ((b3 & 0x3) != 0)// last 2 bits should be zero        {          return null;        }        byte[] tmp = new byte[i * 3 + 2];        System.arraycopy(decodedData, 0, tmp, 0, i * 3);        tmp[encodedIndex++] = (byte) (b1 << 2 | b2 >> 4);        tmp[encodedIndex] = (byte) (((b2 & 0xf) << 4) | ((b3 >> 2) & 0xf));        return tmp;      } else {        return null;      }    } else { // No PAD e.g 3cQl      b3 = base64Alphabet[d3];      b4 = base64Alphabet[d4];      decodedData[encodedIndex++] = (byte) (b1 << 2 | b2 >> 4);      decodedData[encodedIndex++] = (byte) (((b2 & 0xf) << 4) | ((b3 >> 2) & 0xf));      decodedData[encodedIndex++] = (byte) (b3 << 6 | b4);    }    return decodedData;  }    private static int removeWhiteSpace(char[] data) {    if (data == null) {      return 0;    }    // count characters that's not whitespace    int newSize = 0;    int len = data.length;    for (int i = 0; i < len; i++) {      if (!isWhiteSpace(data[i])) {        data[newSize++] = data[i];      }    }    return newSize;  }}

然后是我经过2次封装的类,注释很清楚,拿过去直接用就行

package com.duanlian.daimengmusic.utils;import Android.graphics.Bitmap;import android.graphics.BitmapFactory;import android.util.Base64;import java.io.ByteArrayOutputStream;import java.io.IOException;public class Base64Object {    public static String base64ToString(String base64) {    byte[] decode = Base64Util.decode(base64);    String s = new String(decode);    return s;  }    public static String stringToBase64(String ss) {    byte[] bytes = ss.getBytes();    String encode = Base64Util.encode(bytes);    return encode;  }    public static String bitmapToBase641(Bitmap bitmap) {    String result = null;    ByteArrayOutputStream baos = null;    try {      if (bitmap != null) {        baos = new ByteArrayOutputStream();        bitmap.compress(Bitmap.CompressFormat.JPEG, 100, baos);        baos.flush();        baos.close();        byte[] bitmapBytes = baos.toByteArray();        result = Base64.encodeToString(bitmapBytes, Base64.DEFAULT);      }    } catch (IOException e) {      e.printStackTrace();    } finally {      try {        if (baos != null) {          baos.flush();          baos.close();        }      } catch (IOException e) {        e.printStackTrace();      }    }    return result;  }    public static Bitmap base64ToBitmap(String base64Data) {    byte[] bytes = Base64.decode(base64Data, Base64.DEFAULT);    return BitmapFactory.decodeByteArray(bytes, 0, bytes.length);  }}

关于在Java中怎么将 Base64编码与String字符串进行转换就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: 在Java中怎么将 Base64编码与String字符串进行转换

本文链接: https://www.lsjlt.com/news/224534.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C++ 生态系统中流行库和框架的贡献指南
    作为 c++++ 开发人员,通过遵循以下步骤即可为流行库和框架做出贡献:选择一个项目并熟悉其代码库。在 issue 跟踪器中寻找适合初学者的问题。创建一个新分支,实现修复并添加测试。提交...
    99+
    2024-05-15
    框架 c++ 流行库 git
  • C++ 生态系统中流行库和框架的社区支持情况
    c++++生态系统中流行库和框架的社区支持情况:boost:活跃的社区提供广泛的文档、教程和讨论区,确保持续的维护和更新。qt:庞大的社区提供丰富的文档、示例和论坛,积极参与开发和维护。...
    99+
    2024-05-15
    生态系统 社区支持 c++ overflow 标准库
  • c++中if elseif使用规则
    c++ 中 if-else if 语句的使用规则为:语法:if (条件1) { // 执行代码块 1} else if (条件 2) { // 执行代码块 2}// ...else ...
    99+
    2024-05-15
    c++
  • c++中的继承怎么写
    继承是一种允许类从现有类派生并访问其成员的强大机制。在 c++ 中,继承类型包括:单继承:一个子类从一个基类继承。多继承:一个子类从多个基类继承。层次继承:多个子类从同一个基类继承。多层...
    99+
    2024-05-15
    c++
  • c++中如何使用类和对象掌握目标
    在 c++ 中创建类和对象:使用 class 关键字定义类,包含数据成员和方法。使用对象名称和类名称创建对象。访问权限包括:公有、受保护和私有。数据成员是类的变量,每个对象拥有自己的副本...
    99+
    2024-05-15
    c++
  • c++中优先级是什么意思
    c++ 中的优先级规则:优先级高的操作符先执行,相同优先级的从左到右执行,括号可改变执行顺序。操作符优先级表包含从最高到最低的优先级列表,其中赋值运算符具有最低优先级。通过了解优先级,可...
    99+
    2024-05-15
    c++
  • c++中a+是什么意思
    c++ 中的 a+ 运算符表示自增运算符,用于将变量递增 1 并将结果存储在同一变量中。语法为 a++,用法包括循环和计数器。它可与后置递增运算符 ++a 交换使用,后者在表达式求值后递...
    99+
    2024-05-15
    c++
  • c++中a.b什么意思
    c++kquote>“a.b”表示对象“a”的成员“b”,用于访问对象成员,可用“对象名.成员名”的语法。它还可以用于访问嵌套成员,如“对象名.嵌套成员名.成员名”的语法。 c++...
    99+
    2024-05-15
    c++
  • C++ 并发编程库的优缺点
    c++++ 提供了多种并发编程库,满足不同场景下的需求。线程库 (std::thread) 易于使用但开销大;异步库 (std::async) 可异步执行任务,但 api 复杂;协程库 ...
    99+
    2024-05-15
    c++ 并发编程
  • 如何在 Golang 中备份数据库?
    在 golang 中备份数据库对于保护数据至关重要。可以使用标准库中的 database/sql 包,或第三方包如 github.com/go-sql-driver/mysql。具体步骤...
    99+
    2024-05-15
    golang 数据库备份 mysql git 标准库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作