Base64编码和解码(手写和调包)

2023-12-13 01:38

本文主要是介绍Base64编码和解码(手写和调包),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

做了很久的CTF,一直使用在线工具去解析base64,从没想过这些编码的原理,终于有心思研究一下。

0x01. 什么是base64?

Base64是一种用64个字符来表示任意二进制数据的方法。它是一种编码方式,并不是加密方式。它通过将二进制数据转变为64个“可打印字符”,完成了数据在HTTP协议上的传输。

0x02. base64如何玩转?

Base64编码要求把3个8位字节( 3 8 = 24 3*8 =24 38=24)转化为4个6位的字节( 4 6 = 24 4*6=24 46=24),之后在6位的前面补两个0,形成8位一个字节的形式。 如果剩下的字符不足3个字节,则用0填充,输出字符使用‘=’,因此编码后输出的文本末尾可能会出现1或2个‘=’。

0x02_1. base64编码表

为了保证所输出的编码位可读字符,Base64制定了一个编码表,以便进行统一转换。编码表的大小为 2 6 = 64 2^6=64 26=64,这也是Base64名称的由来。编码表如下:

在这里插入图片描述
引用一个作图优秀的博客:https://www.cnblogs.com/xq1314/p/7909521.html

0x02_2. 图例分析

假设我们有三个字母Man,进行base64编码,过程如图:

3个8位字节转化为4个6位的字节,之后在6位的前面补两个0,形成8位一个字节的形式。

在这里插入图片描述
但是,当需要转换的字符数不是3的倍数的情况下该怎么办呢?Base64规定,当需要转换的字符不是3的倍数时,一律采用补0的方式凑足3的倍数,具体如下表所示:

在这里插入图片描述

0x03. base64编码脚本

import math
from string import ascii_uppercase, ascii_lowercase, digitsdef base64_encode(s):base = ascii_uppercase + ascii_lowercase + digits + '+/'bits = [bin(ord(x))[2:].rjust(8, '0') for x in s]bits_concat = ''.join(bits)rounds = math.ceil(len(bits_concat) / 6)bits_concat_cut = [bits_concat[6 * round: 6 * (round + 1)] for round in range(rounds)]result = [base[int(x.ljust(6, '0'), 2)] for x in bits_concat_cut]res = ''.join(result)if len(result) % 4 == 0:return reselif len(result) % 4 == 2:return res + '=='else:return res + '='if __name__ == '__main__':print(base64_encode('Man'))print(base64_encode('Ma'))print(base64_encode('M'))

结果如图:
在这里插入图片描述

0x04. base64解码脚本

import math
from string import ascii_uppercase, ascii_lowercase, digitsdef base64_decode(s):base = ascii_uppercase + ascii_lowercase + digits + '+/'if '==' in s: # 如果是填充两个==s = s[0: -2]elif '=' in s: # 如果是填充一个==s = s[0: -1]# 找到对应的密码表进制,填充为6位一组bin_data = [bin(base.find(x))[2:].rjust(6, '0') for x in s]bin_data_concat = ''.join(bin_data)# 将拼接字符以8位长度作为分隔还原cut = [bin_data_concat[idx: idx + 8] for idx in range(0, len(bin_data_concat), 8)]# 当字符长度为8位直接还原,不足长度说明是填充的无需操作rt = [chr(int(x, 2)) if len(x) == 8 else '' for x in cut]return ''.join(rt)if __name__ == '__main__':print(base64_decode('TWFu'))print(base64_decode('TWE='))print(base64_decode('TQ=='))

结果如图:
在这里插入图片描述

0x05. 使用python3.5自带的函数进行编码

import base64if __name__ == '__main__':string = 'Man'.encode()str_encode = base64.b64encode(string)# 编码得到TWFuprint(str_encode)str_decode = base64.b64decode(str_encode)# 解码得到Manprint(str_decode)

结果如图:在这里插入图片描述

0x06. 总结

  • 在网络传输中,不是所的的内容都是可打印字符,其中绝大多数数据是不可见字符,base64可以基于64个可打印字符来表示这些带有不可打印字符的传输数据。
  • base64一般不作为安全加密算法的,因为过程可逆。

幸地识请桃花面,从此阡陌多暖春。 最后放个美图放松一下眼睛:
在这里插入图片描述

这篇关于Base64编码和解码(手写和调包)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/486696

相关文章

Java文件与Base64之间的转化方式

《Java文件与Base64之间的转化方式》这篇文章介绍了如何使用Java将文件(如图片、视频)转换为Base64编码,以及如何将Base64编码转换回文件,通过提供具体的工具类实现,作者希望帮助读者... 目录Java文件与Base64之间的转化1、文件转Base64工具类2、Base64转文件工具类3、

使用Python实现图片和base64转换工具

《使用Python实现图片和base64转换工具》这篇文章主要为大家详细介绍了如何使用Python中的base64模块编写一个工具,可以实现图片和Base64编码之间的转换,感兴趣的小伙伴可以了解下... 简介使用python的base64模块来实现图片和Base64编码之间的转换。可以将图片转换为Bas

通过C#和RTSPClient实现简易音视频解码功能

《通过C#和RTSPClient实现简易音视频解码功能》在多媒体应用中,实时传输协议(RTSP)用于流媒体服务,特别是音视频监控系统,通过C#和RTSPClient库,可以轻松实现简易的音视... 目录前言正文关键特性解决方案实现步骤示例代码总结最后前言在多媒体应用中,实时传输协议(RTSP)用于流媒体服

BUUCTF(34)特殊的 BASE64

使用pycharm时,如果想把代码撤销到之前的状态可以用 Ctrl+z 如果不小心撤销多了,可以用 Ctrl+Shift+Z 还原, 别傻傻的重新敲了 BUUCTF在线评测 (buuoj.cn) 查看字符串,想到base64的变表 这里用的c++的标准程序库中的string,头文件是#include<string> 这是base64的加密函数 std::string

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

form表单提交编码的问题

浏览器在form提交后,会生成一个HTTP的头部信息"content-type",标准规定其形式为Content-type: application/x-www-form-urlencoded; charset=UTF-8        那么我们如果需要修改编码,不使用默认的,那么可以如下这样操作修改编码,来满足需求: hmtl代码:   <meta http-equiv="Conte

FFmpeg系列-视频解码后保存帧图片为ppm

在正常开发中遇到花屏时怎么处理呢?可以把解码后的数据直接保存成帧图片保存起来,然后直接看图片有没有花屏来排除是否是显示的问题,如果花屏,则代表显示无问题,如果图片中没有花屏,则可以往显示的方向去排查了。 void saveFrame(AVFrame* pFrame, int width, int height, int iFrame){FILE *pFile;char szFilename[

4-4.Andorid Camera 之简化编码模板(获取摄像头 ID、选择最优预览尺寸)

一、Camera 简化思路 在 Camera 的开发中,其实我们通常只关注打开相机、图像预览和关闭相机,其他的步骤我们不应该花费太多的精力 为此,应该提供一个工具类,它有处理相机的一些基本工具方法,包括获取摄像头 ID、选择最优预览尺寸以及打印相机参数信息 二、Camera 工具类 CameraIdResult.java public class CameraIdResult {

stl的sort和手写快排的运行效率哪个比较高?

STL的sort必然要比你自己写的快排要快,因为你自己手写一个这么复杂的sort,那就太闲了。STL的sort是尽量让复杂度维持在O(N log N)的,因此就有了各种的Hybrid sort algorithm。 题主你提到的先quicksort到一定深度之后就转为heapsort,这种是introsort。 每种STL实现使用的算法各有不同,GNU Standard C++ Lib