Welcome to the Java Programming Forums


The professional, friendly Java community. 21,500 members and growing!


The Java Programming Forums are a community of Java programmers from all around the World. Our members have a wide range of skills and they all have one thing in common: A passion to learn and code Java. We invite beginner Java programmers right through to Java professionals to post here and share your knowledge. Become a part of the community, help others, expand your knowledge of Java and enjoy talking with like minded people. Registration is quick and best of all free. We look forward to meeting you.


>> REGISTER NOW TO START POSTING


Members have full access to the forums. Advertisements are removed for registered users.

Results 1 to 2 of 2

Thread: How to Pass Hex number as Argument to main

  1. #1
    Junior Member
    Join Date
    Mar 2012
    Location
    India
    Posts
    3
    My Mood
    Depressed
    Thanks
    0
    Thanked 0 Times in 0 Posts

    Question How to Pass Hex number as Argument to main

    Hi All,

    How to pass a Hex number as argument to main,

    I use this argument as the plain text of a cipher. but i am not able to get the expected output

    here is the code
    /**
     * <b>The Anubis block cipher.</b>
     *
     * <P>
     * <b>References</b>
     *
     * <P>
     * The Anubis algorithm was developed by
     * <a href="mailto:pbarreto@scopus.com.br">Paulo S. L. M. Barreto</a> and
     * <a href="mailto:vincent.rijmen@cryptomathic.com">Vincent Rijmen</a>.
     *
     * See
     *		P.S.L.M. Barreto, V. Rijmen,
     *		``The Anubis block cipher,''
     *		NESSIE submission, 2000.
     * 
     * @author  Paulo S.L.M. Barreto
     * @author	Vincent Rijmen.
     *
     * @version 2.0 (2001.05.15)
     *
     * Differences from version 1.0:
     *
     * This software implements the "tweaked" version of Anubis.
     * Only the S-box and (consequently) the rounds constants have been changed.
     *
     * =============================================================================
     *
     * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ''AS IS'' AND ANY EXPRESS
     * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
     * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE
     * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
     * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
     * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
     * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
     * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     *
     */
    import java.io.*;
    public final class Anubis {
     
     
     
    	private static final String sbox =
            "\uba54\u2f74\u53d3\ud24d\u50ac\u8dbf\u7052\u9a4c" +
            "\uead5\u97d1\u3351\u5ba6\ude48\ua899\udb32\ub7fc" +
            "\ue39e\u919b\ue2bb\u416e\ua5cb\u6b95\ua1f3\ub102" +
            "\uccc4\u1d14\uc363\uda5d\u5fdc\u7dcd\u7f5a\u6c5c" +
            "\uf726\uffed\ue89d\u6f8e\u19a0\uf089\u0f07\uaffb" +
            "\u0815\u0d04\u0164\udf76\u79dd\u3d16\u3f37\u6d38" +
            "\ub973\ue935\u5571\u7b8c\u7288\uf62a\u3e5e\u2746" +
            "\u0c65\u6861\u03c1\u57d6\ud958\ud866\ud73a\uc83c" +
            "\ufa96\ua798\uecb8\uc7ae\u694b\uaba9\u670a\u47f2" +
            "\ub522\ue5ee\ube2b\u8112\u831b\u0e23\uf545\u21ce" +
            "\u492c\uf9e6\ub628\u1782\u1a8b\ufe8a\u09c9\u874e" +
            "\ue12e\ue4e0\ueb90\ua41e\u8560\u0025\uf4f1\u940b" +
            "\ue775\uef34\u31d4\ud086\u7ead\ufd29\u303b\u9ff8" +
            "\uc613\u0605\uc511\u777c\u7a78\u361c\u3959\u1856" +
            "\ub3b0\u2420\ub292\ua3c0\u4462\u10b4\u8443\u93c2" +
            "\u4abd\u8f2d\ubc9c\u6a40\ucfa2\u804f\u1fca\uaa42";
     
    	private static int[] T0 = new int[256];
    	private static int[] T1 = new int[256];
    	private static int[] T2 = new int[256];
    	private static int[] T3 = new int[256];
    	private static int[] T4 = new int[256];
    	private static int[] T5 = new int[256];
     
        ////////////////////////////////////////////////////////////////////////////
     
    	public Anubis() {}
     
    	static {
     
     
    		for (int x = 0; x < 256; x++) {
    			char c = sbox.charAt(x/2);
    			int s1 = ((x & 1) == 0) ? c >>> 8 : c & 0xff;
    			int s2 = s1 << 1;
                if (s2 >= 0x100) {
                    s2 ^= 0x11d; // reduce s2 (mod ROOT)
                }
    			int s4 = s2 << 1;
                if (s4 >= 0x100) {
                    s4 ^= 0x11d; // reduce s4 (mod ROOT)
                }
    			int s6 = s4 ^ s2;
    			int s8 = s4 << 1;
                if (s8 >= 0x100) {
                    s8 ^= 0x11d; // reduce s8 (mod ROOT)
                }
    			int x2 = x  << 1;
                if (x2 >= 0x100) {
                    x2 ^= 0x11d; // reduce x2 (mod ROOT)
                }
    			int x4 = x2 << 1;
                if (x4 >= 0x100) {
                    x4 ^= 0x11d; // reduce x4 (mod ROOT)
                }
    			int x6 = x2 ^ x4;
    			int x8 = x4 << 1;
                if (x8 >= 0x100) {
                    x8 ^= 0x11d; // reduce x8 (mod ROOT)
                }
     
    			T0[x] = (s1 << 24) | (s2 << 16) | (s4 << 8) | s6; // [ S[x], 2S[x], 4S[x], 6S[x]]
    			T1[x] = (s2 << 24) | (s1 << 16) | (s6 << 8) | s4; // [2S[x],  S[x], 6S[x], 4S[x]]
    			T2[x] = (s4 << 24) | (s6 << 16) | (s1 << 8) | s2; // [4S[x], 6S[x],  S[x], 2S[x]]
    			T3[x] = (s6 << 24) | (s4 << 16) | (s2 << 8) | s1; // [6S[x], 4S[x], 2S[x],  S[x]]
    			T4[x] = (s1 << 24) | (s1 << 16) | (s1 << 8) | s1; // [ S[x],  S[x],  S[x],  S[x]]
    			T5[x] = (x  << 24) | (x2 << 16) | (x6 << 8) | x8; // [   x,    2x,    6x,    8x]
    		}
     
     
        } // static
     
    	protected int[/*R + 1*/][/*4*/] roundKeyEnc = null;
    	protected int[/*R + 1*/][/*4*/] roundKeyDec = null;
     
    	/**
    	 * Create the Anubis key schedule for a given cipher key.
    	 * 
         * @param key   The 32N-bit cipher key.
    	 */
    	public final void keySetup(byte[/*4*N*/] key) {
     
    		// determine the N length parameter:
    		int N = key.length/4; // consider only the first 4*N bytes
    		if (N < 4 || N > 10) {
    			throw new RuntimeException("Invalid Anubis key size: " + (32*N) + " bits.");
    		}
    		int[] kappa = new int[N];
    		int[] inter = new int[N];
     
    		// determine number of rounds from key size:
    		int R = 8 + N;
    		roundKeyEnc = new int[R + 1][4];
    		roundKeyDec = new int[R + 1][4];
     
            // map byte array cipher key to initial key state (mu):
            for (int i = 0, pos = 0; i < N; i++) {
    			kappa[i] =
    				((key[pos++]       ) << 24) ^
    				((key[pos++] & 0xff) << 16) ^
    				((key[pos++] & 0xff) <<  8) ^
    				((key[pos++] & 0xff)      );
            }
     
    		// generate R + 1 round keys:
    		for (int r = 0; r <= R; r++) {
    			int K0, K1, K2, K3;
    			/*
    			 * generate r-th round key K^r:
    			 */
    			K0 = T4[(kappa[N - 1] >>> 24)       ];
    			K1 = T4[(kappa[N - 1] >>> 16) & 0xff];
    			K2 = T4[(kappa[N - 1] >>>  8) & 0xff];
    			K3 = T4[(kappa[N - 1]       ) & 0xff];
    			for (int t = N - 2; t >= 0; t--) {
    				K0 = T4[(kappa[t] >>> 24)       ] ^
    					(T5[(K0 >>> 24)       ] & 0xff000000) ^
    					(T5[(K0 >>> 16) & 0xff] & 0x00ff0000) ^
    					(T5[(K0 >>>  8) & 0xff] & 0x0000ff00) ^
    					(T5[(K0       ) & 0xff] & 0x000000ff);
    				K1 = T4[(kappa[t] >>> 16) & 0xff] ^
    					(T5[(K1 >>> 24)       ] & 0xff000000) ^
    					(T5[(K1 >>> 16) & 0xff] & 0x00ff0000) ^
    					(T5[(K1 >>>  8) & 0xff] & 0x0000ff00) ^
    					(T5[(K1       ) & 0xff] & 0x000000ff);
    				K2 = T4[(kappa[t] >>>  8) & 0xff] ^
    					(T5[(K2 >>> 24)       ] & 0xff000000) ^
    					(T5[(K2 >>> 16) & 0xff] & 0x00ff0000) ^
    					(T5[(K2 >>>  8) & 0xff] & 0x0000ff00) ^
    					(T5[(K2       ) & 0xff] & 0x000000ff);
    				K3 = T4[(kappa[t]       ) & 0xff] ^
    					(T5[(K3 >>> 24)       ] & 0xff000000) ^
    					(T5[(K3 >>> 16) & 0xff] & 0x00ff0000) ^
    					(T5[(K3 >>>  8) & 0xff] & 0x0000ff00) ^
    					(T5[(K3       ) & 0xff] & 0x000000ff);
    			}
    			roundKeyEnc[r][0] = K0;
    			roundKeyEnc[r][1] = K1;
    			roundKeyEnc[r][2] = K2;
    			roundKeyEnc[r][3] = K3;
     
    			/*
    			 * compute kappa^{r+1} from kappa^r:
    			 */
    			for (int i = 0; i < N; i++) {
    				inter[i] = 
    					T0[(kappa[     i         ] >>> 24)       ] ^
    					T1[(kappa[(N + i - 1) % N] >>> 16) & 0xff] ^
    					T2[(kappa[(N + i - 2) % N] >>>  8) & 0xff] ^
    					T3[(kappa[(N + i - 3) % N]       ) & 0xff];
    			}
    			kappa[0] =
    				(T0[4*r    ] & 0xff000000) ^
    				(T1[4*r + 1] & 0x00ff0000) ^
    				(T2[4*r + 2] & 0x0000ff00) ^
    				(T3[4*r + 3] & 0x000000ff) ^
    				inter[0];
    			for (int i = 1; i < N; i++) {
    				kappa[i] = inter[i];
    			}
    		}
     
    		// generate inverse key schedule: K'^0 = K^R, K'^R = K^0, K'^r = theta(K^{R-r}):
    		for (int i = 0; i < 4; i++) {
    			roundKeyDec[0][i] = roundKeyEnc[R][i];
    			roundKeyDec[R][i] = roundKeyEnc[0][i];
    		}
    		for (int r = 1; r < R; r++) {
    			for (int i = 0; i < 4; i++) {
    				int v = roundKeyEnc[R - r][i];
    				roundKeyDec[r][i] =
    					T0[T4[(v >>> 24)       ] & 0xff] ^
    					T1[T4[(v >>> 16) & 0xff] & 0xff] ^
    					T2[T4[(v >>>  8) & 0xff] & 0xff] ^
    					T3[T4[(v       ) & 0xff] & 0xff];
    			}
    		}
    	} // keySetup
     
    	/**
         * Either encrypt or decrypt a data block, according to the key schedule.
         * 
         * @param	block		the data block to be encrypted/decrypted.
         * @param	roundKey	the key schedule to be used.
         */
        protected final void crypt(byte[/*16*/] block, int[/*R + 1*/][/*4*/] roundKey) {
    		int[] state = new int[4];
    		int[] inter = new int[4];
    		int R = roundKey.length - 1; // number of rounds
     
            /*
    		 * map byte array block to cipher state (mu)
    		 * and add initial round key (sigma[K^0]):
    		 */
            for (int i = 0, pos = 0; i < 4; i++) {
    			state[i] =
    				((block[pos++]       ) << 24) ^
    				((block[pos++] & 0xff) << 16) ^
    				((block[pos++] & 0xff) <<  8) ^
    				((block[pos++] & 0xff)      ) ^
    				roundKey[0][i];
            }
     
            // R - 1 full rounds:
            for (int r = 1; r < R; r++) {
    			inter[0] =
    				T0[(state[0] >>> 24)       ] ^
    				T1[(state[1] >>> 24)       ] ^
    				T2[(state[2] >>> 24)       ] ^
    				T3[(state[3] >>> 24)       ] ^
    				roundKey[r][0];
    			inter[1] =
    				T0[(state[0] >>> 16) & 0xff] ^
    				T1[(state[1] >>> 16) & 0xff] ^
    				T2[(state[2] >>> 16) & 0xff] ^
    				T3[(state[3] >>> 16) & 0xff] ^
    				roundKey[r][1];
    			inter[2] =
    				T0[(state[0] >>>  8) & 0xff] ^
    				T1[(state[1] >>>  8) & 0xff] ^
    				T2[(state[2] >>>  8) & 0xff] ^
    				T3[(state[3] >>>  8) & 0xff] ^
    				roundKey[r][2];
    			inter[3] =
    				T0[(state[0]       ) & 0xff] ^
    				T1[(state[1]       ) & 0xff] ^
    				T2[(state[2]       ) & 0xff] ^
    				T3[(state[3]       ) & 0xff] ^
    				roundKey[r][3];
    			for (int i = 0; i < 4; i++) {
    				state[i] = inter[i];
    			}
            }
     
            /*
    		 * last round:
    		 */
    		inter[0] =
    			(T0[(state[0] >>> 24)       ] & 0xff000000) ^
    			(T1[(state[1] >>> 24)       ] & 0x00ff0000) ^
    			(T2[(state[2] >>> 24)       ] & 0x0000ff00) ^
    			(T3[(state[3] >>> 24)       ] & 0x000000ff) ^
    			roundKey[R][0];
    		inter[1] =
    			(T0[(state[0] >>> 16) & 0xff] & 0xff000000) ^
    			(T1[(state[1] >>> 16) & 0xff] & 0x00ff0000) ^
    			(T2[(state[2] >>> 16) & 0xff] & 0x0000ff00) ^
    			(T3[(state[3] >>> 16) & 0xff] & 0x000000ff) ^
    			roundKey[R][1];
    		inter[2] =
    			(T0[(state[0] >>>  8) & 0xff] & 0xff000000) ^
    			(T1[(state[1] >>>  8) & 0xff] & 0x00ff0000) ^
    			(T2[(state[2] >>>  8) & 0xff] & 0x0000ff00) ^
    			(T3[(state[3] >>>  8) & 0xff] & 0x000000ff) ^
    			roundKey[R][2];
    		inter[3] =
    			(T0[(state[0]       ) & 0xff] & 0xff000000) ^
    			(T1[(state[1]       ) & 0xff] & 0x00ff0000) ^
    			(T2[(state[2]       ) & 0xff] & 0x0000ff00) ^
    			(T3[(state[3]       ) & 0xff] & 0x000000ff) ^
    			roundKey[R][3];
     
    		// map cipher state to byte array block (mu^{-1}):
            for (int i = 0, pos = 0; i < 4; i++) {
                int w = inter[i];
                block[pos++] = (byte)(w >>> 24);
                block[pos++] = (byte)(w >>> 16);
                block[pos++] = (byte)(w >>>  8);
                block[pos++] = (byte)(w       );
            }
     
        } // crypt
     
    	/**
         * Encrypt a data block.
         * 
         * @param	block	the data buffer to be encrypted.
         */
        public final void encrypt(byte[/*16*/] block) {
    		crypt(block, roundKeyEnc);
        } // encrypt
     
    	/**
         * Decrypt a data block.
         * 
         * @param	block	the data buffer to be decrypted.
         */
        public final void decrypt(byte[/*16*/] block) {
    		crypt(block, roundKeyDec);
        } // decrypt
     
    	private static String display(byte[] array) {
    		char[] val = new char[2*array.length];
    		String hex = "0123456789ABCDEF";
    		for (int i = 0; i < array.length; i++) {
    			int b = array[i] & 0xff;
    			val[2*i    ] = hex.charAt(b >>> 4);
    			val[2*i + 1] = hex.charAt(b &  15);
    		}
    		return String.valueOf(val);
    	}
     
     
    	public static String toHexString(byte[] bytes)
    	{  
          StringBuilder out = new StringBuilder();
          for (byte b: bytes) 
    	    {
              out.append(String.format("%02X", b) + " ");
            }
        return out.toString();
         }
     
     
    	/**
    	 * Generate the test vector set for Anubis.
    	 *
    	 * The test consists of the encryption of every block
    	 * with a single bit set under every key with a single
    	 * bit set for every allowed key size.
    	 */
    	public static void makeTestVectors() {
    		Anubis a = new Anubis();
    		byte[] key, block;
    		block = new byte[16];
     
    		System.out.println("Anubis test vectors");
    		System.out.println("--------------------------------------------------");
    		for (int N = 4; N <= 10; N++) {
    			/*
    			 * test vectors for 32N-bit keys:
    			*/
    			System.out.println("Test vectors for " + (32*N) + "-bit keys:");
    			key = new byte[4*N];
    			for (int i = 0; i < key.length; i++) {
    				key[i] = 0;
    			}
    			for (int i = 0; i < block.length; i++) {
    				block[i] = 0;
    			}
     
    			/*
    			 * iteration test -- encrypt the null block under the null key a large number of times:
    			 */
    			/*
    			System.out.println("Long iteration test:");
    			System.out.print("\tKEY: " + display(key));
    			a.keySetup(key);
    			for (int k = 0; k < 1000000; k++) {
    				a.encrypt(block);
    			}
    			System.out.println("\tCT: " + display(block));
    			for (int k = 0; k < 1000000; k++) {
    				a.decrypt(block);
    			}
    			for (int i = 0; i < block.length; i++) {
    				if (block[i] != 0) {
    					System.out.println("ERROR IN LONG ITERATION TEST!");
    					return;
    				}
    			}
    			*/
    			System.out.println("Null block under all keys with a single bit set:");
    			for (int k = 0; k < 32*N; k++) {
    				// set the k-th bit:
    				key[k/8] |= (byte)(0x80 >>> (k%8));
    				System.out.print("\tKEY: " + display(key));
    				// setup key:
    				a.keySetup(key);
    				// encrypt the null block:
    				a.encrypt(block);
    				System.out.println("\tCT: " + display(block));
    				System.out.println("\tCT: " + block);
    				// decrypt:
    				a.decrypt(block);
    				for (int i = 0; i < block.length; i++) {
    					if (block[i] != 0) {
    						System.out.println("ERROR IN SINGLE-BIT KEY TEST!");
    						return;
    					}
    				}
    				// reset the k-th key bit:
    				key[k/8] = 0;
    			}
    			System.out.println("--------------------------------------------------");
    		}
    	}
     
    	public static void main(String[] args)
    	{
            Anubis a = new Anubis();
    		byte[] key;
    		//block = new byte[16];
    		key = new byte[16];
    		for (int i=0;i<15 ;i++)
    		{
    		 key[i]=0;
    		 //block[i]=0;
    		}
    		byte[] block = args[0].getBytes();
    		key[0]=(byte)(0x80);
    		int x=100;
    //while(x>0)
    //{
    		//System.out.println("Anubis test vectors");
    		//System.out.println("--------------------------------------------------");
    		//System.out.print("\tKEY: " + display(key));
    				// setup key:
    				a.keySetup(key);
    				// encrypt the null block:
    				//System.out.println("plain>"+block);
    				a.encrypt(block);
    				System.out.println("Cipher>"+display(block));
    				//System.out.println("" + block);
    		/* try {
                    //thread to sleep for the specified number of milliseconds
                    Thread.sleep(20000);
                } catch (Exception e) {
                    System.out.println(e);
                }
    		 */
    		//x=x-1;
    //}		
     
    		/*
    		System.out.println("Press <ENTER> to finish...");
    		System.in.read();
    		*/
    		System.exit(0);
    	}
     
     
    } // Anubis


    Here is what i try to do

    key=80000000000000000000000000000000
    plain=00000000000000000000000000000000
    cipher=B835BDC334829D8371BFA371E4B3C4FD


    java Anubis 0000000000000000
    Cipher>94720C115A776D2FB0CF366C69FDD4BE

    Any clue ,how to solve ?


  2. #2
    Super Moderator Norm's Avatar
    Join Date
    May 2010
    Location
    Eastern Florida
    Posts
    25,140
    Thanks
    65
    Thanked 2,720 Times in 2,670 Posts

    Default Re: How to Pass Hex number as Argument to main

    pass a Hex number as argument to main,
    Are you asking how to convert a String in hex format: "1AB3" that is passed to a main() method on the commandline in a String array to an int value?
    The Integer class's parseInt method has parameters that allow you to specify the radix of the String being converted.
    If you don't understand my answer, don't ignore it, ask a question.

Similar Threads

  1. Argument promotion
    By u-will-neva-no in forum Java Theory & Questions
    Replies: 3
    Last Post: May 16th, 2011, 07:02 AM
  2. How to returned random number to original number?
    By i4ba1 in forum Algorithms & Recursion
    Replies: 2
    Last Post: March 19th, 2011, 04:35 AM
  3. 'pass by value' and 'pass by reference'
    By pokuri in forum Object Oriented Programming
    Replies: 5
    Last Post: January 26th, 2011, 11:30 AM
  4. Replies: 6
    Last Post: November 12th, 2010, 04:40 AM
  5. Replies: 2
    Last Post: March 26th, 2010, 11:22 AM