f_psw_bczh.srf 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. $PBExportHeader$f_psw_bczh.srf
  2. global type f_psw_bczh from function_object
  3. end type
  4. forward prototypes
  5. global function string f_psw_bczh (string obj_string, integer add_expr, string keystr)
  6. end prototypes
  7. global function string f_psw_bczh (string obj_string, integer add_expr, string keystr);//f_psw_BCzh(STRING obj_string,INT add_expr,STRING keystr) 三倍变长加密,可以用于任意字符串
  8. //obj_string 目标的处理字符串
  9. //add_expr 0 :加密,1:解密
  10. //keystr 密钥数字字符串
  11. //IF add_expr = 0 THEN
  12. // obj_string = FromAnsi( ToAnsi ( obj_string ) )
  13. //end if
  14. IF IsNull(obj_string) THEN RETURN obj_string
  15. Int LS_XX,STR_LEN,LS_YY
  16. String RT_STRING = '',ZH_STR = '',FORMAT_STR
  17. STR_LEN = Lena(obj_string)
  18. //IF STR_LEN=0 THEN RETURN ''
  19. //FORMAT_STR=RIGHT(STRING(Pi(10)/1.11111,'0.###############'),15)
  20. FORMAT_STR = keystr
  21. IF Lena(FORMAT_STR) > 0 THEN
  22. IF add_expr = 0 THEN
  23. FOR LS_YY = 1 To (STR_LEN/Lena(FORMAT_STR))+1
  24. ZH_STR = ZH_STR+FORMAT_STR
  25. NEXT
  26. ELSE
  27. FOR LS_YY = 1 To ((STR_LEN/3)/Lena(FORMAT_STR))+1
  28. ZH_STR = ZH_STR+FORMAT_STR
  29. NEXT
  30. END IF
  31. END IF
  32. IF add_expr = 0 THEN //ADD
  33. FOR LS_XX = 1 TO STR_LEN
  34. RT_STRING = RT_STRING+String(999 - Integer(Mida(ZH_STR,LS_XX,1))^2 * 9 - Asc(Mida(obj_string,LS_XX,1)) ,'000') //
  35. NEXT
  36. RT_STRING = Reverse(RT_STRING)
  37. IF RT_STRING = '' THEN RT_STRING = '3003003003'
  38. ELSE //EXPR
  39. IF obj_string = '3003003003' THEN
  40. RT_STRING = ''
  41. ELSEIF obj_string = '' THEN
  42. // RT_STRING = '12233445'
  43. RT_STRING = ''
  44. ELSE
  45. obj_string = Reverse(obj_string)
  46. FOR LS_XX = 1 TO STR_LEN/3
  47. //MESSAGEBOX(STRINASC(Mid (obj_string,LS_XX*3 - 2,3)))
  48. IF Integer(Mida(obj_string,LS_XX*3 - 2,3)) = 0 THEN
  49. RT_STRING = RT_STRING+String(Asc(Mida(obj_string,LS_XX*3 - 2,3))*13)
  50. ELSE
  51. RT_STRING = RT_STRING+Char(999 - Integer(Mida(ZH_STR,LS_XX,1))^2 * 9 - Integer(Mida(obj_string,LS_XX*3 - 2,3)) ) //
  52. END IF
  53. NEXT
  54. END IF
  55. END IF
  56. RETURN RT_STRING
  57. end function