Categories


Tags


HTTP使用RSA公钥加密算法加密明文

网站想要加密传输数据以防被窃取,最可靠的方式莫过于使用公钥加密算法加密,使用HTTPS协议的网站在整个传输过程中都使用了这个技术,对于未能使用HTTPS的HTTP网站我们也可以自行实现。

功能说明

由于HTTP是直接传输明文数据的,在网络安全越发严峻的今天,未经加密的HTTP方式已经变得岌岌可危,谷歌公司更是直接表明在搜索结果中会优先考虑使用HTTPS加密的网站。

尽管整体趋势是向HTTPS倾斜的,但是由于诸多服务器以及CDN等服务商还没全面兼容HTTPS协议,目前要实现整站切换至HTTPS协议可行性还不高。

同时安全形势又刻不容缓,对此,我们可以自行实现RSA加密私密信息。

算法说明

由于多梦数学不是很好,RSA公钥加密算法的具体实现多梦就不多说了,对算法的实现有兴趣的童鞋可以去看看阮一峰的“RSA算法原理”,下面多梦就说说RSA算法的效果。

RSA算法是非对称加密算法的一种,也叫公钥加密。

和对称加密算法不同的是,对称加密算法是加密和解密都使用同一把钥匙同一种规则,也就是如果你知道怎么加密的,你就知道怎么解密了。所以算法和密钥不能泄露,否则加密就无意义了。

而公钥加密算法则是同时拥有两把钥匙,一个叫公钥,一个叫私钥。这两个钥匙是对应的,使用公钥加密的内容只有使用私钥才能解密,使用私钥加密的内容只有使用公钥才能解密。所以算法和公钥都是可以公开的,只要私钥还是私密的,就是安全的。

实现思路

由于我们是加密HTTP要发送的数据,所以加密过程是要在客户端浏览器完成的,算法和密钥都需要在发送HTTP数据之前就已经存在浏览器中,此时使用对称加密算法已经无意义,因为别人根据你这个加密可以直接解密。

所以我们需要选择非对称性加密,在网页中引入算法和公钥加密,然后发送HTTP数据到服务器,服务器再根据私钥解密。因为私钥是私密的,所以算法和公钥公开也是无法解密,也是安全的。

具体到HTTP请求的加密实现,就是在网页提交表单数据之前使用JavaScript实现公钥加密数据,然后服务器接受到加密数据后,使用PHP或其他服务器语言进行私钥解密。

扩展阅读

使用JavaScript实现OpenSSL RSA加密和解密:https://github.com/travist/jsencrypt

使用PHP实现OpenSSL RSA加密和解密:http://php.net/manual/zh/ref.openssl.php

来源:投稿,原文链接。

来源:月光博客


Public @ 2017-11-18 15:56:00

为什么访问网站的时候,网址后面出现随机?jdfwkey=0plwb1字符,是否影响正常访问?

这些随机字符可能是网站生成的唯一标识符,常常用于跟踪用户和分析用户行为。在绝大多数情况下,这些随机字符不会影响正常访问,因为它们只是一种辅助功能。但是,在某些情况下,可能会存在问题,例如可能会导致链接出错或无法访问网站。如果这种情况发生,可以联系网站管理员寻求帮助。

Public @ 2023-03-30 21:00:15

域名注册新手指南

搜索引擎将会根据网站的域名来进行收录,拥有合适的域名才能够获取更多的来自搜索引擎的流量,进而带来更多的目标客户! 1.确定域名找到适合的域名,要注意单词书写无误,能准确表达您的目的,在网站设计中具有独特性,方便用户记忆。 2.获取域名获取域名步骤一般有两步:   a.注册商网站:一般通过搜索引擎上搜索相关关键字,如“域名注册”、“域名网站”,进入网站后查询下是否可以购买到所需的域名;

Public @ 2023-02-28 15:00:46

HTTPS究竟是啥?这篇文章带你快速了解HTTPS

HTTPS是超文本传输安全协议(HTTP Secure),是HTTP上加入SSL/TLS协议后的安全加密方式。HTTPS协议通过SSL/TLS证书验证以及数据加密来保证数据传输的安全性。在HTTPS协议的基础上,网页浏览器与网站服务器之间的数据传输过程将会被加密,使得攻击者无法对通信数据进行窃取、篡改、劫持等恶意操作。 HTTPS协议的作用是让网站浏览器与网站服务器之间的数据传输变得安全。HTT

Public @ 2023-04-22 23:00:26

Chrome下强制http重定向到https的方法

使用Google的https搜索的时候,我们会发现搜索结果虽然可以显示,但是有时候结果的链接却无法打开。这里的原因是因为Google的https的搜索结果链接往往使用的是http的方式打开,因此有时候会无法访问,本文将介绍在Chrome下解决这个问题的方法。如果你使用的是Chrome浏览器,只需要经过一些简单的设置,就可以强制Google的https搜索结果链接也使用https的方式打开。打开Ch

Public @ 2021-10-09 15:55:59

更多您感兴趣的搜索

0.570390s