⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 base64.java

📁 基于MJSIP的j2me客户端
💻 JAVA
字号:
/*
 * Copyright (C) 2005 Luca Veltri - University of Parma - Italy
 * 
 * This file is part of MjSip (http://www.mjsip.org)
 * 
 * MjSip is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 * 
 * MjSip is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 * 
 * You should have received a copy of the GNU General Public License
 * along with MjSip; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 * 
 * Author(s):
 * Luca Veltri (luca.veltri@unipr.it)
 */

package org.zoolu.tools;



/** Class Base64 can be used for base64-encoding a byte array
  * and/or for base64-decoding a base64-string.
  *
  * @author Camilla Ferramola, Univeristy of Parma, Italy - 2004
  */
public class Base64
{ 
   private static final String base64codes ="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";   
   private static int[] aux = new int[4];
                    

   /** Base64 encoder */
   public static String encode(byte[] input)
   {
   	
      String stringacod = "";
      byte[] bin = new  byte[3];
      
      int iter = (input.length)/3;
      int nzero = (input.length)%3;
      int i = 0;
     
      for (i=0; i<iter; i++)
      {              
         bin[0] = input[i*3];
         bin[1] = input[i*3+1];
         bin[2] = input[i*3+2];
         
         aux[0] = ((bin[0] >>> 2)&63);
         aux[1] = ((bin[0] & 3) << 4) + ((bin[1] >>> 4)&15);
         aux[2] = ((bin[1] & 15) << 2) + ((bin[2] >>> 6)&3);
         aux[3] = (bin[2] & 63);
         
         // uso gli interi memorizzati in aux[] come indice della stringa base64codes 
         //System.out.println("aux[0]="+aux[0]+" aux[1]="+aux[1]);
         stringacod = stringacod + base64codes.charAt(aux[0])+ base64codes.charAt(aux[1])+
                      base64codes.charAt(aux[2])+base64codes.charAt(aux[3]);
      } 
   
      if( i==iter )
      {
         if ( nzero==0 )
         {
         }
         else
         if ( nzero==1 )
         {  // l'ultimo pacchetto da analizzare ha 8 bit
            // quindi ottengo due caratteri in base64 e due caratteri padding "="                       
            aux[0] = ((input[iter*3] >>> 2) & 63);
            aux[1] = (input[iter*3] & 3) << 4;
            
            stringacod = stringacod + base64codes.charAt(aux[0])+base64codes.charAt(aux[1])+"==";
         }
         else 
         if (nzero==2)
         {  // l'ultimo pacchetto da analizzare ha 16 bit quindi ottengo
            // tre caratteri in base 64 e uno di padding "="                             
            aux[0] = ((input[iter*3] >>> 2) & 63) ;
            aux[1] = ((input[iter*3] & 3) << 4) + ((input[iter*3+1] >>> 4) & 15);
            aux[2] = (input[iter*3+1 ] & 15) << 2;
            
            stringacod = stringacod + base64codes.charAt(aux[0])+ base64codes.charAt(aux[1])+
                         base64codes.charAt(aux[2])+"=";
         }
      }

      return stringacod;
        
   }

 
   /** Base64 decoder */
   public static byte[] decode (String stringacod)
   {
      // tolgo gli eventuali "=" alla fine della stringa
      int uguale = stringacod.indexOf("=");
      if ( uguale != -1) stringacod = stringacod.substring(0,uguale);
      
      int[] bin = new int[3];
      int iter = (stringacod.length())/4;
      int resto = (stringacod.length())%4;
      
      int nzero = 0;
      if (resto!=0) nzero = 1;    
      byte[] output = new byte[iter*3 + nzero*(resto-1)];    
      
      int i = 0;
      for (i=0; i<iter; i++)
      {  	
         aux[0] = base64codes.indexOf(stringacod.charAt(i*4));
         aux[1] = base64codes.indexOf(stringacod.charAt(i*4+1));
         aux[2] = base64codes.indexOf(stringacod.charAt(i*4+2));
         aux[3] = base64codes.indexOf(stringacod.charAt(i*4+3));
         	  
         bin[0] = (aux[0]<<2) + (aux[1]>>>4);
         bin[1] = (aux[1]%16 <<4) + (aux[2]>>>2);
         bin[2] = (aux[2]%4 <<6) + aux[3];
     	   	  
         output[i*3] = (byte)bin [0];
         output[i*3+1] = (byte)bin [1];
         output[i*3+2] = (byte)bin [2];
      }
      
      if (i==iter)
      {
         // per come 

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -