-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbase64_alternative.c
137 lines (118 loc) · 4.82 KB
/
base64_alternative.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
// Base64 คืออะไร ช่วยพี่โบ๊ทด้วย!!
// Base64 คือ วิธีการเข้ารหัสข้อมูลรูปแบบหนึ่ง ที่จะเปลี่ยนข้อความ หรือข้อมูลต้นฉบับไปเป็นข้อความ
// หรือข้อมูลชุดใหม่ ที่ไม่สามารถอ่าน หรือรู้ว่าข้อมูลชุดนี้คืออะไร ซึ่งการเข้ารหัสชนิดนี้จะแทนที่ข้อมูลด้วยตัวอักษร 64 ตัว
// นั่นคือที่มาของ BASE64 ซึ่่งวิธีการถอดรหัสด้วยตนเองนั้นค่อนข้างจะซับซ้อน คิอ จะทําย้อนกลับโดยให้นําข้อมูลมาแปลงเป็นฐานสอง 6 bit มาเรียงต่อกันก่อน
// แล้วนํามาจัดกลุ่ม กลุ่มละ 8 bit โดย bit สุดท้ายที่เหลือไม่ครบ 8 bit ให้ตัดทิ้ง หลังจากนั้นก็แปลงเลขฐานสอง 8 bit แต่ละชุดเป็นข้อมูล ASCII
// โดยในข้อนี้มีอยากให้น้องช่วยพี่โบ๊ทในการเขียนโปรแกรมเพื่อเข้ารหัส Base64 เพราะว่าพี่โบ๊ทไม่ไหวแล้วววววววว โดยน้องๆสามารถศึกษาเพิ่มเติมได้จาก link ที่พี่ใส่ไว้ใน
// เพิ่มเติมเลยครับ
// https://thiti.dev/blog/5979
#include <stdio.h>
#include <string.h>
#include <math.h>
int int_to_bit(int k)
{
return (k == 0 || k == 1 ? k : ((k % 2) + 10 * int_to_bit(k / 2)));
}
char bit_to_base64_char(char bit[7])
{
int number = 0;
for (int i = 5; i >= 0; i--)
{
if (bit[i] == '1')
{
number += pow(2, 5 - i);
}
}
if (number >= 0 && number <= 25)
{
number += 65;
}
if (number >= 26 && number <= 51)
{
number += 71;
}
if (number >= 52 && number <= 61)
{
number -= 4;
}
if (number == 62)
{
number = 43;
}
if (number == 63)
{
number = 47;
}
char base64_char = (char)number;
return base64_char;
}
int main()
{
char str[100];
scanf("%[^\n]s", &str);
int bit[100];
for (int i = 0; i < strlen(str); i++)
{
bit[i] = int_to_bit((int)str[i]);
}
char all_bit[1000];
int last_all_bit_spot = 0;
char old_remainder[7] = {'0', '0', '0', '0', '0', '0', '\0'};
int old_remainder_number = 0;
int six_bit_number = 6;
int remainder = 2;
for (int i = 0; i < strlen(str); i++)
{
char bit_char[9] = {'0', '0', '0', '0', '0', '0', '0', '0', '\0'};
int changing_digit = 7;
while (bit[i] != 0)
{
if (bit[i] % 10 == 1)
{
bit_char[changing_digit] = '1';
}
bit[i] /= 10;
changing_digit--;
}
char base64_bit[7] = {'0', '0', '0', '0', '0', '0', '\0'};
int position = 0;
for (int i = 0; i < old_remainder_number; i++)
{
base64_bit[position] = old_remainder[i];
position++;
}
for (int i = 0; i < six_bit_number; i++)
{
base64_bit[position] = bit_char[i];
position++;
}
for (int i = 0; i < remainder; i++)
{
old_remainder[i] = bit_char[six_bit_number + i];
}
// printf("%s\n", base64_bit);
printf("%c", bit_to_base64_char(base64_bit));
if (remainder == 6)
{
printf("%c", bit_to_base64_char(old_remainder));
// printf("%s\n", old_remainder);
}
if (i == strlen(str) - 1 && remainder != 6)
{
char base64_bit[7] = {'0', '0', '0', '0', '0', '0', '\0'};
for (int i = 0; i < remainder; i++)
{
base64_bit[i] = old_remainder[i];
}
printf("%c", bit_to_base64_char(old_remainder));
for (int i = 0; i < (6 - remainder) / 2; i++)
{
printf("=");
}
}
old_remainder_number = old_remainder_number + 2 > 4 ? 0 : old_remainder_number + 2;
six_bit_number = six_bit_number - 2 < 2 ? 6 : six_bit_number - 2;
remainder = remainder + 2 > 6 ? 2 : remainder + 2;
}
return 0;
}