public.cpp 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. #include "StdAfx.h"
  2. #include "public.h"
  3. #include <time.h>
  4. #include <stdio.h>
  5. #include <string.h>
  6. #include <stdlib.h>
  7. const unsigned char hextable[]={"0123456789ABCDEF"};
  8. void ConvAscii(unsigned char *Hex,char *Ascii,unsigned int len)
  9. {
  10. unsigned int i;
  11. for(i=0;i<len;i++)
  12. {
  13. Ascii[2*i]=hextable[Hex[i]>>4];
  14. Ascii[2*i+1]=hextable[Hex[i]&0xf];
  15. }
  16. Ascii[2*len]=0;
  17. }
  18. //*******************************************************************************
  19. void AsciiToHex(char *Ascii,unsigned char *Hex,int len)
  20. {
  21. int i;
  22. unsigned char ch;
  23. for(i=0;i<len;i=i+2)
  24. {
  25. ch=(Ascii[i]&0xf);
  26. if(Ascii[i]>'9')
  27. ch+=9;
  28. Hex[i/2]=ch<<4;
  29. ch=Ascii[i+1]&0xf;
  30. if(Ascii[i+1]>'9')
  31. ch+=9;
  32. Hex[i/2]+=ch;
  33. }
  34. }
  35. int convTo3x(unsigned char*from,int flen,char*to)
  36. {
  37. int i = 0;
  38. unsigned char ch;
  39. for(i=0;i<flen;++i) {
  40. ch=from[i];
  41. ch>>=4;
  42. ch&=0x0f;
  43. ch|=0x30;
  44. to[i*2] = ch;
  45. ch=from[i];
  46. ch&=0x0f;
  47. ch|=0x30;
  48. to[i*2+1]=ch;
  49. }
  50. return flen*2;
  51. }
  52. int _3xToHex(char *Ascii,unsigned char *Hex,int len)
  53. {
  54. int i = 0,j=0;
  55. unsigned char tmp[512] = {0};
  56. unsigned char ch;
  57. for(i = 0;i<len;i++)
  58. {
  59. j = 2*i;
  60. ch = Ascii[j]&0x0F;
  61. ch<<=4;
  62. ch |= (Ascii[j+1]&0x0F);
  63. tmp[j/2] = ch;
  64. }
  65. memcpy(Hex,tmp,len/2);
  66. return (len/2);
  67. }
  68. int get_random(int len,unsigned char*random)
  69. {
  70. int iloop;
  71. unsigned char ch;
  72. srand((int)time(NULL));
  73. for(iloop=0;iloop<len;iloop++)
  74. {
  75. ch = rand()%256;
  76. if(ch==0)
  77. {
  78. iloop--;
  79. continue;
  80. }
  81. random[iloop]=ch;
  82. }
  83. return iloop;
  84. }
  85. int RSA_GetBitLen(unsigned char *a, int alen)
  86. {
  87. int i;
  88. int temp;
  89. int bitlen;
  90. if (0 == alen)
  91. return 0;
  92. for(i = alen-1;i >= 0; i--)
  93. {
  94. if(a[i] > 0)
  95. break;
  96. }
  97. if(i == -1)
  98. {
  99. return 0;
  100. }
  101. temp = i;
  102. bitlen = temp << 3;
  103. for (i = 7; i >= 0; i--)
  104. {
  105. if (a[temp] & (1 << i))
  106. break;
  107. }
  108. bitlen += (int)(i + 1);
  109. return bitlen;
  110. }