直接上代码

1、Utils类,包括签名和随机字符串

import java.util.Random;import javax.crypto.Mac;import javax.crypto.spec.SecretKeySpec;/** *  * @author mrlixirong * * 2011-11-16 */public class Utils {//签名public static String getSignature(String baseString,String key){String returnStr="";Mac mac = null;byte[] byteHMAC = null;try {mac = Mac.getInstance("HmacSHA1");SecretKeySpec spec = new SecretKeySpec(key.getBytes(), "HmacSHA1");mac.init(spec);byteHMAC = mac.doFinal(baseString.getBytes());returnStr = Base64Encoder.encode(byteHMAC);//returnStr=URLEncoder.encode(returnStr,ENCODING);} catch (Exception e1) {returnStr="error";e1.printStackTrace();}return returnStr;}/* * 获取随机字符串 * 实现方法很多,也很简单,但是对这种简单的东西,开发者有时候就是不想去敲键盘 * 但是不敲就做不下去,本来在此愿意成全和我一样有此烦恼的开发者 */public static String getRandomString(int len){String returnStr="";char[] ch=new char[len];Random rd=new Random();for(int i=0;i<len;i++){ch[i]=(char)(rd.nextInt(9)+97);}returnStr=new String(ch);return returnStr;}}


2、Base64Encoder

public class Base64Encoder {    private static final char last2byte = (char) Integer.parseInt("00000011", 2);    private static final char last4byte = (char) Integer.parseInt("00001111", 2);    private static final char last6byte = (char) Integer.parseInt("00111111", 2);    private static final char lead6byte = (char) Integer.parseInt("11111100", 2);    private static final char lead4byte = (char) Integer.parseInt("11110000", 2);    private static final char lead2byte = (char) Integer.parseInt("11000000", 2);    private static final char[] encodeTable = new char[]{'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', '+', '/'};    public static String encode(byte[] from) {        StringBuffer to = new StringBuffer((int) (from.length * 1.34) + 3);        int num = 0;        char currentByte = 0;        for (int i = 0; i < from.length; i++) {            num = num % 8;            while (num < 8) {                switch (num) {                    case 0:                        currentByte = (char) (from[i] & lead6byte);                        currentByte = (char) (currentByte >>> 2);                        break;                    case 2:                        currentByte = (char) (from[i] & last6byte);                        break;                    case 4:                        currentByte = (char) (from[i] & last4byte);                        currentByte = (char) (currentByte << 2);                        if ((i + 1) < from.length) {                            currentByte |= (from[i + 1] & lead2byte) >>> 6;                        }                        break;                    case 6:                        currentByte = (char) (from[i] & last2byte);                        currentByte = (char) (currentByte << 4);                        if ((i + 1) < from.length) {                            currentByte |= (from[i + 1] & lead4byte) >>> 4;                        }                        break;                }                to.append(encodeTable[currentByte]);                num += 6;            }        }        if (to.length() % 4 != 0) {            for (int i = 4 - to.length() % 4; i > 0; i--) {                to.append("=");            }        }        return to.toString();    }}


项目源代码:http://download.csdn.net/detail/mrlixirong/3804385

更多相关文章

  1. Android(安卓)studio3.x 多渠道打包apk
  2. 第一章 andriod studio 安装与环境搭建
  3. android用户界面-组件Widget-画廊视图Gallery
  4. Android开发者实用代码片段 与大家分享
  5. 【Android(安卓)volley】Android库Volley的使用介绍
  6. android 中使用TextView实现分段显示不同颜色的字符串
  7. exp: 修改Android中strings.xml文件, 动态改变数据
  8. Android(安卓)编程下通过 zipalign 对 APK 文件进行优化
  9. Android(安卓)中数据库查询方法 query() 中的 select

随机推荐

  1. sqlserver存储过程中SELECT 与 SET 对变
  2. sqlserver Case函数应用介绍
  3. SQL 中sp_executesql存储过程的使用帮助
  4. SQL 复合查询条件(AND,OR,NOT)对NULL值的
  5. SQL 中 NULL值测试代码
  6. SQLServer 2000定时执行SQL语句
  7. sql 游标使用笔记
  8. sqlserver 手工实现差异备份的步骤
  9. SQL Server复制功能要避开缺陷的干扰小结
  10. SQL Server允许重复空字段不空字段值唯一