学习笔记-CTF密码相关
RSA共模攻击
RSA基本原理
① 选择两个大的质数p和q,N=pq;
② 根据欧拉函数,求得r=(p-1)(q-1);
③ 选一个小于r的整数e,求得e关于模r的模反元素d;
④ 将p和q的记录销毁;
⑤ 公钥为(N,e),私钥为(N,d)
加密:
将消息转换为小于N的整数n,
通过n^e≡c(mod N)
得到密文c
解密:
通过c^d≡n(mod N)
将密文c变为原文n
共模攻击原理:
当N相同时,找到两个互质的e,在已知N、c1、c2、e1、e2的情况下,
c1=m^e1%N
c2=m^e2%N
可通过公式e1s1+e2s2=1,解得s1和s2两个整数
最终得到c1^s1*c2^s2=m
凯撒密码
加密:
En(x)=(x+n) mod 26
解密:
Dn(x)=(x-n) mod 26
其中偏移量n为大于等于1小于26的整数
原理:明文中的所有字母按照偏移量n偏移后被替换为密文。
维吉尼亚密码
——古典密码中需要密钥的密码
加密:
Ci≡Pi+Ki(mod 26)
解密:
Pi≡Ci-Ki(mod 26)
其中K为密钥
维吉尼亚密码表:

猪圈密码

两种加解密方式
一:图形和字母变换
例:

二:左右一一对应变换
Python脚本实现:
import sys def pigpen_chiper(letter):
a = "abcdefghistuv"
b = "jklmnopqrwxyz"
if letter.isalpha():
if letter in a:
n = a.find(letter)
pig = b[n]
else:
n = b.find(letter)
pig = a[n]
return pig
else:
return letter def pigpen(word):
"""
pigpen chiper
"""
res = ''
for letter in word:
res += pigpen_chiper(letter)
return res if __name__ == '__main__':
if len(sys.argv) != 2:
print "Pigpen_chiper decode 猪圈密码解密器v1.0 BY 0h1in9e"
print "Usage: "+sys.argv[0]+" 'ocjp{zkii}'"
else:
print pigpen(sys.argv[1])
AAencode
扩展:ppencode/rrencode/jjencode
参考URL:https://www.cnblogs.com/android-html5/archive/2011/02/09/2533784.html
Rabbit密码
一种流密码
在线加解密URL:http://www.sojson.com/encrypt_rabbit.html
栅栏密码
原理:①将要传递的信息交替排成上下两行;②将下面一行字母排在上面一行后边形成密文。
例:

学习笔记-CTF密码相关的更多相关文章
- DSP EPWM学习笔记2 - EPWM相关寄存器设置问题解析
DSP EPWM学习笔记2 - EPWM相关寄存器设置问题解析 彭会锋 本篇主要针对不太熟悉的TZ 故障捕获 和 DB 死区产生两个子模块进行学习研究 感觉TI的寄存器命名还是有一定规律可循的 SEL ...
- 学习笔记之html5相关内容
写一下昨天学习的html5的相关内容,首先谈下初次接触html5的感受.以前总是听说html5是如何的强大,如何的将要改变世界.总是充满了神秘感.首先来谈一下我接触的第一个属性是 input的里面的 ...
- rails学习笔记: rake db 相关命令
rails学习笔记: rake db 命令行 rake db:*****script/generate model task name:string priority:integer script/g ...
- TSPL学习笔记(4):数组相关练习
最近研究函数式编程,都是haskell和scheme交互着看的,所以笔记中两种语言的内容都有,练习一般也都用两种语言分别实现. 本篇练习一些数组有关的问题,之所以与数组相关是因为在命令式编程中以下问题 ...
- Linux学习笔记之Linux相关知识
[想成为某一方面的大神,没有捷径可走,只能不断的记录.练习.总结.coding……] notes:主要从网上摘录了一些关于Linux的历史以及一些相关内容,以便对Linux系统有一定的了解.这不但可以 ...
- Struts 2学习笔记——拦截器相关
一.添加国际化支持 默认的struts-deault.xml文件中已经定义了国际化拦截器,内容如下 <!-定义国际化拦截器--> <interceptor name="i1 ...
- python学习笔记六 面向对象相关下(基础篇)
面向对象基本知识: 面向对象是一种编程方式,此编程方式的实现是基于对 类 和 对象 的使用 类 是一个模板,模板中包装了多个“函数”供使用(可以将多函数中公用的变量封装到对象中) 对象,根据模板创建的 ...
- Python学习笔记——与爬虫相关的网络知识
1 关于URL URL(Uniform / Universal Resource Locator):统一资源定位符,用于完整地描述Internet上网页和其他资源的地址的一种标识方法 URL是爬虫的入 ...
- linux学习笔记一----------文件相关操作
一.目录结构 二.文件管理操作命令(有关文件夹操作,使用Tab键自动补全文件名(如果多个默认第一个)) 1.ls 查看目录信息:ls -l 查看目录详细信息(等价于ll 某些系统不支持) 2.pwd ...
随机推荐
- MQTT协议实现Android中的消息收发
前言 MQTT(Message Queuing Telemetry Transport,消息队列遥测传输),基于发布/订阅范式的消息协议,是一种极其简单和轻量级的消息协议,专为受限设备和低带宽.高延迟 ...
- 运输问题中产销不平衡问题(表上作业法和LINGO方法)
对于产销不平衡问题有两种情况: 供大于求(产大于销)→增加虚拟销地 供不应求(产小于销)→增加虚拟产地 例如以下例题: 这个题中,总产量为55,总销量为60,故而我们知道这个问题属于供不应求. 1.这 ...
- 3.Metasploit攻击流程及命令介绍
Metasploit 进阶第一讲 攻击流程及命令介绍 01.渗透测试过程环节(PTES) 1.前期交互阶段:与客户组织进行交互讨论,确定范围,目标等 2.情报搜集阶段:获取更多目标组织信 ...
- JavaScript new 的时候到底发生了什么?
function Person(name) { this.name = name; } let liLei = new Person('lilei'); console.log(liLiei.name ...
- Azure安装win2016的服务器,并下载安装mysql数据库心得
随便写写 第一部分:新建虚拟机创建win2016服务器 这部分内容跟着微软云提示操作即可, 基本步骤:创建一堆名字,选择一个地区的服务器,配置一些基本信息,然后azure就会自动创建虚拟机并安装你选择 ...
- 关于C#三层架构增删改查中的“删除”问题
序: 刚学习C#,经过一段时间学习,现在正在做一个简单的前后台联通的项目(主要是C#三层架构实现增删改查).分享一点儿小经验,也供自己以后可以回头看看自己的码农之路. 内容: 主要分享的是一条删除会用 ...
- 分享淘宝时间服务器同步时间接口api和苏宁时间服务器接口api
最近要开发一款抢购秒杀的小工具,需要同步系统时间,这里分享两个时间服务器接口api给大家: 1.淘宝时间服务器时间接口 http://api.m.taobao.com/rest/api3.do?api ...
- (CSS):last-child与:last-of-type区别
<!DOCTYPE html><html><head> <meta charset="utf-8"> <title>la ...
- Springboot项目中 前端展示本地图片
Springboot项目中 前端展示本地图片 本文使用的是Springboot官方推荐的thymeleaf(一种页面模板技术) 首先在pom文件加依赖 <dependency> <g ...
- Emergency Evacuation(最短下车时间)———(思维)
题意: 给你一个车厢和一些人的位置,这些人都坐在座位上,求这些人全部出去的时间最小值. 注意: 有许多行座位,且每行关于过道对称,出口在过道一端,一个时间只能移动一个单位,且每时刻每个格子只能有一人 ...