javaee6怎么进行base64加密?

javaee6怎么进行base64加密?,第1张

package com.raqsoft.common

public class Base64

{

private static final char intToBase64[] = {

'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J',

'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T',

'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd',

'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',

'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x',

'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7',

'8', '9', '+', '/'

}

private static final char intToAltBase64[] = {

'!', '"', '#', '$', '%', '&', '\'', '(', ')', ',',

'-', '.', ':', '', '<', '>', '@', '[', ']', '^',

'`', '_', '{', '|', '}', '~', 'a', 'b', 'c', 'd',

'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',

'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x',

'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7',

'8', '9', '+', '?'

}

private static final byte base64ToInt[] = {

-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,

-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,

-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,

-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,

-1, -1, -1, 62, -1, -1, -1, 63, 52, 53,

54, 55, 56, 57, 58, 59, 60, 61, -1, -1,

-1, -1, -1, -1, -1, 0, 1, 2, 3, 4,

5, 6, 7, 8, 9, 10, 11, 12, 13, 14,

15, 16, 17, 18, 19, 20, 21, 22, 23, 24,

25, -1, -1, -1, -1, -1, -1, 26, 27, 28,

29, 30, 31, 32, 33, 34, 35, 36, 37, 38,

39, 40, 41, 42, 43, 44, 45, 46, 47, 48,

49, 50, 51

}

private static final byte altBase64ToInt[] = {

-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,

-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,

-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,

-1, -1, -1, 0, 1, 2, 3, 4, 5, 6,

7, 8, -1, 62, 9, 10, 11, -1, 52, 53,

54, 55, 56, 57, 58, 59, 60, 61, 12, 13,

14, -1, 15, 63, 16, -1, -1, -1, -1, -1,

-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,

-1, -1, -1, -1, -1, -1, -1, -1, -1, -1,

-1, 17, -1, 18, 19, 21, 20, 26, 27, 28,

29, 30, 31, 32, 33, 34, 35, 36, 37, 38,

39, 40, 41, 42, 43, 44, 45, 46, 47, 48,

49, 50, 51, 22, 23, 24, 25

}

public static String byteArrayToBase64(byte bb[]) {

return byteArrayToBase64(bb, false)

}

public static String byteArrayToAltBase64(byte bb[]) {

return byteArrayToBase64(bb, true)

}

private static String byteArrayToBase64(byte bb[], boolean flag) {

int i = bb.length

int j = i / 3

int k = i - 3 * j

int l = 4 * ((i + 2) / 3)

StringBuffer stringbuffer = new StringBuffer(l)

char ac[] = flag ? intToAltBase64 : intToBase64

int i1 = 0

for(int j1 = 0j1 <jj1++) {

int k1 = bb[i1++] &0xff

int i2 = bb[i1++] &0xff

int k2 = bb[i1++] &0xff

stringbuffer.append(ac[k1 >>2])

stringbuffer.append(ac[k1 <<4 &0x3f | i2 >>4])

stringbuffer.append(ac[i2 <<2 &0x3f | k2 >>6])

stringbuffer.append(ac[k2 &0x3f])

}

if(k != 0) {

int l1 = bb[i1++] &0xff

stringbuffer.append(ac[l1 >>2])

if(k == 1) {

stringbuffer.append(ac[l1 <<4 &0x3f])

stringbuffer.append("==")

} else {

int j2 = bb[i1++] &0xff

stringbuffer.append(ac[l1 <<4 &0x3f | j2 >>4])

stringbuffer.append(ac[j2 <<2 &0x3f])

stringbuffer.append('=')

}

}

return stringbuffer.toString()

}

public static byte[] base64ToByteArray(String s) {

return base64ToByteArray(s, false)

}

public static byte[] altBase64ToByteArray(String s) {

return base64ToByteArray(s, true)

}

private static byte[] base64ToByteArray(String s, boolean flag) {

byte bb[] = flag ? altBase64ToInt : base64ToInt

int i = s.length()

int j = i / 4

if(4 * j != i)

throw new IllegalArgumentException("String length must be a multiple of four.")

int k = 0

int l = j

if(i != 0) {

if(s.charAt(i - 1) == '=') {

k++

l--

}

if(s.charAt(i - 2) == '=')

k++

}

byte bc[] = new byte[3 * j - k]

int i1 = 0

int j1 = 0

for(int k1 = 0k1 <lk1++) {

int l1 = base64toInt(s.charAt(i1++), bb)

int j2 = base64toInt(s.charAt(i1++), bb)

int l2 = base64toInt(s.charAt(i1++), bb)

int j3 = base64toInt(s.charAt(i1++), bb)

bc[j1++] = (byte)(l1 <<2 | j2 >>4)

bc[j1++] = (byte)(j2 <<4 | l2 >>2)

bc[j1++] = (byte)(l2 <<6 | j3)

}

if(k != 0) {

int i2 = base64toInt(s.charAt(i1++), bb)

int k2 = base64toInt(s.charAt(i1++), bb)

bc[j1++] = (byte)(i2 <<2 | k2 >>4)

if(k == 1) {

int i3 = base64toInt(s.charAt(i1++), bb)

bc[j1++] = (byte)(k2 <<4 | i3 >>2)

}

}

return bc

}

private static int base64toInt(char c, byte bb[]) {

byte b = bb[c]

if(b <0)

throw new IllegalArgumentException("Illegal character " + c)

else

return b

}

public static void main(String[] args) {

String s = "0123456789"

byte[] b = s.getBytes()

s = Base64.byteArrayToBase64(b)

System.out.println(s)

b = Base64.base64ToByteArray(s)

System.out.println(new String(b))

}

}

JavaEE是用Java编写的一种基于服务器的应用程序平台,它有以下优缺点:

优点:

可移植性:JavaEE应用程序可以在支持Java虚拟机的任何平台上运行,这使得JavaEE应用程序具有很好的可移植性。

安全性:JavaEE平台提供了许多安全机制,包括身份验证、授权和加密等,这使得JavaEE应用程序可以更安全地运行。

可扩展性:JavaEE平台的组件可以相互连接和重用,这使得JavaEE应用程序具有很好的可扩展性。

事务处理:JavaEE平台提供了强大的事务处理机制,可以保证事务的一致性和可靠性。

大型企业应用程序:JavaEE适用于大型企业应用程序开发,可以支持高并发、高吞吐量和大规模数据处理。

缺点:

学习曲线:与其他语言相比,JavaEE有较大的学习曲线,需要学习众多的框架和技术。

复杂性:JavaEE应用程序通常比较复杂,需要设计和实现多个组件之间的协作。

性能:与其他语言相比,JavaEE的性能可能稍低,但随着Java虚拟机的不断优化,性能已经得到很大的改进。

部署复杂性:JavaEE应用程序的部署可能相对复杂,需要配置服务器和环境,但现代的JavaEE容器如Tomcat等已经极大地简化了这个过程。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11666679.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-17
下一篇 2023-05-17

发表评论

登录后才能评论

评论列表(0条)

保存