凯撒加密算法实现 JAVA实现caesar凯撒加密算法

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

凯撒加密算法实现 JAVA实现caesar凯撒加密算法

  2021-03-19 我要评论
想了解JAVA实现caesar凯撒加密算法的相关内容吗,在本文为您仔细讲解凯撒加密算法实现的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:caesar,凯撒加密,下面大家一起来学习吧。

复制代码 代码如下:

public class Caesar {
 public static final String SOURCE = "abcdefghijklmnopqrstuvwxyz";
 public static final int LEN = SOURCE.length();

 /**
  * @param args
  */
 public static void main(String[] args) {
     String result = caesarEncryption("newyork");
     System.out.println("encryption result:" + result);
     System.out.println("decryption result:" + caesarDecryption(result));

 }

 //Encryption
 public static String caesarEncryption(String s) {
     StringBuilder sb = new StringBuilder();

     if (s == null || s.length() < 1) {
         System.out.println("you Input nothing.");
         return null;
     }

     if (!isAlp(s)) {
         System.out.println("input ABC... only");
         return null;
     }

     s = s.toLowerCase();

     int len = s.length();
     for (int j = 0; j < len; j++) {
         char c = s.charAt(j);
         int a = SOURCE.indexOf(c);
         if (a == LEN -1) a = -1;
         if (a == LEN -2) a = -2;
         if (a == LEN - 3) a = -3;
         sb.append(SOURCE.charAt(a + 3));
     }
     return sb.toString();
 }

 //Decryption
 public static String caesarDecryption(String s) {
     StringBuilder sb = new StringBuilder();

     if (s == null || s.length() < 1) {
         System.out.println("you Input nothing.");
         return null;
     }

     if (!isAlp(s)) {
         System.out.println("input ABC... only");
         return null;
     }

     s = s.toLowerCase();
     for (int i = 0; i < s.length(); i++) {
         char c = s.charAt(i);
         int a = SOURCE.indexOf(c);
         if (a == 2) a = LEN + 2;
         if (a == 1) a = LEN + 1;
         if (a == 0) a = LEN;
         sb.append(SOURCE.charAt(a - 3));
     }
     return sb.toString();
 }

 public static boolean isAlp(String s) {
     String p = "^[A-Za-z]+$";
     Pattern pattern = Pattern.compile(p);
     Matcher matcher = pattern.matcher(s);
     if (matcher.find()) {
         return true;
     }
     return false;
 }
}

猜您喜欢

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们