isoutil.java

来自「java pos,你可以直接编译运行,」· Java 代码 · 共 1,158 行 · 第 1/3 页

JAVA
1,158
字号
    }    /**     * converts a byte array to printable characters     * @param b - byte array     * @return String representation     */    public static String dumpString(byte[] b) {        StringBuffer d = new StringBuffer(b.length * 2);        for (int i=0; i<b.length; i++) {            char c = (char) b[i];            if (Character.isISOControl (c)) {                // TODO: complete list of control characters,                // use a String[] instead of this weird switch                switch (c) {                    case '\r'  : d.append ("{CR}");   break;                    case '\n'  : d.append ("{LF}");   break;                    case '\000': d.append ("{NULL}"); break;                    case '\001': d.append ("{SOH}");  break;                    case '\002': d.append ("{STX}");  break;                    case '\003': d.append ("{ETX}");  break;                    case '\004': d.append ("{EOT}");  break;                    case '\005': d.append ("{ENQ}");  break;                    case '\006': d.append ("{ACK}");  break;                    case '\007': d.append ("{BEL}");  break;                    case '\020': d.append ("{DLE}");  break;                    case '\025': d.append ("{NAK}");  break;                    case '\026': d.append ("{SYN}");  break;                    case '\034': d.append ("{FS}");  break;                    case '\036': d.append ("{RS}");  break;                    default:                        char hi = Character.forDigit ((b[i] >> 4) & 0x0F, 16);                        char lo = Character.forDigit (b[i] & 0x0F, 16);                        d.append('[');                        d.append(Character.toUpperCase(hi));                        d.append(Character.toUpperCase(lo));                        d.append(']');                        break;                }            }            else                d.append (c);        }        return d.toString();    }    /**     * converts a byte array to hex string      * (suitable for dumps and ASCII packaging of Binary fields     * @param b - byte array     * @param offset  - starting position     * @param len     * @return String representation     */    public static String hexString(byte[] b, int offset, int len) {        StringBuffer d = new StringBuffer(len * 2);        len += offset;        for (int i=offset; i<len; i++) {            char hi = Character.forDigit ((b[i] >> 4) & 0x0F, 16);            char lo = Character.forDigit (b[i] & 0x0F, 16);            d.append(Character.toUpperCase(hi));            d.append(Character.toUpperCase(lo));        }        return d.toString();    }    /**     * bit representation of a BitSet     * suitable for dumps and debugging     * @param b - the BitSet     * @return string representing the bits (i.e. 011010010...)     */    public static String bitSet2String (BitSet b) {        int len = b.size();        len = (len > 128) ? 128: len;        StringBuffer d = new StringBuffer(len);        for (int i=0; i<len; i++)            d.append (b.get(i) ? '1' : '0');        return d.toString();    }    /**     * converts a BitSet into a binary field     * used in pack routines     * @param b - the BitSet     * @return binary representation     */    public static byte[] bitSet2byte (BitSet b)    {        int len = (b.length() > 65) ? 128 : 64;        byte[] d = new byte[len >> 3];        for (int i=0; i<len; i++)             if (b.get(i+1))                 d[i >> 3] |= (0x80 >> (i % 8));        if (len>64)            d[0] |= 0x80;        return d;    }    /**     * Converts a binary representation of a Bitmap field     * into a Java BitSet     * @param b - binary representation     * @param offset - staring offset     * @param bitZeroMeansExtended - true for ISO-8583     * @return java BitSet object     */    public static BitSet byte2BitSet         (byte[] b, int offset, boolean bitZeroMeansExtended)    {        int len = bitZeroMeansExtended ?            ((b[offset] & 0x80) == 0x80 ? 128 : 64) : 64;        BitSet bmap = new BitSet (len);        for (int i=0; i<len; i++)             if (((b[offset + (i >> 3)]) & (0x80 >> (i % 8))) > 0)                bmap.set(i+1);        return bmap;    }    /**     * Converts a binary representation of a Bitmap field     * into a Java BitSet     * @param bmap - BitSet     * @param b - hex representation     * @param bitOffset - (i.e. 0 for primary bitmap, 64 for secondary)     * @return java BitSet object     */    public static BitSet byte2BitSet (BitSet bmap, byte[] b, int bitOffset)    {        int len = b.length << 3;        for (int i=0; i<len; i++)             if (((b[i >> 3]) & (0x80 >> (i % 8))) > 0)                bmap.set(bitOffset + i + 1);        return bmap;    }    /**     * Converts an ASCII representation of a Bitmap field     * into a Java BitSet     * @param b - hex representation     * @param offset - starting offset     * @param bitZeroMeansExtended - true for ISO-8583     * @return java BitSet object     */    public static BitSet hex2BitSet         (byte[] b, int offset, boolean bitZeroMeansExtended)    {        int len = bitZeroMeansExtended ?          ((Character.digit((char)b[offset],16) & 0x08) == 8 ? 128 : 64) :          64;        BitSet bmap = new BitSet (len);        for (int i=0; i<len; i++) {            int digit = Character.digit((char)b[offset + (i >> 2)], 16);            if ((digit & (0x08 >> (i%4))) > 0)                bmap.set(i+1);        }        return bmap;    }    /**     * Converts an ASCII representation of a Bitmap field     * into a Java BitSet     * @param bmap - BitSet     * @param b - hex representation     * @param bitOffset - (i.e. 0 for primary bitmap, 64 for secondary)     * @return java BitSet object     */    public static BitSet hex2BitSet (BitSet bmap, byte[] b, int bitOffset)    {        int len = b.length << 2;        for (int i=0; i<len; i++) {            int digit = Character.digit((char)b[i >> 2], 16);            if ((digit & (0x08 >> (i%4))) > 0)                bmap.set (bitOffset + i + 1);        }        return bmap;    }    /**     * @param   b       source byte array     * @param   offset  starting offset     * @param   len     number of bytes in destination (processes len*2)     * @return  byte[len]     */    public static byte[] hex2byte (byte[] b, int offset, int len) {        byte[] d = new byte[len];        for (int i=0; i<len*2; i++) {            int shift = i%2 == 1 ? 0 : 4;            d[i>>1] |= Character.digit((char) b[offset+i], 16) << shift;        }        return d;    }    /**     * @param s source string (with Hex representation)     * @return byte array     */    public static byte[] hex2byte (String s) {        return hex2byte (s.getBytes(), 0, s.length() >> 1);    }    /**     * format double value     * @param amount    the amount     * @param fieldLen  the field len     * @return a String of fieldLen characters (right justified)     */    public static String formatDouble(double d, int len) {        String prefix = Long.toString((long) d);        String suffix = Integer.toString (            (int) ((Math.round(d * 100f)) % 100) );        try {            prefix = ISOUtil.padleft(prefix,len-3,' ');            suffix = ISOUtil.zeropad(suffix, 2);        } catch (ISOException e) {            e.printStackTrace();        }        return prefix + "." + suffix;    }    /**     * prepare long value used as amount for display     * (implicit 2 decimals)     * @param l value     * @param len display len     * @return formated field     * @exception ISOException     */    public static String formatAmount(long l, int len) throws ISOException {        String buf = Long.toString(l);        if (l < 100)            buf = zeropad(buf, 3);        StringBuffer s = new StringBuffer(padleft (buf, len-1, ' ') );        s.insert(len-3, '.');        return s.toString();    }    /**     * XML normalizer     * @param s source String     * @param canonical true if we want to normalize \r and \n as well     * @return normalized string suitable for XML Output     */    public static String normalize (String s, boolean canonical) {        StringBuffer str = new StringBuffer();        int len = (s != null) ? s.length() : 0;        for (int i = 0; i < len; i++) {            char ch = s.charAt(i);            switch (ch) {                case '<':                     str.append("&lt;");                    break;                case '>':                     str.append("&gt;");                    break;                case '&':                     str.append("&amp;");                    break;                case '"':                     str.append("&quot;");                    break;                case '\r':                case '\n':                     if (canonical) {                        str.append("&#");                        str.append(Integer.toString(ch));                        str.append(';');                        break;                    }                    // else, default append char                default:                     if (ch >= 0x20 && ch <= 0x7F)                        str.append(ch);                    else {                        str.append("&#");                        str.append(Integer.toString(ch));                        str.append(';');                    }            }        }        return (str.toString());    }    /**     * XML normalizer (default canonical)     * @param s source String     * @return normalized string suitable for XML Output     */    public static String normalize (String s) {        return normalize (s, true);    }    /**     * Protects PAN, Track2, CVC (suitable for logs).     *     * <pre>     * "40000101010001" is converted to "400001____0001"     * "40000101010001=020128375" is converted to "400001____0001=0201_____"     * "123" is converted to "___"     * </pre>     * @param s string to be protected      * @return 'protected' String     */    public static String protect (String s) {        StringBuffer sb = new StringBuffer();        int len   = s.length();        int clear = len > 6 ? 6 : 0;        int lastFourIndex = -1;        if (clear > 0) {            lastFourIndex = s.indexOf ('=') - 4;            if (lastFourIndex < 0) {                lastFourIndex = s.indexOf ('^') - 4;                if (lastFourIndex < 0)                     lastFourIndex = len - 4;            }        }        for (int i=0; i<len; i++) {            if (s.charAt(i) == '=')                clear = 5;            else if (s.charAt(i) == '^') {                lastFourIndex = 0;                clear = len - i;            }            else if (i == lastFourIndex)                clear = 4;            sb.append (clear-- > 0 ? s.charAt(i) : '_');        }        return sb.toString();    }    public static int[] toIntArray(String s) {        StringTokenizer st = new StringTokenizer (s);        int[] array = new int [st.countTokens()];        for (int i=0; st.hasMoreTokens(); i++)             array[i] = Integer.parseInt (st.nextToken());        return array;    }    /**     * Bitwise XOR between corresponding bytes     * @param op1 byteArray1     * @param op2 byteArray2     * @return an array of length = the smallest between op1 and op2     */    public static byte[] xor (byte[] op1, byte[] op2) {        byte[] result = null;        // Use the smallest array        if (op2.length > op1.length) {            result = new byte[op1.length];        }        else {            result = new byte[op2.length];        }        for (int i = 0; i < result.length; i++) {            result[i] = (byte)(op1[i] ^ op2[i]);        }        return  result;    }    /**     * Bitwise XOR between corresponding byte arrays represented in hex     * @param op1 hexstring 1     * @param op2 hexstring 2     * @return an array of length = the smallest between op1 and op2     */    public static String hexor (String op1, String op2) {        byte[] xor = xor (hex2byte (op1), hex2byte (op2));        return hexString (xor);    }    /**     * Trims a byte[] to a certain length     * @param array the byte[] to be trimmed     * @param length the wanted length     * @return the trimmed byte[]     */    public static byte[] trim (byte[] array, int length) {        byte[] trimmedArray = new byte[length];        System.arraycopy(array, 0, trimmedArray, 0, length);        return  trimmedArray;    }    /**     * Concatenates two byte arrays (array1 and array2)     * @param array1     * @param array2     * @return the concatenated array     */    public static byte[] concat (byte[] array1, byte[] array2) {        byte[] concatArray = new byte[array1.length + array2.length];        System.arraycopy(array1, 0, concatArray, 0, array1.length);        System.arraycopy(array2, 0, concatArray, array1.length, array2.length);        return  concatArray;

⌨️ 快捷键说明

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