Как избежать задержки при записи с TextBox строки с случайными значениями в страшнем байте юникода? - VB

Узнай цену своей работы

Формулировка задачи:

С целью сделать текст нечитаемым и при попытке выполнить такой вот код, получаю странную задержку при выполнении. При некоторых значениях j, оператор textbox.Text = num может выполняться от 10 до 40 сек. Это выполнялось в ворд 2003.
Листинг программы
  1. Dim num() As Byte
  2. ---------------------------------
  3. Private Sub cb2_Click()
  4. Randomize
  5. j = Int(255 * Rnd + 1)
  6. num = textbox.Text
  7. For i = 0 To UBound(num) Step 2
  8. num(i + 1) = j
  9. Next
  10. textbox.Text = num
  11. End Sub
Кроме того в VB6 это вообще не работает как надо, потому что при попытке раскодировать текст и выполнении оператора num = textbox.Text всегда получается как если бы старший байт юникода всегда был равен 0, независимо от того что туда заносилось реально. Это касается только VB6 и я вообще не понимаю почему так.
Листинг программы
  1. Private Sub cb1_Click()
  2. num = textbox.Text
  3. For i = 0 To UBound(num) Step 2
  4. num(i + 1) = 0
  5. Next
  6. textbox.Text = num
  7. End Sub
Отсюда 2 вопроса: 1. Как избежать задержки при записи с TextBox строки с случайными значениями в страшнем байте юникода? 2. Как заставить VB6 потом прочитать записаное в него значение и почему у него такое ненормальное поведение? Спасибо.

Решение задачи: «Как избежать задержки при записи с TextBox строки с случайными значениями в страшнем байте юникода?»

textual
Листинг программы
  1. Option Explicit
  2.  
  3. Private Declare Function CryptAcquireContext Lib "advapi32.dll" Alias "CryptAcquireContextA" (ByRef phProv As Long, ByVal pszContainer As String, ByVal pszProvider As String, ByVal dwProvType As Long, ByVal dwFlags As Long) As Long
  4.  
  5. Private Declare Function CryptReleaseContext Lib "advapi32.dll" (ByVal hProv As Long, ByVal dwFlags As Long) As Long
  6. Private Declare Function CryptCreateHash Lib "advapi32.dll" (ByVal hProv As Long, ByVal Algid As Long, ByVal hKey As Long, ByVal dwFlags As Long, ByRef phHash As Long) As Long
  7. Private Declare Function CryptHashData Lib "advapi32.dll" (ByVal hHash As Long, ByVal pbData As String, ByVal dwDataLen As Long, ByVal dwFlags As Long) As Long
  8.        
  9. Private Declare Function CryptDeriveKey Lib "advapi32.dll" (ByVal hProv As Long, ByVal Algid As Long, ByVal hBaseData As Long, ByVal dwFlags As Long, phKey As Long) As Long
  10. Private Declare Function CryptDestroyKey Lib "advapi32.dll" (hKey As Long) As Long
  11.  
  12. Private Declare Function CryptEncrypt Lib "advapi32.dll" (ByVal hKey As Long, ByVal hHash As Long, ByVal Final As Long, ByVal dwFlags As Long, pbData As Any, pdwDataLen As Long, ByVal dwBufLen As Long) As Long
  13. Private Declare Function CryptDecrypt Lib "advapi32.dll" (ByVal hKey As Long, ByVal hHash As Long, ByVal Final As Long, ByVal dwFlags As Long, pbData As Any, pdwDataLen As Long) As Long
  14.  
  15. Private Const ALG_CLASS_DATA_ENCRYPT As Long = 24576
  16. Private Const ALG_TYPE_RSA As Long = 1024
  17. Private Const ALG_SID_RC4 As Long = 1
  18. Private Const ALG_TYPE_STREAM As Long = 2048
  19. Private Const CALG_MD5 As Long = &H8003& ' Hashing algorithm
  20. Private Const CALG_RC4 As Long = (ALG_CLASS_DATA_ENCRYPT Or ALG_TYPE_STREAM Or ALG_SID_RC4)
  21.  
  22. Private Const MS_DEFAULT_PROVIDER  As String = "Microsoft Base Cryptographic Provider v1.0"
  23. Private Const PROV_RSA_FULL As Long = 1
  24. Private Const CRYPT_VERIFYCONTEXT = &HF0000000
  25.  
  26. Public Enum eEncryptionMode
  27.     emEncrypt
  28.     emDecrypt
  29. End Enum
  30.  
  31. Public Function vbEncrypt(ByVal pstrText As String, ByVal pstrPassword As String) As Byte()
  32.     vbEncrypt = CoreCrypto(pstrText, pstrPassword, emEncrypt)
  33. End Function
  34.  
  35. Public Function vbDecrypt(ByVal pstrText As String, ByVal pstrPassword As String) As Byte()
  36.     vbDecrypt = CoreCrypto(pstrText, pstrPassword, emDecrypt)
  37. End Function
  38.  
  39. Private Function CoreCrypto(ByVal pstrText As String, ByVal pstrPassword As String, ByVal pMode As eEncryptionMode) As Byte()
  40.     Dim hProv As Long
  41.     Dim ByteBuffer() As Byte
  42.     Dim strProvider As String
  43.     Dim hHash As Long
  44.     Dim hKey As Long
  45.     Dim lngDataLen As Long
  46.    
  47.    
  48.     ByteBuffer = pstrText
  49.    
  50.     ' Grab an RSA-based cryptoapi context using Microsoft's base provider
  51.    strProvider = MS_DEFAULT_PROVIDER & vbNullChar
  52.     CryptAcquireContext hProv, vbNullString, strProvider, PROV_RSA_FULL, CRYPT_VERIFYCONTEXT ' final param could be  0&
  53.    
  54.     ' Generate a hash of the password
  55.    CryptCreateHash hProv, CALG_MD5, 0, 0, hHash
  56.     CryptHashData hHash, pstrPassword, Len(pstrPassword), 0
  57.    
  58.     ' Derive a symmetric key based on hashed password
  59.    CryptDeriveKey hProv, CALG_RC4, hHash, 0&, hKey
  60.    
  61.     ' Apply decryption or encryption using derived key
  62.    lngDataLen = UBound(ByteBuffer)
  63.    
  64.     Select Case pMode
  65.         Case emEncrypt
  66.             CryptEncrypt hKey, 0, 1, 0, ByteBuffer(0), lngDataLen, UBound(ByteBuffer)

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

7   голосов , оценка 4.286 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы