📄 tigerdigest.java
字号:
package org.bouncycastle.crypto.digests;
import org.bouncycastle.crypto.Digest;
/**
* implementation of Tiger based on:
* <a href="http://www.cs.technion.ac.il/~biham/Reports/Tiger">
* http://www.cs.technion.ac.il/~biham/Reports/Tiger</a>
*/
public class TigerDigest
implements Digest
{
/*
* S-Boxes.
*/
private static final long[] t1 = {
0x02AAB17CF7E90C5EL /* 0 */, 0xAC424B03E243A8ECL /* 1 */,
0x72CD5BE30DD5FCD3L /* 2 */, 0x6D019B93F6F97F3AL /* 3 */,
0xCD9978FFD21F9193L /* 4 */, 0x7573A1C9708029E2L /* 5 */,
0xB164326B922A83C3L /* 6 */, 0x46883EEE04915870L /* 7 */,
0xEAACE3057103ECE6L /* 8 */, 0xC54169B808A3535CL /* 9 */,
0x4CE754918DDEC47CL /* 10 */, 0x0AA2F4DFDC0DF40CL /* 11 */,
0x10B76F18A74DBEFAL /* 12 */, 0xC6CCB6235AD1AB6AL /* 13 */,
0x13726121572FE2FFL /* 14 */, 0x1A488C6F199D921EL /* 15 */,
0x4BC9F9F4DA0007CAL /* 16 */, 0x26F5E6F6E85241C7L /* 17 */,
0x859079DBEA5947B6L /* 18 */, 0x4F1885C5C99E8C92L /* 19 */,
0xD78E761EA96F864BL /* 20 */, 0x8E36428C52B5C17DL /* 21 */,
0x69CF6827373063C1L /* 22 */, 0xB607C93D9BB4C56EL /* 23 */,
0x7D820E760E76B5EAL /* 24 */, 0x645C9CC6F07FDC42L /* 25 */,
0xBF38A078243342E0L /* 26 */, 0x5F6B343C9D2E7D04L /* 27 */,
0xF2C28AEB600B0EC6L /* 28 */, 0x6C0ED85F7254BCACL /* 29 */,
0x71592281A4DB4FE5L /* 30 */, 0x1967FA69CE0FED9FL /* 31 */,
0xFD5293F8B96545DBL /* 32 */, 0xC879E9D7F2A7600BL /* 33 */,
0x860248920193194EL /* 34 */, 0xA4F9533B2D9CC0B3L /* 35 */,
0x9053836C15957613L /* 36 */, 0xDB6DCF8AFC357BF1L /* 37 */,
0x18BEEA7A7A370F57L /* 38 */, 0x037117CA50B99066L /* 39 */,
0x6AB30A9774424A35L /* 40 */, 0xF4E92F02E325249BL /* 41 */,
0x7739DB07061CCAE1L /* 42 */, 0xD8F3B49CECA42A05L /* 43 */,
0xBD56BE3F51382F73L /* 44 */, 0x45FAED5843B0BB28L /* 45 */,
0x1C813D5C11BF1F83L /* 46 */, 0x8AF0E4B6D75FA169L /* 47 */,
0x33EE18A487AD9999L /* 48 */, 0x3C26E8EAB1C94410L /* 49 */,
0xB510102BC0A822F9L /* 50 */, 0x141EEF310CE6123BL /* 51 */,
0xFC65B90059DDB154L /* 52 */, 0xE0158640C5E0E607L /* 53 */,
0x884E079826C3A3CFL /* 54 */, 0x930D0D9523C535FDL /* 55 */,
0x35638D754E9A2B00L /* 56 */, 0x4085FCCF40469DD5L /* 57 */,
0xC4B17AD28BE23A4CL /* 58 */, 0xCAB2F0FC6A3E6A2EL /* 59 */,
0x2860971A6B943FCDL /* 60 */, 0x3DDE6EE212E30446L /* 61 */,
0x6222F32AE01765AEL /* 62 */, 0x5D550BB5478308FEL /* 63 */,
0xA9EFA98DA0EDA22AL /* 64 */, 0xC351A71686C40DA7L /* 65 */,
0x1105586D9C867C84L /* 66 */, 0xDCFFEE85FDA22853L /* 67 */,
0xCCFBD0262C5EEF76L /* 68 */, 0xBAF294CB8990D201L /* 69 */,
0xE69464F52AFAD975L /* 70 */, 0x94B013AFDF133E14L /* 71 */,
0x06A7D1A32823C958L /* 72 */, 0x6F95FE5130F61119L /* 73 */,
0xD92AB34E462C06C0L /* 74 */, 0xED7BDE33887C71D2L /* 75 */,
0x79746D6E6518393EL /* 76 */, 0x5BA419385D713329L /* 77 */,
0x7C1BA6B948A97564L /* 78 */, 0x31987C197BFDAC67L /* 79 */,
0xDE6C23C44B053D02L /* 80 */, 0x581C49FED002D64DL /* 81 */,
0xDD474D6338261571L /* 82 */, 0xAA4546C3E473D062L /* 83 */,
0x928FCE349455F860L /* 84 */, 0x48161BBACAAB94D9L /* 85 */,
0x63912430770E6F68L /* 86 */, 0x6EC8A5E602C6641CL /* 87 */,
0x87282515337DDD2BL /* 88 */, 0x2CDA6B42034B701BL /* 89 */,
0xB03D37C181CB096DL /* 90 */, 0xE108438266C71C6FL /* 91 */,
0x2B3180C7EB51B255L /* 92 */, 0xDF92B82F96C08BBCL /* 93 */,
0x5C68C8C0A632F3BAL /* 94 */, 0x5504CC861C3D0556L /* 95 */,
0xABBFA4E55FB26B8FL /* 96 */, 0x41848B0AB3BACEB4L /* 97 */,
0xB334A273AA445D32L /* 98 */, 0xBCA696F0A85AD881L /* 99 */,
0x24F6EC65B528D56CL /* 100 */, 0x0CE1512E90F4524AL /* 101 */,
0x4E9DD79D5506D35AL /* 102 */, 0x258905FAC6CE9779L /* 103 */,
0x2019295B3E109B33L /* 104 */, 0xF8A9478B73A054CCL /* 105 */,
0x2924F2F934417EB0L /* 106 */, 0x3993357D536D1BC4L /* 107 */,
0x38A81AC21DB6FF8BL /* 108 */, 0x47C4FBF17D6016BFL /* 109 */,
0x1E0FAADD7667E3F5L /* 110 */, 0x7ABCFF62938BEB96L /* 111 */,
0xA78DAD948FC179C9L /* 112 */, 0x8F1F98B72911E50DL /* 113 */,
0x61E48EAE27121A91L /* 114 */, 0x4D62F7AD31859808L /* 115 */,
0xECEBA345EF5CEAEBL /* 116 */, 0xF5CEB25EBC9684CEL /* 117 */,
0xF633E20CB7F76221L /* 118 */, 0xA32CDF06AB8293E4L /* 119 */,
0x985A202CA5EE2CA4L /* 120 */, 0xCF0B8447CC8A8FB1L /* 121 */,
0x9F765244979859A3L /* 122 */, 0xA8D516B1A1240017L /* 123 */,
0x0BD7BA3EBB5DC726L /* 124 */, 0xE54BCA55B86ADB39L /* 125 */,
0x1D7A3AFD6C478063L /* 126 */, 0x519EC608E7669EDDL /* 127 */,
0x0E5715A2D149AA23L /* 128 */, 0x177D4571848FF194L /* 129 */,
0xEEB55F3241014C22L /* 130 */, 0x0F5E5CA13A6E2EC2L /* 131 */,
0x8029927B75F5C361L /* 132 */, 0xAD139FABC3D6E436L /* 133 */,
0x0D5DF1A94CCF402FL /* 134 */, 0x3E8BD948BEA5DFC8L /* 135 */,
0xA5A0D357BD3FF77EL /* 136 */, 0xA2D12E251F74F645L /* 137 */,
0x66FD9E525E81A082L /* 138 */, 0x2E0C90CE7F687A49L /* 139 */,
0xC2E8BCBEBA973BC5L /* 140 */, 0x000001BCE509745FL /* 141 */,
0x423777BBE6DAB3D6L /* 142 */, 0xD1661C7EAEF06EB5L /* 143 */,
0xA1781F354DAACFD8L /* 144 */, 0x2D11284A2B16AFFCL /* 145 */,
0xF1FC4F67FA891D1FL /* 146 */, 0x73ECC25DCB920ADAL /* 147 */,
0xAE610C22C2A12651L /* 148 */, 0x96E0A810D356B78AL /* 149 */,
0x5A9A381F2FE7870FL /* 150 */, 0xD5AD62EDE94E5530L /* 151 */,
0xD225E5E8368D1427L /* 152 */, 0x65977B70C7AF4631L /* 153 */,
0x99F889B2DE39D74FL /* 154 */, 0x233F30BF54E1D143L /* 155 */,
0x9A9675D3D9A63C97L /* 156 */, 0x5470554FF334F9A8L /* 157 */,
0x166ACB744A4F5688L /* 158 */, 0x70C74CAAB2E4AEADL /* 159 */,
0xF0D091646F294D12L /* 160 */, 0x57B82A89684031D1L /* 161 */,
0xEFD95A5A61BE0B6BL /* 162 */, 0x2FBD12E969F2F29AL /* 163 */,
0x9BD37013FEFF9FE8L /* 164 */, 0x3F9B0404D6085A06L /* 165 */,
0x4940C1F3166CFE15L /* 166 */, 0x09542C4DCDF3DEFBL /* 167 */,
0xB4C5218385CD5CE3L /* 168 */, 0xC935B7DC4462A641L /* 169 */,
0x3417F8A68ED3B63FL /* 170 */, 0xB80959295B215B40L /* 171 */,
0xF99CDAEF3B8C8572L /* 172 */, 0x018C0614F8FCB95DL /* 173 */,
0x1B14ACCD1A3ACDF3L /* 174 */, 0x84D471F200BB732DL /* 175 */,
0xC1A3110E95E8DA16L /* 176 */, 0x430A7220BF1A82B8L /* 177 */,
0xB77E090D39DF210EL /* 178 */, 0x5EF4BD9F3CD05E9DL /* 179 */,
0x9D4FF6DA7E57A444L /* 180 */, 0xDA1D60E183D4A5F8L /* 181 */,
0xB287C38417998E47L /* 182 */, 0xFE3EDC121BB31886L /* 183 */,
0xC7FE3CCC980CCBEFL /* 184 */, 0xE46FB590189BFD03L /* 185 */,
0x3732FD469A4C57DCL /* 186 */, 0x7EF700A07CF1AD65L /* 187 */,
0x59C64468A31D8859L /* 188 */, 0x762FB0B4D45B61F6L /* 189 */,
0x155BAED099047718L /* 190 */, 0x68755E4C3D50BAA6L /* 191 */,
0xE9214E7F22D8B4DFL /* 192 */, 0x2ADDBF532EAC95F4L /* 193 */,
0x32AE3909B4BD0109L /* 194 */, 0x834DF537B08E3450L /* 195 */,
0xFA209DA84220728DL /* 196 */, 0x9E691D9B9EFE23F7L /* 197 */,
0x0446D288C4AE8D7FL /* 198 */, 0x7B4CC524E169785BL /* 199 */,
0x21D87F0135CA1385L /* 200 */, 0xCEBB400F137B8AA5L /* 201 */,
0x272E2B66580796BEL /* 202 */, 0x3612264125C2B0DEL /* 203 */,
0x057702BDAD1EFBB2L /* 204 */, 0xD4BABB8EACF84BE9L /* 205 */,
0x91583139641BC67BL /* 206 */, 0x8BDC2DE08036E024L /* 207 */,
0x603C8156F49F68EDL /* 208 */, 0xF7D236F7DBEF5111L /* 209 */,
0x9727C4598AD21E80L /* 210 */, 0xA08A0896670A5FD7L /* 211 */,
0xCB4A8F4309EBA9CBL /* 212 */, 0x81AF564B0F7036A1L /* 213 */,
0xC0B99AA778199ABDL /* 214 */, 0x959F1EC83FC8E952L /* 215 */,
0x8C505077794A81B9L /* 216 */, 0x3ACAAF8F056338F0L /* 217 */,
0x07B43F50627A6778L /* 218 */, 0x4A44AB49F5ECCC77L /* 219 */,
0x3BC3D6E4B679EE98L /* 220 */, 0x9CC0D4D1CF14108CL /* 221 */,
0x4406C00B206BC8A0L /* 222 */, 0x82A18854C8D72D89L /* 223 */,
0x67E366B35C3C432CL /* 224 */, 0xB923DD61102B37F2L /* 225 */,
0x56AB2779D884271DL /* 226 */, 0xBE83E1B0FF1525AFL /* 227 */,
0xFB7C65D4217E49A9L /* 228 */, 0x6BDBE0E76D48E7D4L /* 229 */,
0x08DF828745D9179EL /* 230 */, 0x22EA6A9ADD53BD34L /* 231 */,
0xE36E141C5622200AL /* 232 */, 0x7F805D1B8CB750EEL /* 233 */,
0xAFE5C7A59F58E837L /* 234 */, 0xE27F996A4FB1C23CL /* 235 */,
0xD3867DFB0775F0D0L /* 236 */, 0xD0E673DE6E88891AL /* 237 */,
0x123AEB9EAFB86C25L /* 238 */, 0x30F1D5D5C145B895L /* 239 */,
0xBB434A2DEE7269E7L /* 240 */, 0x78CB67ECF931FA38L /* 241 */,
0xF33B0372323BBF9CL /* 242 */, 0x52D66336FB279C74L /* 243 */,
0x505F33AC0AFB4EAAL /* 244 */, 0xE8A5CD99A2CCE187L /* 245 */,
0x534974801E2D30BBL /* 246 */, 0x8D2D5711D5876D90L /* 247 */,
0x1F1A412891BC038EL /* 248 */, 0xD6E2E71D82E56648L /* 249 */,
0x74036C3A497732B7L /* 250 */, 0x89B67ED96361F5ABL /* 251 */,
0xFFED95D8F1EA02A2L /* 252 */, 0xE72B3BD61464D43DL /* 253 */,
0xA6300F170BDC4820L /* 254 */, 0xEBC18760ED78A77AL /* 255 */,
};
private static final long[] t2 = {
0xE6A6BE5A05A12138L /* 256 */, 0xB5A122A5B4F87C98L /* 257 */,
0x563C6089140B6990L /* 258 */, 0x4C46CB2E391F5DD5L /* 259 */,
0xD932ADDBC9B79434L /* 260 */, 0x08EA70E42015AFF5L /* 261 */,
0xD765A6673E478CF1L /* 262 */, 0xC4FB757EAB278D99L /* 263 */,
0xDF11C6862D6E0692L /* 264 */, 0xDDEB84F10D7F3B16L /* 265 */,
0x6F2EF604A665EA04L /* 266 */, 0x4A8E0F0FF0E0DFB3L /* 267 */,
0xA5EDEEF83DBCBA51L /* 268 */, 0xFC4F0A2A0EA4371EL /* 269 */,
0xE83E1DA85CB38429L /* 270 */, 0xDC8FF882BA1B1CE2L /* 271 */,
0xCD45505E8353E80DL /* 272 */, 0x18D19A00D4DB0717L /* 273 */,
0x34A0CFEDA5F38101L /* 274 */, 0x0BE77E518887CAF2L /* 275 */,
0x1E341438B3C45136L /* 276 */, 0xE05797F49089CCF9L /* 277 */,
0xFFD23F9DF2591D14L /* 278 */, 0x543DDA228595C5CDL /* 279 */,
0x661F81FD99052A33L /* 280 */, 0x8736E641DB0F7B76L /* 281 */,
0x15227725418E5307L /* 282 */, 0xE25F7F46162EB2FAL /* 283 */,
0x48A8B2126C13D9FEL /* 284 */, 0xAFDC541792E76EEAL /* 285 */,
0x03D912BFC6D1898FL /* 286 */, 0x31B1AAFA1B83F51BL /* 287 */,
0xF1AC2796E42AB7D9L /* 288 */, 0x40A3A7D7FCD2EBACL /* 289 */,
0x1056136D0AFBBCC5L /* 290 */, 0x7889E1DD9A6D0C85L /* 291 */,
0xD33525782A7974AAL /* 292 */, 0xA7E25D09078AC09BL /* 293 */,
0xBD4138B3EAC6EDD0L /* 294 */, 0x920ABFBE71EB9E70L /* 295 */,
0xA2A5D0F54FC2625CL /* 296 */, 0xC054E36B0B1290A3L /* 297 */,
0xF6DD59FF62FE932BL /* 298 */, 0x3537354511A8AC7DL /* 299 */,
0xCA845E9172FADCD4L /* 300 */, 0x84F82B60329D20DCL /* 301 */,
0x79C62CE1CD672F18L /* 302 */, 0x8B09A2ADD124642CL /* 303 */,
0xD0C1E96A19D9E726L /* 304 */, 0x5A786A9B4BA9500CL /* 305 */,
0x0E020336634C43F3L /* 306 */, 0xC17B474AEB66D822L /* 307 */,
0x6A731AE3EC9BAAC2L /* 308 */, 0x8226667AE0840258L /* 309 */,
0x67D4567691CAECA5L /* 310 */, 0x1D94155C4875ADB5L /* 311 */,
0x6D00FD985B813FDFL /* 312 */, 0x51286EFCB774CD06L /* 313 */,
0x5E8834471FA744AFL /* 314 */, 0xF72CA0AEE761AE2EL /* 315 */,
0xBE40E4CDAEE8E09AL /* 316 */, 0xE9970BBB5118F665L /* 317 */,
0x726E4BEB33DF1964L /* 318 */, 0x703B000729199762L /* 319 */,
0x4631D816F5EF30A7L /* 320 */, 0xB880B5B51504A6BEL /* 321 */,
0x641793C37ED84B6CL /* 322 */, 0x7B21ED77F6E97D96L /* 323 */,
0x776306312EF96B73L /* 324 */, 0xAE528948E86FF3F4L /* 325 */,
0x53DBD7F286A3F8F8L /* 326 */, 0x16CADCE74CFC1063L /* 327 */,
0x005C19BDFA52C6DDL /* 328 */, 0x68868F5D64D46AD3L /* 329 */,
0x3A9D512CCF1E186AL /* 330 */, 0x367E62C2385660AEL /* 331 */,
0xE359E7EA77DCB1D7L /* 332 */, 0x526C0773749ABE6EL /* 333 */,
0x735AE5F9D09F734BL /* 334 */, 0x493FC7CC8A558BA8L /* 335 */,
0xB0B9C1533041AB45L /* 336 */, 0x321958BA470A59BDL /* 337 */,
0x852DB00B5F46C393L /* 338 */, 0x91209B2BD336B0E5L /* 339 */,
0x6E604F7D659EF19FL /* 340 */, 0xB99A8AE2782CCB24L /* 341 */,
0xCCF52AB6C814C4C7L /* 342 */, 0x4727D9AFBE11727BL /* 343 */,
0x7E950D0C0121B34DL /* 344 */, 0x756F435670AD471FL /* 345 */,
0xF5ADD442615A6849L /* 346 */, 0x4E87E09980B9957AL /* 347 */,
0x2ACFA1DF50AEE355L /* 348 */, 0xD898263AFD2FD556L /* 349 */,
0xC8F4924DD80C8FD6L /* 350 */, 0xCF99CA3D754A173AL /* 351 */,
0xFE477BACAF91BF3CL /* 352 */, 0xED5371F6D690C12DL /* 353 */,
0x831A5C285E687094L /* 354 */, 0xC5D3C90A3708A0A4L /* 355 */,
0x0F7F903717D06580L /* 356 */, 0x19F9BB13B8FDF27FL /* 357 */,
0xB1BD6F1B4D502843L /* 358 */, 0x1C761BA38FFF4012L /* 359 */,
0x0D1530C4E2E21F3BL /* 360 */, 0x8943CE69A7372C8AL /* 361 */,
0xE5184E11FEB5CE66L /* 362 */, 0x618BDB80BD736621L /* 363 */,
0x7D29BAD68B574D0BL /* 364 */, 0x81BB613E25E6FE5BL /* 365 */,
0x071C9C10BC07913FL /* 366 */, 0xC7BEEB7909AC2D97L /* 367 */,
0xC3E58D353BC5D757L /* 368 */, 0xEB017892F38F61E8L /* 369 */,
0xD4EFFB9C9B1CC21AL /* 370 */, 0x99727D26F494F7ABL /* 371 */,
0xA3E063A2956B3E03L /* 372 */, 0x9D4A8B9A4AA09C30L /* 373 */,
0x3F6AB7D500090FB4L /* 374 */, 0x9CC0F2A057268AC0L /* 375 */,
0x3DEE9D2DEDBF42D1L /* 376 */, 0x330F49C87960A972L /* 377 */,
0xC6B2720287421B41L /* 378 */, 0x0AC59EC07C00369CL /* 379 */,
0xEF4EAC49CB353425L /* 380 */, 0xF450244EEF0129D8L /* 381 */,
0x8ACC46E5CAF4DEB6L /* 382 */, 0x2FFEAB63989263F7L /* 383 */,
0x8F7CB9FE5D7A4578L /* 384 */, 0x5BD8F7644E634635L /* 385 */,
0x427A7315BF2DC900L /* 386 */, 0x17D0C4AA2125261CL /* 387 */,
0x3992486C93518E50L /* 388 */, 0xB4CBFEE0A2D7D4C3L /* 389 */,
0x7C75D6202C5DDD8DL /* 390 */, 0xDBC295D8E35B6C61L /* 391 */,
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -