java Base64

import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.io.PrintStream;

public class Base64
{
  private static final char[] legalChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".toCharArray();

  private static int decode(char paramChar)
  {
    if ((paramChar >= 'A') && (paramChar <= 'Z'))
      return paramChar - 'A';
    if ((paramChar >= 'a') && (paramChar <= 'z'))
      return 26 + (paramChar - 'a');
    if ((paramChar >= '0') && (paramChar <= '9'))
      return 26 + (26 + (paramChar - '0'));
    if (paramChar != '+')
    {
      if (paramChar != '/')
      {
        if (paramChar != '=')
        {
          StringBuilder localStringBuilder = new StringBuilder("unexpected code: ");
          localStringBuilder.append(paramChar);
          throw new RuntimeException(localStringBuilder.toString());
        }
        return 0;
      }
      return 63;
    }
    return 62;
  }

  private static void decode(String paramString, OutputStream paramOutputStream)
    throws IOException
  {
    int i = 0;
    int j = paramString.length();
    while (true)
    {
      if ((i < j) && (paramString.charAt(i) <= ' '))
      {
        i++;
        continue;
      }
      if (i == j)
        return;
      int k = (decode(paramString.charAt(i)) << 18) + (decode(paramString.charAt(i + 1)) << 12) + (decode(paramString.charAt(i + 2)) << 6) + decode(paramString.charAt(i + 3));
      paramOutputStream.write(0xFF & k >> 16);
      if (paramString.charAt(i + 2) == '=')
        return;
      paramOutputStream.write(0xFF & k >> 8);
      if (paramString.charAt(i + 3) == '=')
        return;
      paramOutputStream.write(k & 0xFF);
      i += 4;
    }
  }

  public static byte[] decode(String paramString)
  {
    ByteArrayOutputStream localByteArrayOutputStream = new ByteArrayOutputStream();
    try
    {
      decode(paramString, localByteArrayOutputStream);
      byte[] arrayOfByte = localByteArrayOutputStream.toByteArray();
      try
      {
        localByteArrayOutputStream.close();
        return arrayOfByte;
      }
      catch (IOException localIOException2)
      {
        PrintStream localPrintStream = System.err;
        StringBuilder localStringBuilder = new StringBuilder("Error while decoding BASE64: ");
        localStringBuilder.append(localIOException2.toString());
        localPrintStream.println(localStringBuilder.toString());
        return arrayOfByte;
      }
    }
    catch (IOException localIOException1)
    {
    }
    throw new RuntimeException();
  }

  public static String encode(byte[] paramArrayOfByte)
  {
    int i = paramArrayOfByte.length;
    StringBuffer localStringBuffer = new StringBuffer(3 * paramArrayOfByte.length / 2);
    int j = i - 3;
    int k = 0;
    int m = 0;
    while (true)
    {
      if (k > j)
      {
        if (k == -2 + (0 + i))
        {
          int i3 = (0xFF & paramArrayOfByte[k]) << 16 | (0xFF & paramArrayOfByte[(k + 1)]) << 8;
          localStringBuffer.append(legalChars[(0x3F & i3 >> 18)]);
          localStringBuffer.append(legalChars[(0x3F & i3 >> 12)]);
          localStringBuffer.append(legalChars[(0x3F & i3 >> 6)]);
          localStringBuffer.append("=");
        }
        else if (k == -1 + (0 + i))
        {
          int i2 = (0xFF & paramArrayOfByte[k]) << 16;
          localStringBuffer.append(legalChars[(0x3F & i2 >> 18)]);
          localStringBuffer.append(legalChars[(0x3F & i2 >> 12)]);
          localStringBuffer.append("==");
        }
        return localStringBuffer.toString();
      }
      int n = (0xFF & paramArrayOfByte[k]) << 16 | (0xFF & paramArrayOfByte[(k + 1)]) << 8 | 0xFF & paramArrayOfByte[(k + 2)];
      localStringBuffer.append(legalChars[(0x3F & n >> 18)]);
      localStringBuffer.append(legalChars[(0x3F & n >> 12)]);
      localStringBuffer.append(legalChars[(0x3F & n >> 6)]);
      localStringBuffer.append(legalChars[(n & 0x3F)]);
      k += 3;
      int i1 = m + 1;
      if (m >= 14)
      {
        localStringBuffer.append(" ");
        m = 0;
        continue;
      }
      m = i1;
    }
  }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Base64是一种常用的编码方法,用于将二进制数据表示为可打印字符。在Java中,有多种方式可以进行Base64的加密和解密操作。可以使用sun.misc.BASE64Encoder和sun.misc.BASE64Decoder类进行加密和解密操作,也可以使用com.sun.org.apache.xerces.internal.impl.dv.util.Base64类进行相同的操作。以下是使用这两种方式进行Base64编码和解码的示例代码: 方法一: ```java import sun.misc.BASE64Encoder; import sun.misc.BASE64Decoder; public class Base64 { public static void main(String[] args) { System.out.println(Base64.getBase64Encode("你们好!!!")); System.out.println(Base64.getBase64Decode("5L2g5Lus5aW977yB77yB77yB")); } // 加密 public static String getBase64Encode(String str) { byte[] b = null; String s = null; try { b = str.getBytes("utf-8"); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } if (b != null) { s = new BASE64Encoder().encode(b); } return s; } // 解密 public static String getBase64Decode(String s) { byte[] b = null; String result = null; if (s != null) { BASE64Decoder decoder = new BASE64Decoder(); try { b = decoder.decodeBuffer(s); result = new String(b, "utf-8"); } catch (Exception e) { e.printStackTrace(); } } return result; } } ``` 方法二: ```java import com.sun.org.apache.xerces.internal.impl.dv.util.Base64; public class Base64Demo { public static void main(String[] args) { // 加密 System.out.println(Base64Demo.getBase64Encode("Hello,World!")); // 解密 System.out.println(Base64Demo.getBase64Decode("SGVsbG9Xb3JsZA==")); } public static String getBase64Encode(String str) { if (str == null || "".equals(str)) { return ""; } try { byte[] bt = str.getBytes("UTF-8"); str = String.valueOf(Base64.encode(bt)); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } return str; } public static String getBase64Decode(String str) { if (str == null || "".equals(str)) { return ""; } char[] ch = str.toCharArray(); byte[] bt = Base64.decode(String.valueOf(ch)); try { str = new String(bt,"UTF-8"); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } return str; } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

老大不小心

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值