Java Hex dump Library : Hexadecimal « Data Type « Java

Home
Java
1.2D Graphics GUI
2.3D
3.Advanced Graphics
4.Ant
5.Apache Common
6.Chart
7.Class
8.Collections Data Structure
9.Data Type
10.Database SQL JDBC
11.Design Pattern
12.Development Class
13.EJB3
14.Email
15.Event
16.File Input Output
17.Game
18.Generics
19.GWT
20.Hibernate
21.I18N
22.J2EE
23.J2ME
24.JavaFX
25.JDK 6
26.JDK 7
27.JNDI LDAP
28.JPA
29.JSP
30.JSTL
31.Language Basics
32.Network Protocol
33.PDF RTF
34.Reflection
35.Regular Expressions
36.Scripting
37.Security
38.Servlets
39.Spring
40.Swing Components
41.Swing JFC
42.SWT JFace Eclipse
43.Threads
44.Tiny Application
45.Velocity
46.Web Services SOA
47.XML
Java » Data Type » Hexadecimal 




Java Hex dump Library
      
/*
 * Java Hexdump Library Copyright (c) Matthew Johnson 2005 This program is free
 * software; you can redistribute it and/or modify it under the terms of the GNU
 * Lesser General Public License as published by the Free Software Foundation,
 * version 2 only. This program 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 Lesser
 * General Public License for more details. You should have received a copy of
 * the GNU Lesser General Public License along with this program; if not, write
 * to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
 * Boston, MA 02110-1301, USA. To Contact the author, please email
 [email protected]
 */

//package cx.ath.matthew.utils;

import java.io.PrintStream;

public class Hexdump {
  public static final char[] hexchars = new char[] { '0''1''2''3''4',
      '5''6''7''8''9''a''b''c''d''e''f' };

  public static String format(byte[] buf) {
    return format(buf, 80);
  }

  public static String format(byte[] buf, int width) {
    int bs = (width - 84;
    int i = 0;
    StringBuffer sb = new StringBuffer();
    do {
      for (int j = 0; j < 6; j++) {
        sb.append(hexchars[(i << (j * 40xF00000>> 20]);
      }
      sb.append('\t');
      sb.append(toHex(buf, i, bs));
      sb.append(' ');
      sb.append(toAscii(buf, i, bs));
      sb.append('\n');
      i += bs;
    while (i < buf.length);
    return sb.toString();
  }

  public static void print(byte[] buf) {
    print(buf, System.err);
  }

  public static void print(byte[] buf, int width) {
    print(buf, width, System.err);
  }

  public static void print(byte[] buf, int width, PrintStream out) {
    out.print(format(buf, width));
  }

  public static void print(byte[] buf, PrintStream out) {
    out.print(format(buf));
  }

  public static String toAscii(byte[] buf) {
    return toAscii(buf, 0, buf.length);
  }

  public static String toAscii(byte[] buf, int ofs, int len) {
    StringBuffer sb = new StringBuffer();
    int j = ofs + len;
    for (int i = ofs; i < j; i++) {
      if (i < buf.length) {
        if ((20 <= buf[i]) && (126 >= buf[i])) {
          sb.append((charbuf[i]);
        else {
          sb.append('.');
        }
      else {
        sb.append(' ');
      }
    }
    return sb.toString();
  }

  /**
   * Returns a string which can be written to a Java source file as part of a
   * static initializer for a byte array. Returns data in the format 0xAB,
   * 0xCD, .... use like: javafile.print("byte[] data = {")
   * javafile.print(Hexdump.toByteArray(data)); javafile.println("};");
   */
  public static String toByteArray(byte[] buf) {
    return toByteArray(buf, 0, buf.length);
  }

  /**
   * Returns a string which can be written to a Java source file as part of a
   * static initializer for a byte array. Returns data in the format 0xAB,
   * 0xCD, .... use like: javafile.print("byte[] data = {")
   * javafile.print(Hexdump.toByteArray(data)); javafile.println("};");
   */
  public static String toByteArray(byte[] buf, int ofs, int len) {
    StringBuffer sb = new StringBuffer();
    for (int i = ofs; (i < len&& (i < buf.length); i++) {
      sb.append('0');
      sb.append('x');
      sb.append(hexchars[(buf[i0xF0>> 4]);
      sb.append(hexchars[buf[i0x0F]);
      if (((i + 1< len&& ((i + 1< buf.length)) {
        sb.append(',');
      }
    }
    return sb.toString();
  }

  public static String toHex(byte[] buf) {
    return toHex(buf, 0, buf.length);
  }

  public static String toHex(byte[] buf, int ofs, int len) {
    StringBuffer sb = new StringBuffer();
    int j = ofs + len;
    for (int i = ofs; i < j; i++) {
      if (i < buf.length) {
        sb.append(hexchars[(buf[i0xF0>> 4]);
        sb.append(hexchars[buf[i0x0F]);
        sb.append(' ');
      else {
        sb.append(' ');
        sb.append(' ');
        sb.append(' ');
      }
    }
    return sb.toString();
  }
}

   
    
    
    
    
    
  














Related examples in the same category
1.Convert Decimal to Hexadecimal
2.Convert from decimal to hexadecimal
3.Convert from Byte array to hexadecimal string
4.Convert from decimal to hexadecimal with leading zeroes and uppercase
5.Hex encoder and decoder.
6.Decode hex string to a byte array
7.Returns the hexadecimal value of the supplied byte array
8.Convert byte array to Hex String
9.Convert the bytes to a hex string representation of the bytes
10.Hex decimal dump
11.hex decoder
12.Get Base64 From HEX
13.Converts a hex string to a byte array.
14.append hex digit
15.dump an array of bytes in hex form
16.Get byte array from hex string
17.Check if the current character is an Hex Char <hex> ::= [0x30-0x39] | [0x41-0x46] | [0x61-0x66]
18.Helper function that returns a char from an hex
19.Hex encoder/decoder implementation borrowed from BouncyCastle
20.Util for digesting and encoding bytes/strings.
21.Provide hex utility for converting bytes to hex string
22.Number in hexadecimal format are used throughout Freenet.
23.Convert to/from Hex string
24.This class allows a number to be easily formatted as a hexadecimal number. The representation uses 0-f.
25.This class provides methods for working with hexadecimal representations of data.
26.Hex Util
java2s.com  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.