在用户登录页面,用户输入密码后,在传送到服务器端时,为防止在密码传送过程中,被如360这种东东给拦截到,

需要在传送前对密码进行加密,然后再传送!

利用RSA加密,在客户端使用公钥对密码进行加密,在服务器端接收时使用私钥进行解密

JS端加密主要用到https://github.com/jasondavies/jsbn所述的功能来实现

1、使用linux服务器生成pem文件

$ openssl genrsa -out key.pem

2、提取modulus用作js加密的密钥(红字部份)

$ openssl rsa -in key.pem -noout -modulus

Modulus=C4E4B9345F5BA44DDE717385660EBF6A217CF2D59145A3DA3B57D460A285242E04D7CF57969E77749BC6D325B1381E29BD827F90F13909A97256B4B6B217141F
3、参照https://github.com/jasondavies/jsbn自己引用jsbn.js、prng4.js、rng.js、rsa.js、base64.js

4、JS脚本加密

var RSAPublicKey="C4E4B9345F5BA44DDE717385660EBF6A217CF2D59145A3DA3B57D460A285242E04D7CF57969E77749BC6D325B1381E29BD827F90F13909A97256B4B6B217141F";
var strPassword="123456";
var RSA = new RSAKey();
RSA.setPublic(RSAPublicKey, "10001");
strPassword = RSA.encrypt(strPassword);

在服务器端,使用Rsa来解密

package com.zufangbao.core.security;

import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.FileReader;
import java.io.IOException;
import java.security.KeyFactory;
import java.security.PrivateKey;
import java.security.PublicKey;
import java.security.Security;
import java.security.spec.PKCS8EncodedKeySpec;
import java.security.spec.X509EncodedKeySpec;

import javax.crypto.Cipher;

import org.apache.commons.codec.binary.Base64;
import org.apache.commons.codec.binary.Hex;
import org.apache.log4j.Logger;
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.bouncycastle.openssl.PEMKeyPair;
import org.bouncycastle.openssl.PEMParser;
import org.springframework.stereotype.Component;

/**
 * RSA加解密处理
 * @author Administrator
 *
 */
@Component
public class RsaUtil {
	private static final Logger log = Logger.getLogger(RsaUtil.class);

	public RsaUtil(){
	}
	/**
	 * 使用Pom初始化 @see setPomFile
	 * @param pomFile
	 */
	public RsaUtil(String pemFile){
		this.setPemFile(pemFile);
	}
	/**
	 * 使用公钥私钥初始化 @see setKey
	 * @param publicKey
	 * @param privateKey
	 */
	public RsaUtil(PublicKey publicKey, PrivateKey privateKey){
		this.setKey(publicKey, privateKey);
	}
	/**
	 * 使用公钥私钥文件初始化 @see setKey
	 * @param publicKeyFile
	 * @param privateKeyFile
	 */
	public RsaUtil(String publicKeyFile, String privateKeyFile){
		this.setKey(publicKeyFile, privateKeyFile);
	}
	private PublicKey publicKey;
	private PrivateKey privateKey;
	/**
	 * 获取公钥
	 * @return
	 */
	public PublicKey getPublicKey() {
		return publicKey;
	}
	/**
	 * 设置公钥
	 * @param publicKey
	 */
	public void setPublicKey(PublicKey publicKey) {
		this.publicKey = publicKey;
	}
	/**
	 * 获取私钥
	 * @return
	 */
	public PrivateKey getPrivateKey() {
		return privateKey;
	}
	/**
	 * 设置私钥
	 * @param privateKey
	 */
	public void setPrivateKey(PrivateKey privateKey) {
		this.privateKey = privateKey;
	}
	/**
	 * 设置POM文件方式指定公钥私钥
	 * @param pomFile
	 */
	public void setPemFile(String pemFile){
		BufferedReader br = null;
		try{
			br = new BufferedReader(new FileReader(pemFile));
			Security.addProvider(new BouncyCastleProvider());

			PEMKeyPair kp = (PEMKeyPair) new PEMParser(br).readObject();
			byte[] encodedPublicKey = kp.getPublicKeyInfo().getEncoded();
			byte[] encodedPrivateKey = kp.getPrivateKeyInfo().getEncoded();

			// Now convert to Java objects
			KeyFactory keyFactory = KeyFactory.getInstance( "RSA");
			X509EncodedKeySpec publicKeySpec = new X509EncodedKeySpec(encodedPublicKey);
			PublicKey publicKey = keyFactory.generatePublic(publicKeySpec);

			PKCS8EncodedKeySpec privateKeySpec = new PKCS8EncodedKeySpec(encodedPrivateKey);
			PrivateKey privateKey = keyFactory.generatePrivate(privateKeySpec);
			this.setKey(publicKey, privateKey);
		}catch(Exception e){
			log.fatal("setPomFile failed", e);
		}finally{
			if (br != null){
				try {
					br.close();
				} catch (IOException e) {
					log.fatal("setPomFile failed", e);
				}
			}
		}
	}
	/**
	 * 设置公钥私钥
	 * @param publicKey
	 * @param privateKey
	 */
	public void setKey(PublicKey publicKey, PrivateKey privateKey){
		this.publicKey = publicKey;
		this.privateKey = privateKey;
	}
	/**
	 * 设置公钥私钥
	 * @param publicKeyFile
	 * @param privateKeyFile
	 */
	public void setKey(String publicKeyFile, String privateKeyFile){
		PublicKey publicKey = this.readPublicKey(publicKeyFile);
		PrivateKey privateKey = this.readPrivateKey(privateKeyFile);
		this.setKey(publicKey, privateKey);
	}
	/**
	 * 读取公钥
	 * @param keyFile
	 * @return
	 */
	private PublicKey readPublicKey(String keyFile){
		FileInputStream fis = null;
		try{
			fis = new FileInputStream(keyFile);
			byte[] bytes = new byte[fis.available()];
			fis.read(bytes);
			PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(bytes);
			KeyFactory factory = KeyFactory.getInstance("RSA");
			PublicKey key = factory.generatePublic(keySpec);
			return key;
		}catch(Exception e){
			log.fatal("readPublicKey failed", e);
			return null;
		}finally{
			if (fis != null){
				try {
					fis.close();
				} catch (IOException e) {
					log.fatal("readPublicKey failed", e);
				}
			}
		}
	}
	/**
	 * 读取私钥
	 * @param keyFile
	 * @return
	 */
	private PrivateKey readPrivateKey(String keyFile){
		FileInputStream fis = null;
		try{
			fis = new FileInputStream(keyFile);
			byte[] bytes = new byte[fis.available()];
			fis.read(bytes);
			PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(bytes);
			KeyFactory factory = KeyFactory.getInstance("RSA");
			PrivateKey key = factory.generatePrivate(keySpec);
			return key;
		}catch(Exception e){
			log.fatal("readPublicKey failed", e);
			return null;
		}finally{
			if (fis != null){
				try {
					fis.close();
				} catch (IOException e) {
					log.fatal("readPublicKey failed", e);
				}
			}
		}
	}
	/**
	 * 加密字符串
	 * @param value 普通字符串 长度不能超过53个字节
	 * @return 返回Base64位编码的字符串
	 */
	public String encryptString2b64(String value){
		if (this.getPublicKey() == null){
			log.fatal("RSA公钥为空,加密失败");
			return null;
		}
		try{
			Cipher cipher = Cipher.getInstance("RSA");
	        cipher.init(Cipher.ENCRYPT_MODE, this.getPublicKey());
	        byte[] bytes = cipher.doFinal(value.getBytes());
	        return Base64.encodeBase64String(bytes);
		}catch(Exception e){
			log.fatal("encryptString failed", e);
			return null;
		}
	}
	/**
	 * 使用私钥解码Base64位字串
	 * @param value Base64位字串
	 * @return 返回原始字符串
	 */
	public String decryptString4b64(String value){
		if (this.getPrivateKey() == null){
			log.fatal("RSA私钥为空,加密失败");
			return null;
		}
		if (value == null){
			log.fatal("待RSA解密字串不能为空");
			return null;
		}
		try{
			Cipher cipher = Cipher.getInstance("RSA");
	        cipher.init(Cipher.DECRYPT_MODE, this.getPrivateKey());
	        byte[] bytes = Base64.decodeBase64(value);
	        bytes = cipher.doFinal(bytes);
	        return new String(bytes);
		}catch(Exception e){
			log.fatal("decryptString failed", e);
			return null;
		}
	}
	/**
	 * 加密字符串
	 * @param value 普通字符串 长度不能超过53个字节
	 * @return 返回hex编码的字符串
	 */
	public String encryptString2hex(String value){
		if (this.getPublicKey() == null){
			log.fatal("RSA公钥为空,加密失败");
			return null;
		}
		try{
			Cipher cipher = Cipher.getInstance("RSA");
	        cipher.init(Cipher.ENCRYPT_MODE, this.getPublicKey());
	        byte[] bytes = cipher.doFinal(value.getBytes());
	        return new String(Hex.encodeHex(bytes));
		}catch(Exception e){
			log.fatal("encryptString failed", e);
			return null;
		}
	}
	/**
	 * 使用私钥解码hex字串
	 * @param value hex字串
	 * @return 返回原始字符串
	 */
	public String decryptString4hex(String value){
		if (this.getPrivateKey() == null){
			log.fatal("RSA私钥为空,加密失败");
			return null;
		}
		if (value == null){
			log.fatal("待RSA解密字串不能为空");
			return null;
		}
		try{
			Cipher cipher = Cipher.getInstance("RSA");
	        cipher.init(Cipher.DECRYPT_MODE, this.getPrivateKey());
	        byte[] bytes = Hex.decodeHex(value.toCharArray());
	        bytes = cipher.doFinal(bytes);
	        return new String(bytes);
		}catch(Exception e){
			log.fatal("decryptString failed", e);
			return null;
		}
	}
}

  pom.xml主要依赖有

<dependency>
    <groupId>commons-codec</groupId>
    <artifactId>commons-codec</artifactId>
    <version>1.8</version>
</dependency>
<dependency>
    <groupId>org.bouncycastle</groupId>
    <artifactId>bcpkix-jdk15on</artifactId>
    <version>1.49</version>
</dependency>

 在项目中通过spring注入pem文件,实现解密

用户登录密码RSA加密后传输的实现,非明文密码传输的更多相关文章

  1. 电信级的RSA加密后的密码的破解方法

    一直以来,电信通过HTTP劫持推送广告的方式已经存在了很多年了,这种手段至今并未停止.这种手段月光博客曾经有多次曝光,见<电信级的网络弹出广告>.<获取了电信恶意弹出广告的罪证> ...

  2. Centos 用户登录失败N次后锁定用户禁止登陆

    针对linux上的用户,如果用户连续3次登录失败,就锁定该用户,几分钟后该用户再自动解锁 Linux有一个pam_tally2.so的PAM模块,来限定用户的登录失败次数,如果次数达到设置的阈值,则锁 ...

  3. Centos7下用户登录失败N次后锁定用户禁止登陆的方法

    前言 针对linux上的用户,如果用户连续3次登录失败,就锁定该用户,几分钟后该用户再自动解锁.Linux有一个pam_tally2.so的PAM模块,来限定用户的登录失败次数,如果次数达到设置的阈值 ...

  4. Centos7 用户登录失败N次后锁定用户禁止登陆

    参考网站:https://blog.csdn.net/qq_33285112/article/details/78813369  未试 思路是查找/var/log/secure中验证失败且出现的次数较 ...

  5. GS环境里面 9999 常用密码的加密后的值

    1. Test6530 APTZ5s6vrw1dglqO/63osA== 2. aaaaaa zgnewZXGGoqcPGtNpXTSXQ== 3. cwpass 3Me34S0+zY4xEGUFtz ...

  6. 系统开发中使用拦截器校验是否登录并使用MD5对用户登录密码进行加密

    项目名称:客户管理系统 项目描述: 项目基于javaEE平台,B/S模式开发.使用Struts2.Hibernate/Spring进行项目框架搭建.使用Struts中的Action 控制器进行用户访问 ...

  7. 兼容javascript和C#的RSA加密解密算法,对web提交的数据进行加密传输

    Web应用中往往涉及到敏感的数据,由于HTTP协议以明文的形式与服务器进行交互,因此可以通过截获请求的数据包进行分析来盗取有用的信息.虽然https可以对传输的数据进行加密,但是必须要申请证书(一般都 ...

  8. 如何正确对用户密码进行加密?转自https://blog.csdn.net/zhouyan8603/article/details/80473083

    本文介绍了对密码哈希加密的基础知识,以及什么是正确的加密方式.还介绍了常见的密码破解方法,给出了如何避免密码被破解的思路.相信读者阅读本文后,就会对密码的加密有一个正确的认识,并对密码正确进行加密措施 ...

  9. iOS动态部署之RSA加密传输Patch补丁

    概要:这一篇博客主要说明下iOS客户端动态部署方案中,patch(补丁)是如何比较安全的加载到客户端中. 在整个过程中,需要使用RSA来加密(你可以选择其它的非对称加密算法),MD5来做校验(同样,你 ...

随机推荐

  1. Android Studio常用快捷键汇总(mac)

    查看原文:http://blog.csdn.net/u010818425/article/details/52266195 mac上按键符号 ⌥ : option / alt ⇧ : shift ⌃ ...

  2. VMware系统运维(十)部署虚拟化桌面 Horizon View 5.2 Connection Server安装

    部署桌面虚拟化,首先得安装连接服务器,下面我们开始安装Connection Server. 1.下载并安装以下软件,提示:只能在Win2008R2上安装,Win2012R2无法安装. 2.双击打开程序 ...

  3. Linux文件系统的barrier:启用还是禁用

    大多数当前流行的Linux文件系统,包括EXT3和EXT4,都将文件系统barrier作为一个增强的安全特性.它保护数据不被写入日记.但 是,在许多情况下,我们并不清楚这些barrier是否有用.本文 ...

  4. amoeba实现MySQL读写分离

    amoeba实现MySQL读写分离 准备环境:主机A和主机B作主从配置,IP地址为192.168.131.129和192.168.131.130,主机C作为中间件,也就是作为代理服务器,IP地址为19 ...

  5. React Native教程 - 调用Web API

    react-native官网Fetch介绍:https://facebook.github.io/react-native/docs/network.html#content react-native ...

  6. 转 : React Native 开发之 IDE 选型和配置

    转:https://mp.weixin.qq.com/s?__biz=MzA3ODg4MDk0Ng==&mid=2651112392&idx=1&sn=135e29ddde30 ...

  7. php curl破解防盗链

    function get_content($url){ $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); $header = array( ...

  8. Backbone.js学习之View

    千呼万唤始出来,终于到最后一个要点View了.照旧,先来一睹官方文档: Backbone views are almost more convention than they are code - t ...

  9. JavaScript库开发者们的规则

    详细内容请点击 1. 保持无侵入性 我的HTML标记不想知道你的JavaScript代码. 2. 严禁修改和扩展Object.prototype! 这条很重要,因此需要一条完全针对它的规则.对象是Ja ...

  10. Sql server For XML Path 学习

    最近看到太多人问这种问题   自己也不太了解  就在网上学习学习 自己测试一番 CREATE TABLE test0621 (id INT,NAME NVARCHAR(max)) INSERT tes ...