zoukankan      html  css  js  c++  java
  • 字符串加密

    无聊写个字符串加密的小工具,功能:设置相应的字符串,可进行相应的加密方式,有MD5加密,SHA加密,DES加密。

    字符串加密

    加密类:

    package secret;
    
    import java.io.FileInputStream;
    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.io.ObjectInputStream;
    import java.io.ObjectOutputStream;
    import java.security.KeyPair;
    import java.security.KeyPairGenerator;
    import java.security.MessageDigest;
    import java.security.NoSuchAlgorithmException;
    import java.security.PrivateKey;
    import java.security.PublicKey;
    import java.security.SecureRandom;
    import java.security.Signature;
    
    import javax.crypto.Cipher;
    import javax.crypto.KeyGenerator;
    import javax.crypto.SecretKey;
    
    
    /**   
     * 加密解密   
     *    
     * @author 毛兴宇   
     * @since  http://blog.csdn.net/powmxypow  
     */    
    public class Secret {
        /**   
         * 进行MD5加密   
         *    
         * @param info 要加密的信息   
         * @return String 加密后的字符串   
         */    
        public String encryptToMD5(String info) {     
            byte[] digesta = null;     
            try {     
                // 得到一个md5的消息摘要     
                MessageDigest alga = MessageDigest.getInstance("MD5");     
                // 添加要进行计算摘要的信息     
                alga.update(info.getBytes());     
                // 得到该摘要     
                digesta = alga.digest();     
            } catch (NoSuchAlgorithmException e) {     
                e.printStackTrace();     
            }     
            // 将摘要转为字符串     
            String rs = byte2hex(digesta);     
            return rs;     
        }     
        /**   
         * 进行SHA加密   
         *    
         * @param info 要加密的信息   
         * @return String 加密后的字符串   
         */    
        public String encryptToSHA(String info) {     
            byte[] digesta = null;     
            try {     
                // 得到一个SHA-1的消息摘要     
                MessageDigest alga = MessageDigest.getInstance("SHA-1");     
                // 添加要进行计算摘要的信息     
                alga.update(info.getBytes());     
                // 得到该摘要     
                digesta = alga.digest();     
            } catch (NoSuchAlgorithmException e) {     
                e.printStackTrace();     
            }     
            // 将摘要转为字符串     
            String rs = byte2hex(digesta);     
            return rs;     
        }     
        ////////////////////////////////////////////////////////////////////////////     
        /**   
         * 创建密匙   
         *    
         * @param algorithm 加密算法,可用 DES,DESede,Blowfish   
         * @return SecretKey 秘密(对称)密钥   
         */    
        public SecretKey createSecretKey(String algorithm) {     
            // 声明KeyGenerator对象     
            KeyGenerator keygen;     
            // 声明 密钥对象     
            SecretKey deskey = null;     
            try {     
                // 返回生成指定算法的秘密密钥的 KeyGenerator 对象     
                keygen = KeyGenerator.getInstance(algorithm);     
                // 生成一个密钥     
                deskey = keygen.generateKey();     
            } catch (NoSuchAlgorithmException e) {     
                e.printStackTrace();     
            }     
            // 返回密匙     
            return deskey;     
        }     
        /**   
         * 根据密匙进行DES加密   
         *    
         * @param key 密匙   
         * @param info 要加密的信息   
         * @return String 加密后的信息   
         */    
        public String encryptToDES(SecretKey key, String info) {     
            // 定义 加密算法,可用 DES,DESede,Blowfish     
            String Algorithm = "DES";     
            // 加密随机数生成器 (RNG),(可以不写)     
            SecureRandom sr = new SecureRandom();     
            // 定义要生成的密文     
            byte[] cipherByte = null;     
            try {     
                // 得到加密/解密器     
                Cipher c1 = Cipher.getInstance(Algorithm);     
                // 用指定的密钥和模式初始化Cipher对象     
                // 参数:(ENCRYPT_MODE, DECRYPT_MODE, WRAP_MODE,UNWRAP_MODE)     
                c1.init(Cipher.ENCRYPT_MODE, key, sr);     
                // 对要加密的内容进行编码处理,     
                cipherByte = c1.doFinal(info.getBytes());     
            } catch (Exception e) {     
                e.printStackTrace();     
            }     
            // 返回密文的十六进制形式     
            return byte2hex(cipherByte);     
        }     
        /**   
         * 根据密匙进行DES解密   
         *    
         * @param key 密匙   
         * @param sInfo 要解密的密文   
         * @return String 返回解密后信息   
         */    
        public String decryptByDES(SecretKey key, String sInfo) {     
            // 定义 加密算法,     
            String Algorithm = "DES";     
            // 加密随机数生成器 (RNG)     
            SecureRandom sr = new SecureRandom();     
            byte[] cipherByte = null;     
            try {     
                // 得到加密/解密器     
                Cipher c1 = Cipher.getInstance(Algorithm);     
                // 用指定的密钥和模式初始化Cipher对象     
                c1.init(Cipher.DECRYPT_MODE, key, sr);     
                // 对要解密的内容进行编码处理     
                cipherByte = c1.doFinal(hex2byte(sInfo));     
            } catch (Exception e) {     
                e.printStackTrace();     
            }     
            // return byte2hex(cipherByte);     
            return new String(cipherByte);     
        }     
        // /////////////////////////////////////////////////////////////////////////////     
        /**   
         * 创建密匙组,并将公匙,私匙放入到指定文件中   
         *    
         * 默认放入mykeys.bat文件中   
         */    
        public void createPairKey() {     
            try {     
                // 根据特定的算法一个密钥对生成器     
                KeyPairGenerator keygen = KeyPairGenerator.getInstance("DSA");     
                // 加密随机数生成器 (RNG)     
                SecureRandom random = new SecureRandom();     
                // 重新设置此随机对象的种子     
                random.setSeed(1000);     
                // 使用给定的随机源(和默认的参数集合)初始化确定密钥大小的密钥对生成器     
                keygen.initialize(512, random);// keygen.initialize(512);     
                // 生成密钥组     
                KeyPair keys = keygen.generateKeyPair();     
                // 得到公匙     
                PublicKey pubkey = keys.getPublic();     
                // 得到私匙     
                PrivateKey prikey = keys.getPrivate();     
                // 将公匙私匙写入到文件当中     
                doObjToFile("mykeys.bat", new Object[] { prikey, pubkey });     
            } catch (NoSuchAlgorithmException e) {     
                e.printStackTrace();     
            }     
        }     
        /**   
         * 利用私匙对信息进行签名 把签名后的信息放入到指定的文件中   
         *    
         * @param info 要签名的信息   
         * @param signfile 存入的文件   
         */    
        public void signToInfo(String info, String signfile) {     
            // 从文件当中读取私匙     
            PrivateKey myprikey = (PrivateKey) getObjFromFile("mykeys.bat", 1);     
            // 从文件中读取公匙     
            PublicKey mypubkey = (PublicKey) getObjFromFile("mykeys.bat", 2);     
            try {     
                // Signature 对象可用来生成和验证数字签名     
                Signature signet = Signature.getInstance("DSA");     
                // 初始化签署签名的私钥     
                signet.initSign(myprikey);     
                // 更新要由字节签名或验证的数据     
                signet.update(info.getBytes());     
                // 签署或验证所有更新字节的签名,返回签名     
                byte[] signed = signet.sign();     
                // 将数字签名,公匙,信息放入文件中     
                doObjToFile(signfile, new Object[] { signed, mypubkey, info });     
            } catch (Exception e) {     
                e.printStackTrace();     
            }     
        }     
        /**   
         * 读取数字签名文件 根据公匙,签名,信息验证信息的合法性   
         *    
         * @return true 验证成功 false 验证失败   
         */    
        public boolean validateSign(String signfile) {     
            // 读取公匙     
            PublicKey mypubkey = (PublicKey) getObjFromFile(signfile, 2);     
            // 读取签名     
            byte[] signed = (byte[]) getObjFromFile(signfile, 1);     
            // 读取信息     
            String info = (String) getObjFromFile(signfile, 3);     
            try {     
                // 初始一个Signature对象,并用公钥和签名进行验证     
                Signature signetcheck = Signature.getInstance("DSA");     
                // 初始化验证签名的公钥     
                signetcheck.initVerify(mypubkey);     
                // 使用指定的 byte 数组更新要签名或验证的数据     
                signetcheck.update(info.getBytes());     
                System.out.println(info);     
                // 验证传入的签名     
                return signetcheck.verify(signed);     
            } catch (Exception e) {     
                e.printStackTrace();     
                return false;     
            }     
        }     
        /**   
         * 将二进制转化为16进制字符串   
         *    
         * @param b 二进制字节数组   
         * @return String   
         */    
        public String byte2hex(byte[] b) {     
            String hs = "";     
            String stmp = "";     
            for (int n = 0; n < b.length; n++) {     
                stmp = (java.lang.Integer.toHexString(b[n] & 0XFF));     
                if (stmp.length() == 1) {     
                    hs = hs + "0" + stmp;     
                } else {     
                    hs = hs + stmp;     
                }     
            }     
            return hs.toUpperCase();     
        }     
        /**   
         * 十六进制字符串转化为2进制   
         *    
         * @param hex   
         * @return   
         */    
        public byte[] hex2byte(String hex) {     
            byte[] ret = new byte[8];     
            byte[] tmp = hex.getBytes();     
            for (int i = 0; i < 8; i++) {     
                ret[i] = uniteBytes(tmp[i * 2], tmp[i * 2 + 1]);     
            }     
            return ret;     
        }     
        /**   
         * 将两个ASCII字符合成一个字节; 如:"EF"--> 0xEF   
         *    
         * @param src0 byte   
         * @param src1 byte   
         * @return byte   
         */    
        public static byte uniteBytes(byte src0, byte src1) {     
            byte _b0 = Byte.decode("0x" + new String(new byte[] { src0 }))     
                    .byteValue();     
            _b0 = (byte) (_b0 << 4);     
            byte _b1 = Byte.decode("0x" + new String(new byte[] { src1 }))     
                    .byteValue();     
            byte ret = (byte) (_b0 ^ _b1);     
            return ret;     
        }     
        /**   
         * 将指定的对象写入指定的文件   
         *    
         * @param file 指定写入的文件   
         * @param objs 要写入的对象   
         */    
        public void doObjToFile(String file, Object[] objs) {     
            ObjectOutputStream oos = null;     
            try {     
                FileOutputStream fos = new FileOutputStream(file);     
                oos = new ObjectOutputStream(fos);     
                for (int i = 0; i < objs.length; i++) {     
                    oos.writeObject(objs[i]);     
                }     
            } catch (Exception e) {     
                e.printStackTrace();     
            } finally {     
                try {     
                    oos.close();     
                } catch (IOException e) {     
                    e.printStackTrace();     
                }     
            }     
        }     
        /**   
         * 返回在文件中指定位置的对象   
         *    
         * @param file 指定的文件   
         * @param i 从1开始   
         * @return   
         */    
        public Object getObjFromFile(String file, int i) {     
            ObjectInputStream ois = null;     
            Object obj = null;     
            try {     
                FileInputStream fis = new FileInputStream(file);     
                ois = new ObjectInputStream(fis);     
                for (int j = 0; j < i; j++) {     
                    obj = ois.readObject();     
                }     
            } catch (Exception e) {     
                e.printStackTrace();     
            } finally {     
                try {     
                    ois.close();     
                } catch (IOException e) {     
                    e.printStackTrace();     
                }     
            }     
            return obj;     
        }     
        /**   
         * 测试   
         *    
         * @param args   
         */  
        public static void main(String[] args) {     
        	Secret jiami = new Secret();     
            // 执行MD5加密"Hello world!"     
            System.out.println("Hello经过MD5:" + jiami.encryptToMD5("Hello"));    
            //执行SHA加密"Hello world!"
            System.out.println("Hello world!经过SHA加密:"+jiami.encryptToSHA("Hello world!"));
            // 生成一个DES算法的密匙     
            SecretKey key = jiami.createSecretKey("DES");     
            // 用密匙加密信息"Hello world!"     
            String str1 = jiami.encryptToDES(key, "Hello");     
            System.out.println("使用des加密信息Hello为:" + str1);     
            // 使用这个密匙解密     
            String str2 = jiami.decryptByDES(key, str1);     
            System.out.println("解密后为:" + str2);     
            // 创建公匙和私匙     
            jiami.createPairKey();     
            // 对Hello world!使用私匙进行签名     
            jiami.signToInfo("Hello", "mysign.bat");     
            // 利用公匙对签名进行验证。     
            if (jiami.validateSign("mysign.bat")) {     
                System.out.println("Success!");     
            } else {     
                System.out.println("Fail!");     
            }     
        }
    }
    

    UI类:

    package secret;
    
    import java.awt.EventQueue;
    
    import javax.crypto.SecretKey;
    import javax.swing.JFrame;
    import javax.swing.JLabel;
    import javax.swing.JTextField;
    import javax.swing.event.DocumentEvent;
    import javax.swing.event.DocumentListener;
    import javax.swing.text.Document;
    
    
    public class SecretUI implements  DocumentListener  {
    
    	/**
    	 * @author 毛兴宇
    	 * @param 加密解密UI界面
    	 */
    	private JFrame jframe;
    	private JTextField textfield;
    	private JTextField textfieldMD5;
    	private JTextField textfieldSHA;
    	private JTextField textfieldDES;
    	
    	public static void main(String[] args) {
    		EventQueue.invokeLater(new Runnable() {
    			public void run() {
    				try {
    					SecretUI window = new SecretUI();
    					window.jframe.setVisible(true);
    				} catch (Exception e) {
    					e.printStackTrace();
    				}
    			}
    		});
    		
    	}
    	
    	
    	public SecretUI() { 
    		initialize();
    	}
    
    	private void initialize() {
    		jframe = new JFrame();
    		jframe.setTitle("u5B57u7B26u4E32u52A0u5BC6 By:u6BDBu5174u5B87");
    		jframe.setBounds(100, 100, 424, 199);
    		jframe.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
    		jframe.getContentPane().setLayout(null);
            int w = jframe.getToolkit().getScreenSize().width;//宽度  
            int h = jframe.getToolkit().getScreenSize().height;//高度  
            jframe.setLocation(w/2-212,h/2-99);  
    		jframe.setResizable(false);
    		
    		JLabel label = new JLabel("u9700u52A0u5BC6u5B57u7B26u4E32:");
    		label.setBounds(16, 14, 82, 15);
    		jframe.getContentPane().add(label);
    		
    		JLabel labelMD5 = new JLabel("MD5u52A0u5BC6:");
    		labelMD5.setBounds(30, 50, 54, 15);
    		jframe.getContentPane().add(labelMD5);
    		
    		JLabel labelSHA = new JLabel("SHAu52A0u5BC6:");
    		labelSHA.setBounds(30, 86, 54, 15);
    		jframe.getContentPane().add(labelSHA);
    		
    		JLabel labelDES = new JLabel("DESu52A0u5BC6:");
    		labelDES.setBounds(30, 122, 54, 15);
    		jframe.getContentPane().add(labelDES);
    		
    		textfield = new JTextField();
    		textfield.setBounds(102, 11, 304, 21);
    		jframe.getContentPane().add(textfield);
    		textfield.setColumns(10);
    		
    		Document dt = textfield.getDocument();
    		dt.addDocumentListener(this);
    		
    		textfieldMD5 = new JTextField();
    		textfieldMD5.setColumns(10);
    		textfieldMD5.setBounds(102, 47, 304, 21);
    		jframe.getContentPane().add(textfieldMD5);
    		
    		textfieldSHA = new JTextField();
    		textfieldSHA.setColumns(10);
    		textfieldSHA.setBounds(102, 83, 304, 21);
    		jframe.getContentPane().add(textfieldSHA);
    		
    		textfieldDES = new JTextField();
    		textfieldDES.setColumns(10);
    		textfieldDES.setBounds(102, 119, 304, 21);
    		jframe.getContentPane().add(textfieldDES);
    	}
    
    
        /** 
        * 实现DocumentListener接口changedUpdate方法 
        * 该方法可以跟踪当文本框中已存在的内容改变时,获取相应的值 
        */  
    	public void changedUpdate(DocumentEvent e) {
    		Secret sr = new Secret();
    		textfieldMD5.setText(sr.encryptToMD5(textfield.getText()));
    		textfieldSHA.setText(sr.encryptToSHA(textfield.getText()));
    		SecretKey key = sr.createSecretKey("DES");
    		textfieldDES.setText(sr.encryptToDES(key, textfield.getText()));
    		
    	}
    
    
        /** 
        * 实现DocumentListener接口中insertUpdate方法 
        * 该方法可以跟踪文本框中输入的内容 
        */  
    	public void insertUpdate(DocumentEvent e) {
    		Secret sr = new Secret();
    		textfieldMD5.setText(sr.encryptToMD5(textfield.getText()));
    		textfieldSHA.setText(sr.encryptToSHA(textfield.getText()));
    		SecretKey key = sr.createSecretKey("DES");
    		textfieldDES.setText(sr.encryptToDES(key, textfield.getText()));
    		
    	}
    
    
        /** 
        * 实现DocumentListener接口removeUpdate方法 
        * 该方法可以跟踪文本框中移除的内容,例如:在文本框中点击Backspace 
        */  
    	public void removeUpdate(DocumentEvent e) {
    		Secret sr = new Secret();
    		textfieldMD5.setText(sr.encryptToMD5(textfield.getText()));
    		textfieldSHA.setText(sr.encryptToSHA(textfield.getText()));
    		SecretKey key = sr.createSecretKey("DES");
    		textfieldDES.setText(sr.encryptToDES(key, textfield.getText()));
    		
    		
    	}
    	
    
    }
    


    转载请注明出处:(毛兴宇http://blog.csdn.net/powmxypow/)

  • 相关阅读:
    java设计模式----代理模式
    其他技术----nginx开光
    Less的使用
    C++ 引用和指针
    leetcode 220 Contains Duplicate
    python网络数据采集1
    404
    前端知识点
    tcl自动生成fifo empty checker
    漫话:如何给女朋友解释什么是"大案牍术"?
  • 原文地址:https://www.cnblogs.com/keanuyaoo/p/3293999.html
Copyright © 2011-2022 走看看