(JAVA) 使用异或进行简单的密码加密(JAVA实现)[转]
http://blog.sina.com.cn/s/blog_532af66a0100a1lq.html
import java.io.BufferedReader;
import java.io.FileOutputStream;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStreamReader;
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
public class ChgAnGo {
?// log4jのプロパティフィアル名
?private static String LOG_PROPERTIES = "log4j.properties";
?// パスワドファイルパス
?private static String PASSWORD_FILEPATH = "output/password.txt";
?// 反用文字入力ファイルパス
?private static String CONVERT_FILEPATH = "input/convert.txt";
?// ログメッセジ:暗号化理始
?private static String LOG_ENCRYPT_START = "文字列の暗号化始";
?// ログメッセジ:暗号化理完了
?private static String LOG_ENCRYPT_END = "文字列の暗号化完了";
?// ログメッセジ:暗号化理前
?private static String LOG_ENCRYPT_BEFORE = "暗号化理前:";
?// ログメッセジ:暗号化理後
?private static String LOG_ENCRYPT_AFTER = "暗号化理後:";
?//反用文字を取得できない合
?private static String LOG_CONVERT_KEY_READ_ERROR = "暗号化のキワドの取得に失しました。";
?//ファイルに出力失合
?private static String LOG_FILE_WRITE_ERROR = "暗号化したパスワドのファイル出力に失しました。";
?// コンソルメッセジ:入力メッセジ
?private static String CONSOLE_INPUT_MESSAGE = "暗号化したいパスワドを入力してください。";
?// コンソルメッセジ:入力した文字列バイト数>40合
?private static String CONSOLE_INPUT_COUNT_ERROR = "エラ:40バイト以内文字列を入力してください。";
?// コンソルメッセジ:半角英数字、半角号以外が入力された合
?private static String CONSOLE_INPUT_CHAR_ERROR = "エラ:半角英数字、半角号を入力してください。";
?// コンソルメッセジ:ファイルに出力失合
?private static String CONSOLE_FILE_WRITE_ERROR = "エラ:暗号化したパスワドをファイルに出力するのは失しました。";
?// コンソルメッセジ:反用文字入力ファイルを取得できない合
?private static String CONSOLE_CONVERT_KEY_READ_ERROR = "エラ:暗号化のキワドの取得に失しました。";
?// コンソルメッセジ:暗号化成功合
?private static String CONSOLE_SUCCESS_END = "暗号化したパスワドはoutput/password.txtに出力しました。";
?// コンソルメッセジ:プログラム了
?private static String CONSOLE_END = "理了しました。";
?// ログを出力するために、loggerを取得
?private static Logger logger = Logger.getLogger(ChgAnGo.class.getName());
?
?public static void main(String[] args) {
??ChgAnGo chgAnGo = new ChgAnGo();
??//log4jプロパティファイルを取得する
??PropertyConfigurator.configure(LOG_PROPERTIES);
??//理始ログ出力
??logger.info(LOG_ENCRYPT_START);
??try {
???//暗号化したい文字列
???String inStr = "";
???//暗号化したい文字列の取得
???//コマンドラインから入力した引数が存在(args.length==1)合
???if (args.length == 1) {
????inStr = args[0];
???} else {
????//コマンドラインから入力した引数が不存在(args.length<>1)合
????//????byte[] input = new byte[41];
????//スクリンへメッセジを出力する。
????System.out.println(CONSOLE_INPUT_MESSAGE);
????//スクリンから暗号化したい文字列を取得する。
????BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
????inStr = br.readLine();
???}
???// 文字列のチェック
???//入力した文字列バイト数>40合
???if (inStr.getBytes().length > 40) {
????System.out.println(CONSOLE_INPUT_COUNT_ERROR);
???} else if (inStr.getBytes().length > inStr.length()) {
????//????半角英数字、半角号以外が入力された合
????System.out.println(CONSOLE_INPUT_CHAR_ERROR);
???} else if ("".equals(inStr)) {
????//何も入力しない合
????System.out.println(CONSOLE_INPUT_CHAR_ERROR);
???} else {
????//上以外合、文字列に暗号化理
????//暗号化のキワドの取得
????String cstrKey = chgAnGo.getConvertKey(CONVERT_FILEPATH);
????if (cstrKey != null && !"".equals(cstrKey)) {
?????//暗号化理メソッドを呼び出す
?????String ango = chgAnGo.setEncrypt(inStr, cstrKey);
?????//暗号化した文字列をファイルに出力する。
?????chgAnGo.writeToFile(PASSWORD_FILEPATH, ango.getBytes());
?????//正常了、ログを出力する。
?????logger.info(LOG_ENCRYPT_BEFORE + inStr);
?????logger.info(LOG_ENCRYPT_AFTER + ango);
?????//スクリンへメッセジを出力する。
?????System.out.println(CONSOLE_SUCCESS_END);
?????
?????System.out.println(chgAnGo.getEncrypt(ango, cstrKey));
????} else {
?????//反用文字を取得できない合、ログを出力する。
?????logger.info(LOG_CONVERT_KEY_READ_ERROR);
?????//スクリンへメッセジを出力する。
?????System.out.println(CONSOLE_CONVERT_KEY_READ_ERROR);
????}
???}
??} catch (IOException e) {
???//例外エラ生合、エラを出力する。
???logger.fatal(e.getMessage());
??} finally {
???//理完了ログ出力
???//スクリンへメッセジを出力する
???System.out.println(CONSOLE_END);
???//「文字列の暗号化完了」ログを出力する。
???logger.info(LOG_ENCRYPT_END);
??}
?}
?
?protected String setEncrypt(String password, String cstrKey) {
??//int[] snNum = new int[password.length()];
??char[] snNum = new char[password.length()];
??String result = "";
??//ビット反操作をり回す
??for (int i = 0, j = 0; i < password.length(); i++, j++) {
???//反用文字列」<「暗号化したい文字列」合、
???//反用文字列をり回して利用する
???if (j == cstrKey.length())
????j = 0;
???//暗号化したバイト=(暗号化したい文字)^(反用文字)^(1/(当文字の位置+1))
???//snNum[i] = password.charAt(i) ^ cstrKey.charAt(j) ^ (1 / (i + 1));
???snNum[i] = (char) (password.charAt(i) ^ cstrKey.charAt(j) ^ (1 / (i + 1)));
???result += (char) snNum[i];
??}
??//暗号化した文字列を返す。
??return result;
?}
?
?protected String getEncrypt(String password, String cstrKey) {
??char[] snNum = new char[password.length()];
??String result = "";
??//ビット反操作をり回す
??for (int i = 0, j = 0; i < password.length(); i++, j++) {
???//反用文字列」<「号化したい文字列」合、
???//反用文字列をり回して利用する???
???if (j == cstrKey.length())
????j = 0;
???char n = password.charAt(i);
???//号化したバイト=(号化したい文字)^(反用文字)^(1/(当文字の位置+1))
???snNum[i] = (char) (n ^ cstrKey.charAt(j) ^ (1 / (i + 1)));
???result += snNum[i];
??}
??//号化した文字列を返す。
??return result;
?}
?
?protected void writeToFile(String filePath, byte[] data) throws IOException {
??FileOutputStream outfile = null;
??
??try {
???//ファイルパスより、出力ファイルをく
???outfile = new FileOutputStream(filePath);
???//デタをファイルに出力する
???outfile.write(data, 0, data.length);
???//ファイルを保存する
???outfile.flush();
??} catch (IOException e) {
???//ファイル出力失合、ログを出力する。
???logger.info(LOG_FILE_WRITE_ERROR);
???//スクリンへメッセジを出力する。
???System.out.println(CONSOLE_FILE_WRITE_ERROR);
???
???throw e;
??} finally {
???//ファイルをクロズする
???if (outfile != null) {
????outfile.close();
???}
??}
?}
?
?protected String getConvertKey(String filePath) throws IOException {
??String convertKey = null;
??BufferedReader br = null;
??try {
???//ファイルパスより、入力ファイルをく
???br = new BufferedReader(new FileReader(filePath));
???//反用文字を取得する
???convertKey = br.readLine();
???//反用文字を返す
???return convertKey;
??} catch (IOException e) {
???//反用文字を取得できない合、ログを出力する。
???logger.info(LOG_CONVERT_KEY_READ_ERROR);
???//スクリンへメッセジを出力する。
???System.out.println(CONSOLE_CONVERT_KEY_READ_ERROR);
???throw e;
??} finally {
???//ファイルをクロズする
???if (br != null) {
????br.close();
???}
??}
?}
}