免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3746 | 回复: 9
打印 上一主题 下一主题

用 Haskell 做了一个简单的 Vigenre 加密 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-09-12 10:15 |只看该作者 |倒序浏览
Vigenre 加密算法是一个简单替换密码。我的同学大多都用 Java、VB、VC 来实现。
但我想 Haskell 这样的语言去做这样的数学问题应该是很简单的,所以昨天晚上做了一下尝试。
另外还用 wxHaskell 做了一个很简单的界面。

目前算法的情况是,只支持大写字母的加密,小写字母会自动转化成大写字母,还不支持标点。但是要进行改进的话应该也不难。

存在的问题是:
1. 不清楚如何在 Haskell 中使用中文,好像是与编码有关。
2. 运行用 GHC 编译之后的 exe 文件,除了主窗口之外,后面还会出来一个 CMD 一样的窗口,很是难看。
希望知道解决问题方法的前辈们给一下指点。

附件中有两个文件:Vigenre.hs 是算法实现,VigenreFrame.hs 是界面代码。
希望大家多多拍砖。

编译环境是:Windows XP + GHC 6.8.3 + wxHaskell 0.10.3

核心算法如下:

  1. module Vigenre (encrypt, decrypt)
  2.     where

  3. import Data.List
  4. import Char

  5. -----------------------------------------------------------------
  6. -- helper functions

  7. alphaString :: String
  8. alphaString = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"

  9. line :: Int -> String
  10. line n = b ++ a
  11.     where
  12.       (a, b) = splitAt n alphaString

  13. indexOfElement :: Char -> Int -> Int
  14. indexOfElement e n = i
  15.     where
  16.       (Just i) = elemIndex e (line n)

  17. offset :: Char -> Int
  18. offset x = ord x - ord 'A'

  19. adjustKey :: String -> String -> String
  20. adjustKey m k = map toUpper ((concat $ replicate quotient k)
  21.                              ++ take remainder k)
  22.     where
  23.       quotient =  length m `div` length k
  24.       remainder = length m `mod` length k

  25. -----------------------------------------------------------------


  26. encrypt :: String -> String -> String
  27. encrypt msgString keyString = zipWith encrypt' msgString' keyString'
  28.     where
  29.       encrypt' m k = (line $ offset k) !! (offset m)
  30.       keyString' = map toUpper (adjustKey msgString keyString)
  31.       msgString' = map toUpper msgString
  32.       
  33. decrypt :: String -> String -> String
  34. decrypt msgString keyString = zipWith decrypt' msgString' keyString'
  35.     where
  36.       decrypt' m k = chr (indexOfElement m (offset k) + ord 'A')
  37.       keyString' = map toUpper (adjustKey msgString keyString)
  38.       msgString' = map toUpper msgString
复制代码


[ 本帖最后由 swordfish.cn 于 2008-9-12 10:23 编辑 ]

Vigenre.zip

1.52 KB, 下载次数: 92

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
2 [报告]
发表于 2008-09-12 10:39 |只看该作者
Pretty good.

论坛徽章:
0
3 [报告]
发表于 2008-09-12 16:43 |只看该作者
望洋兴叹中,我什么时候才能到这样的水平呀?。。。。
努力学习中。。。

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
4 [报告]
发表于 2008-09-12 16:56 |只看该作者
原帖由 drunkedcat 于 2008-9-12 16:43 发表
望洋兴叹中,我什么时候才能到这样的水平呀?。。。。

take it easy

论坛徽章:
0
5 [报告]
发表于 2008-09-12 17:01 |只看该作者
原帖由 drunkedcat 于 2008-9-12 16:43 发表
望洋兴叹中,我什么时候才能到这样的水平呀?。。。。
努力学习中。。。


很简单的,我也是现炒现卖而已。

论坛徽章:
0
6 [报告]
发表于 2008-09-12 17:04 |只看该作者
MMMIX 能否帮我看一下那两个问题怎么解决?多谢。

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
7 [报告]
发表于 2008-09-12 17:23 |只看该作者
原帖由 swordfish.cn 于 2008-9-12 17:04 发表
MMMIX 能否帮我看一下那两个问题怎么解决?多谢。

我可以实验下 Linux 下的情况,Windows 没环境。。。

论坛徽章:
0
8 [报告]
发表于 2008-09-12 17:29 |只看该作者
问题是,我现在不用 Windows 不行。

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
9 [报告]
发表于 2008-09-12 21:53 |只看该作者
原帖由 swordfish.cn 于 2008-9-12 17:29 发表
问题是,我现在不用 Windows 不行。

Hi,高兴点嘛

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
10 [报告]
发表于 2008-09-13 09:28 |只看该作者
原帖由 swordfish.cn 于 2008-9-12 10:15 发表
存在的问题是:
1. 不清楚如何在 Haskell 中使用中文,好像是与编码有关。

只要将源文件的编码设置为 UTF-8 即可。
2. 运行用 GHC 编译之后的 exe 文件,除了主窗口之外,后面还会出来一个 CMD 一样的窗口,很是难看。

最开始那个窗口是你调用 panel 的时候产生的。至于说怎么去掉,方法肯定是有的,只不过我不知道
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP