当前位置: 首页 > news >正文

慈溪企业网站建设公司wordpress网盘搜索引擎源码

慈溪企业网站建设公司,wordpress网盘搜索引擎源码,南昌seo网站设计,wordpress 页面路径一、秘钥体系 第一部分查看书籍为 北京大学出版社出版的 丘维声老师的 数学思维方式与创新 在之前安全协议的讲解中#xff0c;很多的协议都是用了秘钥的这一概念#xff0c;相信很多同学对这不求甚解#xff0c;下面我来系统的介绍秘钥体系#xff0c;并且证明一下如今…一、秘钥体系 第一部分查看书籍为 北京大学出版社出版的 丘维声老师的 数学思维方式与创新     在之前安全协议的讲解中很多的协议都是用了秘钥的这一概念相信很多同学对这不求甚解下面我来系统的介绍秘钥体系并且证明一下如今的公钥私钥RSA密码系统。 秘钥即密钥在密码学中密钥key又常称金钥是指某个用来完成加密、解密、完整性验证等密码学应用的秘密信息。在对称密码学或称密钥密码学中加密和解密用的是同一个钥匙因此钥匙需要保密。而在公钥密码学或称非对称密码学中加密和解密用的钥匙不同通常一个是公开的称为公钥另一个保密称为私钥。 1.1 传统加密 传统的加密方法是加密、解密使用同样的密钥由发送者和接收者分别保存在加密和解密时使用。但这带来一个问题是密钥的生成、注入、存储、管理、分发等很复杂特别是随着用户的增加密钥的需求量成倍增加。 1.2 RSA密码系统(重点) 1976年美国斯坦福大学的两名学者迪菲和赫尔曼提出了公开密钥密码体制的概念。所谓的公开密钥密码体制就是使用不同的加密密钥与解密密钥是一种“由已知加密密钥推导出解密密钥在计算上是不可行的”密码体制。     为了论述清楚计算上不可行的问题我们给出一下定理 1.3 欧拉函数 在数论对正整数n欧拉函数是小于或等于n的正整数中与n互质的数的数目因此φ(1)1。 下面我们给出欧拉函数的计算公式 φ(n)n(1−1p1)(1−1p2)…(1−1pk),np1α1p2α2⋯pnαn\varphi (n) n(1-\frac{1}{p_1})(1-\frac{1}{p_2})\ldots(1-\frac{1}{p_k}), np_1^{{\alpha}_1}p_2^{{\alpha}_2}\cdots p_n^{{\alpha}_n}φ(n)n(1−p1​1​)(1−p2​1​)…(1−pk​1​),np1α1​​p2α2​​⋯pnαn​​ 其中p1, p2……pn为x的所有质因数x是不为0的整数 那么是如何证明的呢下面我给出一个比较简单的证明方法(容斥定理) 1.4 欧拉定理 在数论中欧拉定理,也称费马-欧拉定理是一个关于同余的性质。欧拉定理表明若n,a为正整数且n, a互质则: 1.5 公钥私钥体系的引入 知道这两个定理之后让我们联想一下加密的过程 发送方A需要向接收方B发送报文首先在发送方 A 通过 a 的幂进行加密将加密后的内容发送给B然后 接收方B 通过 b 的幂进行还原。而且对于取模的幂运算可以通过快速幂算法在 log(a) 的复杂度下完成过程如下图7-2所示 下面我们给出一个公钥私钥的方案查看他是否可行 接收方 B自己设计出 a, b, n其中 a, b, n满足的关系为ab≡kφ(n)1ab\equiv k{\varphi}(n)1ab≡kφ(n)1 接收方 B将其中的 作为公钥公布在互联网上将 b 作为私钥内部保留那么上述的过程就可以得以实现即该算法是可行的。     下面我们来考虑一下这种机制是否安全当攻击者 接收到 x‾a\overline{x}^{a}xa能否通过公布在互联网上的公钥 (a,n)(a, n)(a,n)计算出 bbb进而解密获取发送方A的原内容 即     在公式 ab≡kφ(n)1ab\equiv k{\varphi}(n)1ab≡kφ(n)1中已知 倘若攻击者知道aaa和φ(n)\varphi (n)φ(n) 就可以使用扩展的欧几里得算法可以在 log(n)log(n)log(n)的复杂度内找到未知数 b, k 的一组解决方案完成密码破解。 1.6 欧几里得算法与扩展欧几里得算法 这里我简单介绍一下欧几里得算法和扩展欧几里得算法 欧几里得算法 首先我们将a, b的最大公约数greatest common divisor记作gcd(a, b)     欧几里得算法就是为了求出两个数a、b的最大公约数他利用gcd(a, b) gcd(b, a%b)将问题不多进行递归求解使用 c 语言书写的代码如下本人手写 int gcd(int a, int b){if(b 0) return a;else return gcd(b, a % b); }扩展的欧几里得算法 是对于欧几里得算法的扩展在原本求解gcd(a, b)的基础之上求解 的问题。 对应的c代码如下证明过程即为代码的第一段注释本人手写 /* exgcd(a, b, x, y):a * x b * y gcd(a, b); exgcd(b, a % b, y, x):b * y (a - a / b * b) * x gcd (b, a % b)a * x b * (y - a / b * x) gcd (a, b)所以说可得递归通式:gcd(a, b, x, y):gcd(b, a % b, y, x)求结果y - a / b * x; 递归终点:b 0 时, a * x 0 * y ax 1, y 0*/ LL exgcd(LL a, LL b, LL x, LL y) {if (b 0LL) {x 1, y 0;return a;} else {exgcd(b, a % b, y, x);y - a / b * x;} }1.7 公钥私钥的具体实现 通过刚刚的扩展的欧几里得算法可以在破解者在已知 (a,φ(n))(a, \varphi (n))(a,φ(n))的前提下可以在O(log(N)O(log(N)O(log(N) 的时间复杂度下求出 中的bbb, 破解出私钥但是知道破解者知道 nnn就可以求出 φ(n)\varphi(n)φ(n)吗之前已经证明过欧拉函数的公式如下所示: 下面对 $\varphi (n) $的求解转移为了将 n 进行质数分解分解成以下形式 那么该分解的复杂度为多少了复杂度为O(n)O(\sqrt {n})O(n​) 当我们n很大时比如 106010^{60}1060此时普通计算机的求解就需要100年。 但是攻击者无法求解出 φn\varphi{n}φn接收方B是如何求解 的呢原来接收方仅仅只需要选取两个大的质数p, q然后让 npqnpqnpq因此可得 φ(n)(p−1)(q−1)\varphi (n)(p-1)(q-1)φ(n)(p−1)(q−1)求解完毕。     至此公开密钥密码体制基本概念讲解完毕 二、ssh密钥登录原理与实现免密登陆 第二部分参考博客 公钥和私钥都属于非对称加密算法的一个实现这个加密算法的信息交换过程是(乙向甲请求远程登录) 持有公钥的一方甲在收到持有私钥的一方乙的请求时甲会在自己的公钥列表中查找是否有乙的公钥如果有则使用一个随机字串使用公钥加密并发送给乙。乙收到加密的字串使用自己的私钥进行解密并将解密后的字串发送给甲。甲接收到乙发送来的字串与自己的字串进行对比如过通过则验证通过否则验证失败。 也就是说请求登陆他人计算机的 客户机 需要有自己的公钥和私钥并将自身公钥发送给 被登录机 服务机 非对称加密算法不能使用相同的密钥进行解密也就是说公钥加密的只能使用私钥进行解密。 这一部分可以通过第一部分的证明得知 ab≡kφ(n)1ab\equiv k\varphi (n) 1ab≡kφ(n)1仅仅使用 aaa或者是 仅仅使用 bbb 是没有这个等式关系的 2.1 免密登陆过程 ssh使用私钥登录大致步骤就是主机A客户端创建公钥私钥并将公钥复制到主机B被登陆机的指定用户下然后主机A使用保存私钥的用户登录到主机B对应保存公钥的用户。 (1) 实验环境 两台主机 主机A客户机192.168.187.137主机B被登陆机192.168.187.142 (2) 实验开始 在需要免密登陆的主机主机A下生成公钥和私钥 ssh-keygen -t rsa ##-t rsa可以省略默认就是生成rsa类型的密钥说明命令执行后会有提示输入三次回车即可执行完成后会在当前用户的.ssh目录下生成两个文件id_rsa、id_rsa.pub文件前者时私钥文件后者是公钥文件拷贝到其他主机只需要拷贝这个文件的内容 将公钥复制到被登陆的主机上的 ~/.ssh/authorized_keys 文件中 拷贝公钥有两种方法其原理都相同 方式一使用 ssh-copy-id 直接拷贝 使用 ssh-copy-id 进行拷贝公钥非常方便只需要指定目标主机和目标主机的用户即可。 ssh-copy-id -i ~/.ssh/id_rsa.pub root192.168.187.142执行这条命令后会自动将登录主机的公钥文件内容追加至目标主机中指定用户root.ssh目录下的authorized_keys文件中。这个过程是全自动的非常方便。 方法二自己创建文件进行拷贝 在登录主机客户机上创建authorized_keys文件并将公钥追加到该文件。 cat id_rsa.pub authorized_keys chmod 600 authorized_keys ##修改文件权限为600该文件有规定如果属组其他人出现可写则文件就不会生效在被登录机的指定用户家目录下创建 .ssh 目录这里在root用户下创建因为要使用密钥登陆到root用户你也可以使 hadoop 用户 mkdir .ssh chmod 700 .ssh ##将目录权限改为700该目录的权限必须是700才有效将登录机创建的authorized_keys文件拷贝到被登录机使用scp scp authorized_keys root192.168.187.142:/root/.ssh/ authorized_keys 100% 402 576.4KB/s 00:002.2 免密登陆 登录 使用主机A乙root用户身份登陆到主机B ssh root192.168.187.142 Last login: Wed Feb 13 15:24:30 2019 from 192.168.187.137首次登录将弹出保存信息输入yes即可此时已经实现了免密的密钥登陆。 注意事项和说明     上例只能实现主机A免密登陆到主机B的root用户如果想让主机B也免密登录到主机A创建密钥和拷贝步骤相同。     密钥登陆的方式只能登录被登录机中 .ssh 目录下有对应公钥的用户如果想让所有用户都可以被登录则需要将authorized_keys文件的内容追加到其他用户的 ~/.ssh/authorized_keys 文件中。     如果使用自己创建的authorized_keys文件进行复制公钥则要严格设置权限权限不正确会导致文件无法使用也就无法进行密钥验证。 再次说明第二部分参考至博客园的一个博客
http://www.zqtcl.cn/news/215033/

相关文章:

  • 建筑类企业网站模板怎么制作网站链接
  • 常州网站建设外包襄阳做网站的
  • 临清网站优化用jsp做网站的感想
  • 个人工作室网站网站备案 万网
  • 网络推广模板网站会员管理软件
  • 西乡塘网站建设网站建设公司的成本有哪些方面
  • 在哪里可以学习做网站西安制作公司网站的公司
  • 网站建设 更新 维护淮北矿业工程建设公司网站
  • 网站开发 平台宝应做网站
  • 网站开发开题报告广州的兼职网站建设
  • 辽宁同鑫建设网站网站后期维护费用
  • 政法网站建设有哪些不足广州网站建设信息科技有限公司
  • 营销型网站 平台海口智能建站价格
  • 网站空间过期电商网站建设比较好的
  • seo公司 彼亿营销舆情优化公司
  • diango是做网站的后端吗网页怎么做成app
  • 思勤传媒网站建设公司如何查询网站的外链
  • 网站设计思路文案范文专业手机网站建设多少钱
  • 有部分网站打不开网站服务内容怎么写
  • 百度安全网站检测好看的免费的小说网站模板
  • 锡山区住房和城乡建设局网站免费ppt模板下载简约
  • 建设银行 杭州招聘网站建设工程有限公司是干什么的
  • 做网站必须购买空间吗?3点新闻发布
  • 济南集团网站建设流程东莞做网站公司首选
  • 有需要做网站推广找我网站怎么 备案
  • 怎么把网站放到服务器上站长工具seo综合查询外部链接数量
  • 做网站上市的公司开一家公司最低注册资金
  • 仙居谁认识做网站的有哪些好的网站建设
  • 互动广告机网站建设怀集网站建设
  • 好的 做网站的软件公司pinterest app下载