JAVA字符加密
Posted 立木-Six
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA字符加密相关的知识,希望对你有一定的参考价值。
1、字符加密解密
古罗马皇帝凯撒在打仗时曾经使用过以下方法加密军事情报:
请编写一个程序,使用上述算法加密或解密用户输入的英文字串。
(1)源代码:
import java.util.Scanner; public class Jiami { public static void main(String[] args) { // TODO Auto-generated method stub Scanner scan = new Scanner(System.in); String str = scan.next(); String jm = jiaMi(str); System.out.println("将 " + str + " 加密结果 " + jm); jm = jieMi(str); System.out.println("将 " + str + " 解密结果 " + jm); scan.close();
} public static String jiaMi(String str){ StringBuffer jm = new StringBuffer(); char ch; for(int i = 0;i < str.length();i++){ if( (str.charAt(i) >= \'x\' && str.charAt(i) <= \'z\') || (str.charAt(i) >= \'X\' && str.charAt(i) <= \'Z\') )
{ ch = (char) (str.charAt(i) - 23); jm.append(ch); } else
{ ch = (char) (str.charAt(i) + 3); jm.append(ch); } } return jm.toString(); } public static String jieMi(String str)
{ StringBuffer jm = new StringBuffer(); char ch; for(int i = 0;i < str.length();i++)
{ if( (str.charAt(i) >= \'a\' && str.charAt(i) <= \'c\') || (str.charAt(i) >= \'A\' && str.charAt(i) <= \'C\') )
{ ch = (char) (str.charAt(i) + 23); jm.append(ch); } else
{ ch = (char) (str.charAt(i) - 3); jm.append(ch); } } return jm.toString(); } }
(2)程序截图
(3)程序设计思想:
读入字符串,
加密:遍历该字符串,如果该字符串原先为 x , y , z则减去23,否则加上3
解密:遍历该字符串,如果该字符串原先为 a , b , c则加上23,否则减去3
(4)程序流程图:
2、字符串相等
(1)"=="判断引用的地址是否相等,equals()方法比较的是值是否相等;
(2)字符串为不可变量,使用 \'+\' , 相当于得到了一个新的字符串对象(地址不同)。
3、String类的Length()、charAt()、 getChars()、replace()、 toUpperCase()、 toLowerCase()、trim()、toCharArray()使用说明
(1)length
public int length()
- Specified by:
length
in interfaceCharSequence
- Returns:
- the length of the sequence of characters represented by this object.
- 返回此字符串的长度。
- 例如:
-
String str = "Hello";
System.out.println(str.length()); //5
(2)charAt
public char charAt(int index)
char
value at the specified index. An index ranges from 0
to length() - 1
. The first char
value of the sequence is at index 0
, the next at index 1
, and so on, as for array indexing.
If the char
value specified by the index is a surrogate, the surrogate value is returned.
- Specified by:
charAt
in interfaceCharSequence
- Parameters:
index
- the index of thechar
value.- Returns:
- the
char
value at the specified index of this string. The firstchar
value is at index0
. - Throws:
IndexOutOfBoundsException
- if theindex
argument is negative or not less than the length of this string.- 返回指定索引处的
char
值。 - 例如:
-
String str = "Hello";
System.out.println(str.charAt(2));// l
(3)getChars
public void getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin)
The first character to be copied is at index srcBegin
; the last character to be copied is at index srcEnd-1
(thus the total number of characters to be copied issrcEnd-srcBegin
). The characters are copied into the subarray of dst
starting at index dstBegin
and ending at index:
dstBegin + (srcEnd-srcBegin) - 1
- Parameters:
srcBegin
- index of the first character in the string to copy.srcEnd
- index after the last character in the string to copy.dst
- the destination array.dstBegin
- the start offset in the destination array.- Throws:
IndexOutOfBoundsException
- If any of the following is true:srcBegin
is negative.srcBegin
is greater thansrcEnd
srcEnd
is greater than the length of this stringdstBegin
is negativedstBegin+(srcEnd-srcBegin)
is larger thandst.length
将字符从此字符串复制到目标字符数组。
(4)replace
public String replace(char oldChar, char newChar)
oldChar
in this string with newChar
.
If the character oldChar
does not occur in the character sequence represented by this String
object, then a reference to this String
object is returned. Otherwise, a String
object is returned that represents a character sequence identical to the character sequence represented by this String
object, except that every occurrence of oldChar
is replaced by an occurrence of newChar
.
Examples:
"mesquite in your cellar".replace(\'e\', \'o\') returns "mosquito in your collar" "the war of baronets".replace(\'r\', \'y\') returns "the way of bayonets" "sparring with a purple porpoise".replace(\'p\', \'t\') returns "starring with a turtle tortoise" "JonL".replace(\'q\', \'x\') returns "JonL" (no change)
- Parameters:
oldChar
- the old character.newChar
- the new character.- Returns:
- a string derived from this string by replacing every occurrence of
oldChar
withnewChar
. - 返回一个新的字符串,它是通过用
newChar
替换此字符串中出现的所有oldChar
得到的。
(5)toUpperCase
public String toUpperCase()
String
to upper case using the rules of the default locale. This method is equivalent to toUpperCase(Locale.getDefault())
.
Note: This method is locale sensitive, and may produce unexpected results if used for strings that are intended to be interpreted locale independently. Examples are programming language identifiers, protocol keys, and html tags. For instance, "title".toUpperCase()
in a Turkish locale returns "T\\u0130TLE"
, where \'\\u0130\' is the LATIN CAPITAL LETTER I WITH DOT ABOVE character. To obtain correct results for locale insensitive strings, use toUpperCase(Locale.ROOT)
.
- Returns:
- the
String
, converted to uppercase. - See Also:
toUpperCase(Locale)
- 使用默认语言环境的规则将此
String
中的所有字符都转换为大写。
(6)toLowerCase
public String toLowerCase()
String
to lower case using the rules of the default locale. This is equivalent to calling toLowerCase(Locale.getDefault())
.
Note: This method is locale sensitive, and may produce unexpected results if used for strings that are intended to be interpreted locale independently. Examples are programming language identifiers, protocol keys, and HTML tags. For instance, "TITLE".toLowerCase()
in a Turkish locale returns "t\\u0131tle"
, where \'\\u0131\' is the LATIN SMALL LETTER DOTLESS I character. To obtain correct results for locale insensitive strings, use toLowerCase(Locale.ROOT)
.
- Returns:
- the
String
, converted to lowercase. - See Also:
toLowerCase(Locale)
- 使用默认语言环境的规则将此
String
中的所有字符都转换为小写。
(7)trim
public String trim()
If this String
object represents an empty character sequence, or the first and last characters of character sequence represented by this String
object both have codes greater than \'\\u0020\'
(the space character), then a reference to this String
object is returned.
Otherwise, if there is no character with a code greater than \'\\u0020\'
in the string, then a String
object representing an empty string is returned.
Otherwise, let k be the index of the first character in the string whose code is greater than \'\\u0020\'
, and let m be the index of the last character in the string whose code is greater than \'\\u0020\'
. A String
object is returned, representing the substring of this string that begins with the character at index k and ends with the character at index m-that is, the result of this.substring(k, m + 1)
.
This method may be used to trim whitespace (as defined above) from the beginning and end of a string.
- Returns:
- A string whose value is this string, with any leading and trailing white space removed, or this string if it has no leading or trailing white space.
- 返回字符串的副本,忽略前导空白和尾部空白。
(8)toCharArray
public char[] toCharArray()
- Returns:
- a newly allocated character array whose length is the length of this string and whose contents are initialized to contain the character sequence represented by this string.
- 将此字符串转换为一个新的字符数组。
以上是关于JAVA字符加密的主要内容,如果未能解决你的问题,请参考以下文章
通过 Java 正则表达式提取 semver 版本字符串的片段