[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[文本处理] 批处理用维热纳尔方阵给文本加密

如下,维热纳尔方阵,请发现每行变化的规律。
  1.        A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
  2.        a b c d e f g h i j k l m n o p q r s t u v w x y z
  3. -----------------------------------------------------------
  4. 1      B C D E F G H I J K L M N O P Q R S T U V W X Y Z A
  5. 2      C D E F G H I J K L M N O P Q R S T U V W X Y Z A B
  6. 3      D E F G H I J K L M N O P Q R S T U V W X Y Z A B C
  7. 4      E F G H I J K L M N O P Q R S T U V W X Y Z A B C D
  8. 5      F G H I J K L M N O P Q R S T U V W X Y Z A B C D E
  9. 6      G H I J K L M N O P Q R S T U V W X Y Z A B C D E F
  10. 7      H I J K L M N O P Q R S T U V W X Y Z A B C D E F G
  11. 8      I J K L M N O P Q R S T U V W X Y Z A B C D E F G H
  12. 9      J K L M N O P Q R S T U V W X Y Z A B C D E F G H I
  13. 10     K L M N O P Q R S T U V W X Y Z A B C D E F G H I J
  14. 11     L M N O P Q R S T U V W X Y Z A B C D E F G H I J K
  15. 12     M N O P Q R S T U V W X Y Z A B C D E F G H I J K L
  16. 13     N O P Q R S T U V W X Y Z A B C D E F G H I J K L M
  17. 14     O P Q R S T U V W X Y Z A B C D E F G H I J K L M N
  18. 15     P Q R S T U V W X Y Z A B C D E F G H I J K L M N O
  19. 16     Q R S T U V W X Y Z A B C D E F G H I J K L M N O P
  20. 17     R S T U V W X Y Z A B C D E F G H I J K L M N O P Q
  21. 18     S T U V W X Y Z A B C D E F G H I J K L M N O P Q R
  22. 19     T U V W X Y Z A B C D E F G H I J K L M N O P Q R S
  23. 20     U V W X Y Z A B C D E F G H I J K L M N O P Q R S T
  24. 21     V W X Y Z A B C D E F G H I J K L M N O P Q R S T U
  25. 22     W X Y Z A B C D E F G H I J K L M N O P Q R S T U V
  26. 23     X Y Z A B C D E F G H I J K L M N O P Q R S T U V W
  27. 24     Y Z A B C D E F G H I J K L M N O P Q R S T U V W X
  28. 25     Z A B C D E F G H I J K L M N O P Q R S T U V W X Y
  29. 26     A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
复制代码
加密实例:
用forset来加密better to do well than to say well

密 匙 F O R E S T F O R E S T F O R E S T F O R E S T F O R  
明 文 b e t t e r t o d o w e l l t h a n t o s a y w e l l  
密 文 G S K X W K Y C U S O X Q Z K L S G Y C J E Q P J Z C  
(看第5行,F开头,明文是b,要用G来加密;第14行,O开头,明文是e,要用S来  
加密,如此类推......)

以下。
密匙:trust
明文:believe
密文:U V F A X O V

密匙: false
明文: believe
密文: G E W A I A E

密匙:batch
明文:bbsbathome
密文:C B L D H U H H O L


要求:
一,输入任意密匙和明文,用维热纳尔方阵加密,输出正确结果。
二,如能正确解答出要求一,写出相应的解密程序,只是一个逆推理。

[ 本帖最后由 pusofalse 于 2009-5-1 20:53 编辑 ]
1

评分人数

    • wxcute: 楼主这个主题就很好,我来加分PB + 10
心绪平和,眼藏静谧。

回复 1# pusofalse
看看我这行吗
附件: 您需要登录才可以下载或查看附件。没有帐号?注册

TOP

话说怎么把加密好的密文输出到比如c:\123.txt

TOP

回复 22# 狱渊



解密算法是动态的,有“无限种”可能
密钥能确定其中的一种,并以此推算出明文

TOP

我彻底晕了   明文密钥是做什么的?

TOP

为什么不能加解密带数字的字符串啊

TOP

我来学习下

TOP

  1. @echo off&setlocal enabledelayedexpansion
  2. set x=ABCDEFGHIJKLMNOPQRSTUVWXYZ
  3. set miwen=&set yum=miwen
  4. for /l %%a in (0 1 25) do (
  5.    set /a n=%%a+1,#!x:~%%a,1!=n
  6.    set #!n!=!x:~%%a,1!
  7. )
  8. set /p my=请输入密匙
  9. set /p mw=请输入明文
  10. set m=0
  11. :lp
  12. set/a mm=m+99
  13. for /l %%a in (!m!,1,!mm!) do (
  14. for %%b in (!yum!) do (
  15.   set miwen=!miwen!!#%%b!
  16.   if "!mw:~%%a!" equ "" goto :ok
  17.   set /a "yum=(#!my:~0,1!+#!mw:~%%a,1!+24)%%26+1",m=%%a+1
  18.   set my=!my:~1!!my:~0,1!
  19. )
  20. )
  21. goto :lp
  22. :ok
  23. echo 密文:  !miwen!
  24. pause
复制代码

[ 本帖最后由 netbenton 于 2009-5-14 12:54 编辑 ]
1

评分人数

TOP

  1. @echo off&setlocal enabledelayedexpansion
  2. set "x=ABCDEFGHIJKLMNOPQRSTUVWXYZ"&set code=!x!&set "miwen="
  3. for /l %%a in (1 1 26) do (
  4.    set /a .!x:~0,1!=%%a
  5.    set code2=!code2! !x:~0,1!
  6.    set "x=!x:~1!"
  7. )
  8. set /p my=请输入密匙
  9. set /p mw=请输入明文
  10. for %%a in (!code2!) do set mw=!mw:%%a= %%a !
  11. for %%a in (!mw!) do (
  12.    if not defined my_ set "my_=!my!"
  13.    set /a yum=.!my_:~0,1!,w=.%%a-1
  14.    for %%i in (!yum!) do set "codex=!my_:~0,1!!code:~%%i!!code:~0,%%i!"
  15.    for %%i in (!w!) do set "miwen=!miwen!!codex:~%%i,1!"
  16.    set "my_=!my_:~1!"
  17. )
  18. echo 密文:  !miwen!
  19. pause
复制代码
2

评分人数

技术问题请到论坛发帖求助!

TOP

翻了一个不得了的帖子出来, 有很多东西可以学

TOP

方法:把26位字母与1-26相应的数字对应起来,密文即为明文字母对应的数字与密钥字母对应的数字相加-1所对应的字母。
  1. @echo off&setlocal enabledelayedexpansion
  2. set "code=A B C D E F G H I J K L M N O P Q R S T U V W X Y Z"
  3. for %%i in (%code%) do (
  4.     set /a num+=1
  5.     set t!num!=%%i
  6.     set p%%i=!num!
  7. )
  8. :begin
  9. set /p text=请输入明文:&set /p key=请输入密钥:&set /p=密文:<nul
  10. :loop
  11. set "_text=%text:~,1%"&set "_key=%key:~,1%"
  12. set "text=%text:~1%"&set "key=%key:~1%%_key%"
  13. set /a n=!p%_text%!+!p%_key%!
  14. set /a n=!n!%%26-1
  15. set /p=!t%n%! <nul
  16. if defined text goto loop
  17. echo.&echo.&goto begin
复制代码
set "key=%key:~1%%_key%"一句借鉴了batman的,感觉好多种方法这种最简洁。
  1. 哦,好像和上楼的思想一样啊,不好意思啊,发表以后才仔细看。把标头去了!
复制代码

[ 本帖最后由 lhjoanna 于 2008-11-19 01:24 编辑 ]
1

评分人数

TOP

不过
将 set /a vav=%va2%+%va1% 改成 set /a vav=%va2%+%va1%-1
将 set /a vav=%va1%-%va2%  改成 set /a vav=%va1%-%va2% +1
不就符合要求了吗
  1. @echo off&setlocal enabledelayedexpansion
  2. echo 1、加密  2、解密
  3. set /p bs=
  4. set var=1
  5. for %%i in (a b c d e f g h i j k l m n o p q r s t u v w x y z) do (
  6. set ve=%%i &set "%%i=!var!" &set "!var!=!ve!"
  7. set /a var=!var!+1)
  8. goto %bs%
  9. :1
  10. set /p vaa=请输入明文 :
  11. goto ss
  12. :2
  13. set /p vaa=请输入密文 :
  14. :ss
  15. set /p vab=请输入密钥 :
  16. :st
  17. set va1=%vaa:~0,1% &set vaa=%vaa:~1%
  18. set va2=%vab:~0,1% &set vab=%vab:~1%%vab:~0,1%
  19. goto %bs%%bs%
  20. :11
  21. set /a vav=%va2%+%va1%-1
  22. if %vav% gtr 26 set /a vav=%vav%-26
  23. goto js
  24. :22
  25. set /a vav=%va1%-%va2%+1
  26. if %vav% lss 1 set /a vav=%vav%+26
  27. :js
  28. set /p=!%vav%!<nul
  29. if not "%vaa%"=="" goto st
  30. pause >nul
复制代码

[ 本帖最后由 mkl 于 2008-8-23 15:44 编辑 ]
1

评分人数

TOP

OMG审题错误真是粗心,不过也巧,怎么就变成什么凯撒移位相了,嘿嘿!

TOP

如果从右向左,那就不是维热纳尔了。
你的结果可以理解为在用维热纳尔加密之后再向右移一位。
与凯撒移位相结合,虽然又牢固了一些,但看题目,只使用维热纳尔方针加密而已。
心绪平和,眼藏静谧。

TOP

另一种思路,不生成方阵,只计算索引数,加解密支持空格.
密匙:key with space
文本:this is a simple test this is a simple test this is a simple test
模式(1.加密[默认] 2.解密):1
结果:DMGSWRLHASHJPUWJYTAAMHT YTCNCEZ ORFXLXPUHXDERHEATQSSQAVNXUJEWBY T
请按任意键继续. . .
密匙:key with space
文本:DMGSWRLHASHJPUWJYTAAMHT YTCNCEZ ORFXLXPUHXDERHEATQSSQAVNXUJEWBY T
模式(1.加密[默认] 2.解密):2
结果:THIS IS A SIMPLE TEST THIS IS A SIMPLE TEST THIS IS A SIMPLE TEST
请按任意键继续. . .
  1. cls&@echo off&SETLOCAL ENABLEDELAYEDEXPANSION
  2. set "str=. ABCDEFGHIJKLMNOPQRSTUVWXYZ" & set sMAX=27
  3. :main
  4. set/p keystring=密匙:
  5. set/p string=文本:
  6. set/p mode=模式(1.加密[默认] 2.解密):
  7. set/p=结果:<nul
  8. set mode=%mode%1
  9. set mode=%mode:~0,1%
  10. call :getkeyword
  11. set/a i=0,l=1
  12. :loop
  13. call :index !string:~%i%,1!
  14. if %mode% equ 2 (
  15. set/a idx=index+sMAX-offset%l%
  16. ) else (
  17. set/a idx=index+offset%l%
  18. )
  19. if %idx% gtr %sMAX% set/a idx%%=sMAX
  20. set/p=!str:~%idx%,1!<nul
  21. set/a i+=1,l= l %% keylength + 1
  22. if not "!string:~%i%,1!"=="" goto:loop
  23. echo.&pause&goto:main
  24. :getkeyword
  25. set i=0
  26. :lp
  27. if "!keystring:~%i%,1!"=="" goto:eof
  28. call :index !keystring:~%i%,1!
  29. set/a i+=1
  30. set/a offset!i!=%index%-1,keylength=i
  31. goto:lp
  32. :index
  33. set index=1
  34. if "%1"=="" goto:eof
  35. for %%a in (a b c d e f g h i j k l m n o p q r s t u v w x y z) do if %1 geq %%a set/a index+=1
复制代码

[ 本帖最后由 dishuo 于 2008-8-23 15:35 编辑 ]
2

评分人数

高手=发现问题^分析问题^解决问题

TOP

返回列表