mas01mj@732
|
1 /*
|
mas01mj@732
|
2 Copyright (c) 2008, Adobe Systems Incorporated
|
mas01mj@732
|
3 All rights reserved.
|
mas01mj@732
|
4
|
mas01mj@732
|
5 Redistribution and use in source and binary forms, with or without
|
mas01mj@732
|
6 modification, are permitted provided that the following conditions are
|
mas01mj@732
|
7 met:
|
mas01mj@732
|
8
|
mas01mj@732
|
9 * Redistributions of source code must retain the above copyright notice,
|
mas01mj@732
|
10 this list of conditions and the following disclaimer.
|
mas01mj@732
|
11
|
mas01mj@732
|
12 * Redistributions in binary form must reproduce the above copyright
|
mas01mj@732
|
13 notice, this list of conditions and the following disclaimer in the
|
mas01mj@732
|
14 documentation and/or other materials provided with the distribution.
|
mas01mj@732
|
15
|
mas01mj@732
|
16 * Neither the name of Adobe Systems Incorporated nor the names of its
|
mas01mj@732
|
17 contributors may be used to endorse or promote products derived from
|
mas01mj@732
|
18 this software without specific prior written permission.
|
mas01mj@732
|
19
|
mas01mj@732
|
20 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
|
mas01mj@732
|
21 IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
|
mas01mj@732
|
22 THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
mas01mj@732
|
23 PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
mas01mj@732
|
24 CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
mas01mj@732
|
25 EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
mas01mj@732
|
26 PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
mas01mj@732
|
27 PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
mas01mj@732
|
28 LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
mas01mj@732
|
29 NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
mas01mj@732
|
30 SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
mas01mj@732
|
31 */
|
mas01mj@732
|
32
|
mas01mj@732
|
33 package com.adobe.crypto {
|
mas01mj@732
|
34 import flash.utils.ByteArray;
|
mas01mj@732
|
35 import flash.utils.Endian;
|
mas01mj@732
|
36 import flash.utils.describeType;
|
mas01mj@732
|
37 /**
|
mas01mj@732
|
38 * Keyed-Hashing for Message Authentication
|
mas01mj@732
|
39 * Implementation based on algorithm description at
|
mas01mj@732
|
40 * http://www.faqs.org/rfcs/rfc2104.html
|
mas01mj@732
|
41 */
|
mas01mj@732
|
42 public class HMAC
|
mas01mj@732
|
43 {
|
mas01mj@732
|
44 /**
|
mas01mj@732
|
45 * Performs the HMAC hash algorithm using byte arrays.
|
mas01mj@732
|
46 *
|
mas01mj@732
|
47 * @param secret The secret key
|
mas01mj@732
|
48 * @param message The message to hash
|
mas01mj@732
|
49 * @param algorithm Hash object to use
|
mas01mj@732
|
50 * @return A string containing the hash value of message
|
mas01mj@732
|
51 * @langversion ActionScript 3.0
|
mas01mj@732
|
52 * @playerversion Flash 8.5
|
mas01mj@732
|
53 * @tiptext
|
mas01mj@732
|
54 */
|
mas01mj@732
|
55 public static function hash( secret:String, message:String, algorithm:Object = null ):String
|
mas01mj@732
|
56 {
|
mas01mj@732
|
57 var text:ByteArray = new ByteArray();
|
mas01mj@732
|
58 var k_secret:ByteArray = new ByteArray();
|
mas01mj@732
|
59
|
mas01mj@732
|
60 text.writeUTFBytes(message);
|
mas01mj@732
|
61 k_secret.writeUTFBytes(secret);
|
mas01mj@732
|
62
|
mas01mj@732
|
63 return hashBytes(k_secret, text, algorithm);
|
mas01mj@732
|
64 }
|
mas01mj@732
|
65
|
mas01mj@732
|
66 /**
|
mas01mj@732
|
67 * Performs the HMAC hash algorithm using string.
|
mas01mj@732
|
68 *
|
mas01mj@732
|
69 * @param secret The secret key
|
mas01mj@732
|
70 * @param message The message to hash
|
mas01mj@732
|
71 * @param algorithm Hash object to use
|
mas01mj@732
|
72 * @return A string containing the hash value of message
|
mas01mj@732
|
73 * @langversion ActionScript 3.0
|
mas01mj@732
|
74 * @playerversion Flash 8.5
|
mas01mj@732
|
75 * @tiptext
|
mas01mj@732
|
76 */
|
mas01mj@732
|
77 public static function hashBytes( secret:ByteArray, message:ByteArray, algorithm:Object = null ):String
|
mas01mj@732
|
78 {
|
mas01mj@732
|
79 var ipad:ByteArray = new ByteArray();
|
mas01mj@732
|
80 var opad:ByteArray = new ByteArray();
|
mas01mj@732
|
81 var endian:String = Endian.BIG_ENDIAN;
|
mas01mj@732
|
82
|
mas01mj@732
|
83 if(algorithm == null){
|
mas01mj@732
|
84 algorithm = MD5;
|
mas01mj@732
|
85 }
|
mas01mj@732
|
86
|
mas01mj@732
|
87 if ( describeType(algorithm).@name.toString() == "com.adobe.crypto::MD5" ) {
|
mas01mj@732
|
88 endian = Endian.LITTLE_ENDIAN;
|
mas01mj@732
|
89 }
|
mas01mj@732
|
90
|
mas01mj@732
|
91 if ( secret.length > 64 ) {
|
mas01mj@732
|
92 algorithm.hashBytes(secret);
|
mas01mj@732
|
93 secret = new ByteArray();
|
mas01mj@732
|
94 secret.endian = endian;
|
mas01mj@732
|
95
|
mas01mj@732
|
96 while ( algorithm.digest.bytesAvailable != 0 ) {
|
mas01mj@732
|
97 secret.writeInt(algorithm.digest.readInt());
|
mas01mj@732
|
98 }
|
mas01mj@732
|
99 }
|
mas01mj@732
|
100
|
mas01mj@732
|
101 secret.length = 64
|
mas01mj@732
|
102 secret.position = 0;
|
mas01mj@732
|
103 for ( var x:int = 0; x < 64; x++ ) {
|
mas01mj@732
|
104 var byte:int = secret.readByte();
|
mas01mj@732
|
105 ipad.writeByte(0x36 ^ byte);
|
mas01mj@732
|
106 opad.writeByte(0x5c ^ byte);
|
mas01mj@732
|
107 }
|
mas01mj@732
|
108
|
mas01mj@732
|
109 ipad.writeBytes(message);
|
mas01mj@732
|
110 algorithm.hashBytes(ipad);
|
mas01mj@732
|
111 var tmp:ByteArray = new ByteArray();
|
mas01mj@732
|
112 tmp.endian = endian;
|
mas01mj@732
|
113
|
mas01mj@732
|
114 while ( algorithm.digest.bytesAvailable != 0 ) {
|
mas01mj@732
|
115 tmp.writeInt(algorithm.digest.readInt());
|
mas01mj@732
|
116 }
|
mas01mj@732
|
117 tmp.position = 0;
|
mas01mj@732
|
118
|
mas01mj@732
|
119 while ( tmp.bytesAvailable != 0 ) {
|
mas01mj@732
|
120 opad.writeByte(tmp.readUnsignedByte());
|
mas01mj@732
|
121 }
|
mas01mj@732
|
122 return algorithm.hashBytes( opad );
|
mas01mj@732
|
123 }
|
mas01mj@732
|
124
|
mas01mj@732
|
125 }
|
mas01mj@732
|
126
|
mas01mj@732
|
127 }
|