【0】Ruby on Rails 系列回顾

[Ruby on Rails系列]1、开发环境准备:Vmware和Linux的安装

[Ruby on Rails系列]2、开发环境准备:Ruby on Rails开发环境配置

[Ruby on Rails系列]3、初试Rails:使用Rails开发第一个Web程序

[Ruby on Rails系列]4、专题:Rails应用的国际化[i18n]

[Ruby on Rails系列]5、专题:Talk About SaSS

【1】任务目标

本次主要是要实现一个简单的暗语生成器,并发布到Web,完成后的实例如下:http://ronakey.herokuapp.com/

预计分为上中下3篇完成:

(1)[Ruby on Rails系列]6、一个简单的暗语生成器与解释器(上)

上篇主要是Ruby语言语法的介绍,以及暗语生成器的主要算法实现

(2)[Ruby on Rails系列]7、一个简单的暗语生成器与解释器(中)

中篇主要是基于Ruby on Rails的Web开发,将暗语生产器算法嵌入网页程序中

(3)[Ruby on Rails系列]8、一个简单的暗语生成器与解释器(下)

下篇主要讲述如何将开发好的RoR程序借助Heroku平台部署到Internet上

【2】暗语生成器

主要算法:利用手机九宫格键盘和QWER键盘的映射关系。映射表如下:

映射表:

九宫格键盘 字母 QWER字母
21 a q
22 b w
23 c e
31 d r
32 e t
33 f y
41 g u
42 h i
... ... ...

 

举例:

输入暗语:4274439123334341

通过上述密码表解密可得:iloveyou

【3】算法实现

首先,需要建立一个映射表进行加密和解密,上述映射表的数据结构就是key-value对,在Ruby中,采用Hash类实现上述数据结构:

  @numtocodetable = Hash.[](
"21" => "q", "22" => "w", "23" => "e", "31" => "r", "32" => "t", "33" => "y",
"41" => "u", "42" => "i", "43" => "o", "51" => "p", "52" => "a", "53" => "s",
"61" => "d", "62" => "f", "63" => "g", "71" => "h", "72" => "j", "73" => "k",
"74" => "l", "81" => "z", "82" => "x", "83" => "c", "91" => "v", "92" => "b",
"93" => "n", "94" => "m"
) @codetonumtable = Hash.[](
"q" => "21", "w" => "22", "e" => "23", "r" => "31", "t" => "32", "y" => "33",
"u" => "41", "i" => "42", "o" => "43", "p" => "51", "a" => "52", "s" => "53",
"d" => "61", "f" => "62", "g" => "63", "h" => "71", "j" => "72", "k" => "73",
"l" => "74", "z" => "81", "x" => "82", "c" => "83", "v" => "91", "b" => "92",
"n" => "93", "m" => "94"
)

声明了2个hash类型变量,@numtocodetable实现数字到字母的映射表,@codetonumtable实现字母到数字的映射表。

>>

其次,实现暗语的生成:用户输入明文(字母),通过转换成为密文(数字):

def self.codetonum(code)
num = ""
codeinput = code
codeinput.split(//).each do |item|
num = num + @codetonumtable[item]
end
return num
end

基本原理是:首先将字符串分割为数组,对于字符串中每一个字母,按照上述映射表进行映射,实现字母到数字的转换,最终将字符串中的所有字母转换为数字,并返回。

在Ruby中,对字符串进行分割采用[string].split()方法,如上所示codeinput.split(//)实现了将字符串codeinput分割为一个个的字符数组;其中(//)表示分割的模式,采用正则表达式语法;分割为数组以后,[array].each迭代器支持数组的遍历(类似于foreach循环,函数语言中的map),在each迭代器中利用hashtable实现字母转为数字。

>>

最后,是暗语的解释器:用户输入密文(数字),通过转换得到明文(字母):

def self.numtocode(num)
p = ""
input = num
str = input.scan(/[0-9]{2}/)
str.each do |item|
p = p + @numtocodetable[item]
end
return p
end

基本原理和生成器类似,这里就不具体解释了。

主要注意的是,在这个算法中需要实现输入数字的两两分割,此时采用的方法是[string].scan()方法而不是split方法,scan方法是按照参数中正则表达式的文法处理字符串,并保存为数组;与split的不同在于:split方法依照正则表达式分割字符串,而scan根据正则表达式浏览字符串。正则表达式(/[0-9]{2}/)代表了[0-9]的数字{2}位,这时用scan方法刚好能将字符串两两分割。

【4】实现效果

http://ronakey.herokuapp.com/

(1)输入明文iloveyou:

(2)输入4274439123334341:

在下一部分,我会介绍将此算法用于Web框架Ruby on Rails,看如何将暗语生成器算法嵌入到网页当中。

[Ruby on Rails系列]6、一个简单的暗语生成器与解释器(上)的更多相关文章

  1. [Ruby on Rails系列]3、初试Rails:使用Rails开发第一个Web程序

    本系列前两部分已经介绍了如何配置Ruby on Rails开发环境,现在终于进入正题啦! Part1.开发前的准备 本次的主要任务是开发第一个Rails程序.需要特别指出的是,本次我选用了一个(Paa ...

  2. [Ruby on Rails系列]2、开发环境准备:Ruby on Rails开发环境配置

    前情回顾 上次讲到Vmware虚拟机的安装配置以及Scientific Linux 6.X系统的安装.这回我们的主要任务是在Linux操作系统上完成Ruby on Rails开发环境的配置. 在配置环 ...

  3. [Ruby on Rails系列]4、专题:Rails应用的国际化[i18n]

    1. 什么是internationalization(i18n)? 国际化,英文简称i18n,按照维基百科的定义:国际化是指在设计软件,将软件与特定语言及地区脱钩的过程.当软件被移植到不同的语言及地区 ...

  4. win8平台下Ruby on Rails的第一个web应用

    最近在做一个网站web前端的前期开发,老板要求用Ruby on Rails搭建部署开发环境,上网搜之,发现整个搭建流程比较坑爹,于是用了一款集成软件Bitnami Ruby Stack一键安装到我的w ...

  5. ROS与Matlab系列:一个简单的运动控制

    ROS与Matlab系列:一个简单的运动控制 转自:http://blog.exbot.net/archives/2594 Matlab拥有强大的数据处理.可视化绘图能力以及众多成熟的算法函数,非常适 ...

  6. [Ruby on Rails系列]1、开发环境准备:Vmware和Linux的安装

    Ruby on Rails是一个采用Ruby语言的遵循MVC模式的Web开发框架.使用RoR会得到更加快速爽快的Web开发体验.相比于Java EE,该框架使Web开发的速度和效率变得更加轻快和敏捷. ...

  7. Ruby学习笔记2 : 一个简单的Ruby网站,搭建ruby环境

    Ruby on Rails website 的基础是 请求-返回 循环. 首先是浏览器请求服务器, 第二步,Second, in our Rails application, the route ta ...

  8. 自己动手系列——实现一个简单的ArrayList

    ArrayList是Java集合框架中一个经典的实现类.他比起常用的数组而言,明显的优点在于,可以随意的添加和删除元素而不需考虑数组的大小.处于练手的目的,实现一个简单的ArrayList,并且把实现 ...

  9. 扩展Python模块系列(二)----一个简单的例子

    本节使用一个简单的例子引出Python C/C++ API的详细使用方法.针对的是CPython的解释器. 目标:创建一个Python内建模块test,提供一个功能函数distance, 计算空间中两 ...

随机推荐

  1. 模板:abs用法

    c语言书本上说,数学函数除了求整数的绝对值函数abs()之外<abs() 定义在stdlib.h中>,其余的函数都在头文件 math.h 中定义,包括对浮点数求绝对值的函数fabs().c ...

  2. 3_1 wp8应用生命周期与导航事件[wp8特色开发与编程技巧]

    3_1生命周期 大家好,我是徐文康,今天我们来讨论一下应用程序的生命周期,首先打开app.xaml.cs文件我们可以看到这里有几个已经为我们写好的事件.   Launching 应用程序启动 Acti ...

  3. linux传送文件至服务器

    scp安全文件拷贝(基于ssh的登陆)     1.你想把本地/home下的文件linux.tar.gz传送至远端服务器10.108.125.30,远端服务器的账号名为name,保存至服务器/home ...

  4. javascript中for-in的用法

    for(var 变量名 in object) alert(变量名[第n个]) : 如果object是josn对象的话,变量名就是属性名 如果object是数组的话,变量名就是数字下标 例子:JOSN对 ...

  5. VS2012中进行Web性能和负载测试

    问题1:无法使用ie进行录制 解决方法: 工具 >> 管理加载项 >> 在工具栏和扩展中找到发布者为Microsoft Corporation的Microsoft Web Te ...

  6. php win主机下实现ISAPI_Rewrite伪静态

    有的win主机iss不支持 .htaccess 文件, 我在这里指的不是本地 在本地的话用apmserv服务器可以用.htaccess 文件,用apmserv服务器环境配置伪静态可以看 php 伪静态 ...

  7. Oracle 表的连接方式(2)-----HASH JOIN的基本机制2

    Hash算法原理 对于什么是Hash算法原理?这个问题有点难度,不是很好说清楚,来做一个比喻吧:我们有很多的小猪,每个的体重都不一样,假设体重分布比较平均(我们考虑到公斤级别),我们按照体重来分,划分 ...

  8. Ubuntu12.10编译openwrt遇到的错误

    由于Openwrt有很多工具是要先编译的,在Ubuntu12.10平台下编译openwrt时就遇到了下面这样的错误:elf.cpp: In static member function 'static ...

  9. selenium+python 浏览器标签页跳转 switch_to_window

    浏览器页面跳转方法记录: from selenium import webdriver import time browser = webdriver.Chrome() first_url='http ...

  10. Java eclipse export jar包 包括第三方引入的jar

    1.安装fatjar插件 2.export jar 说明:安装后,操作说明以官网为准,不同的版本会有不同的右键菜单,我的版本(Eclipse Java EE IDE for Web Developer ...