信息安全密码技术--栅栏密码

1、栅栏密码

            所谓栅栏密码,就是把要加密的明文分成N个一组,然后把每组的第1个字连起来,形成一段无规律的话。 不过栅栏密码本身有一个潜规则,就是组成栅栏的字母一般不会太多。(一般不超过30个,也就是一、两句话),从本质上讲,栅栏密码是一种置换技术,即仅仅改变位置而不做替换。

2、加密原理

           ①把将要传递的信息中的字母交替排成上下两行。
           ②再将下面一行字母排在上面一行的后边,从而形成一段密码。

           ③

              例如:

                 明文:THE LONGEST DAY MUST HAVE AN END

                加密:

                 |:把将要传递的信息中的字母交替排成上下两行。

                       T E O G S D Y U T A E N N

                       H L N E T A M S H V A E D

                  II:

                      密文

                      :将下面一行字母排在上面一行的后边。

                        TEOGSDYUTAENN

                        HLNETAMSHVAED
                          解密

                              I.先将密文分为两行

                                 T E O G S D Y U T A E N N

                                 H L N E T A M S H V A E D

                               II.再按上下上下的顺序组合成一句话
                          明文:

                               THE LONGEST DAY MUST HAVE AN END

  3、扩展

                (1)在选择行数时可以使多行,这样对于加密强度有所提高  

                (2)可以在加密之后在使用其他密码进行加密,增加强度     

4、实现的部分源代码

       加密部分:                   

// 获取密钥和明文
				String str_p = et_plaintext.getText().toString();
				char[] str_p_char = null;
					{
					try 
					{
					str_p_char = str_p.toCharArray();
					}
					catch (Exception e) {
						System.out.println("Exception");
					}
					int len=str_p_char.length;
					System.out.println("len:"+len);
					StringBuffer sb_1 = new StringBuffer();
					StringBuffer sb_2 = new StringBuffer();
					if(len%2==1)
					{
					for (int i = 0; i <len;i=i+1)
					{
					if(i%2==0)
					{
						sb_1.append(str_p_char[i]);
					}
					else
					{
						sb_2.append(str_p_char[i]);
					}
					}
					}
					else
					{
						for (int i = 0; i <len; i=i+2)
						{
						sb_1.append(str_p_char[i]);
						sb_2.append(str_p_char[i+1]);
						}
					}
										
					str_p = sb_1.toString()+sb_2.toString();

解密部分:

                String str_c = et_ciphertext.getText().toString();
				char []str_c_char = null;
				
				try {
					str_c_char=str_c.toCharArray();
				 }
					catch(Exception e) {
					System.out.println("Exception");
					}
					int len=str_c_char.length;
					int half=len/2;
					StringBuffer sb = new StringBuffer();
					if(len%2==1) {
					int i=0;
					for (i = 0; i <half;i=i+1) {
					sb.append(str_c_char[i]);
					sb.append(str_c_char[i+half+1]);
					}
					sb.append(str_c_char[half]);
					}
					else {
					for (int i = 0; i <half; i=i+1) {
							sb.append(str_c_char[i]);
							 sb.append(str_c_char[i+half]);
						}
							}
						str_c=sb.toString();

下面是具体的演示过程:

图1 输入要加密的内容

图2 加密后的内容

图3 解密后的内容

以上就是栅栏密码的实现过程。

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

suwu150

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值