Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
0 / 0 / 0
Регистрация: 10.02.2018
Сообщений: 1
1

Шифратор base64

10.02.2018, 14:52. Показов 1411. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
пожалста с шифратором что то не так base64. вот код
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
#include "stdafx.h"
#include <iostream>
#include <math.h>
#include <fstream>
 
 
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "rus");
    system("title шифратор");
 
    ifstream f1;
    ofstream fo;
 
    char s;
 
    int hf;
    int l = 0;
    int choice;
 
    int *arr;
 
 
    const int r = 33;
 
    unsigned char rus_st[] = "абвгдеёжзийклмнопрстуфхцчшщъыьэюя";
    unsigned char rus_zg[] = "АБВГДЕЁЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯ";
    unsigned char ang[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
    unsigned char ang_st[] = "abcdefghijklmnopqrstuvwxyz";
 
    unsigned char *mass1;
 
    cout << "Шифровать - 1" << endl;
    cout << "Дешифровать - 0" << endl;
    cin >> choice;
    system("cls");
 
    int *uier;
    int *uier1;
    int uu = 0;
    uier = new int[l * 8];
 
    if (choice == 1) {
        system("cls");
        cout << "Двоичный код" << "\t" << "Код Asci" << "\t" << "Символ" << endl;
        f1.open("input.txt");
        while (!f1.eof()) {
            f1.get(s);
            if (!f1.eof()) {
                l++;
            }
        }
        f1.close();
        mass1 = new unsigned char[l];
        f1.open("input.txt");
        for (int i = 0; i < l; i++) {
            f1.get(s);
            if (!f1.eof()) {
                mass1[i] = s;
            }
        }
        f1.close();
 
        int ng;
        int count = 8;
        for (int i = 0; i < l; i++) {
            ng = (int)mass1[i];
            arr = new int[count];
            for (int i = 0; i < count; i++) {
                arr[i] = ng % 2;
                ng /= 2;
            }
            for (int i = count - 1; i > 0 - 1; --i) {
                cout << arr[i];
                uier[uu] = arr[i];
                uu++;
            }
            cout << "\t" << (int)mass1[i] << "\t\t" << mass1[i] << endl;
        }
 
        if (uu % 6 != 0) { hf = 6 - uu % 6; uu += 6 - uu % 6; }
        uier1 = new int[uu];
        int tyu = 0;
        for (int i = 0; i < uu; i++) {
            uier1[i] = 0;
            if (tyu < l * 8) {
                uier1[i] = uier[tyu];
                tyu++;
            }
        }
 
        cout << endl;
        int oi = 0;
        for (int i = 0; i < uu; i++) {
            if (oi < 6) cout << uier1[i];
            else { oi = 0; cout << endl << uier1[i]; }
            oi++;
        }
        cout << endl;
 
        arr = new int[uu / 6];
        for (int i = 0; i < uu / 6; i++) arr[i] = 0;
        int count12 = 0;
        int st3 = 5;
 
        for (int i = 0; i < uu; i++) {
            if (i % 6 == 0 && i != 0) {
                count12++;
                st3 = 5;
                cout << endl;
            }
            arr[count12] += (int)(uier1[i] * pow(2, st3));
            cout << arr[count12] << "\t";
            st3--;
        }cout << endl;
 
 
        fo.open("input.txt");
        for (int i = 0; i < uu / 6; i++) {
            cout << ang[arr[i]];
            fo << ang[(int)arr[i]];
        }
        fo.close();
 
        cout << "\n\nШифрование завершено..\n\n";
 
    }
 
    system("pause");
    return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
10.02.2018, 14:52
Ответы с готовыми решениями:

Шифратор-дешифратор
Задача реализовать подстановочный шифр, зашифровать произвольное сообщение, а потом дешифровать...

Шифратор и дешифратор
Помогите пожалуйста написать программу, которая зашифровывает файл и расшифровывает, заранее...

XOR Шифратор
Сделал шифратор на основе XOR’а, но если ввести пробел в сообщении которое надо зашифровать,...

Простой шифратор
Задача такая: пользователь вводит четырехзначное число, после этого программа отображает это число...

2
603 / 403 / 212
Регистрация: 30.04.2017
Сообщений: 743
10.02.2018, 15:43 2
root_max,
Цитата Сообщение от root_max Посмотреть сообщение
uier = new int[l * 8];
Выделяется кусок памяти с нулевым размером в строке 43. Выделяйте память после того как подсчитали элементы, например в строке 65 перед тем как использовать массив. Удивительно, но программа после этой манипуляции работает.
Неплохо было бы оформить код для получения данных, их записи, кодирования и декодирования в отдельные функции.
+Использовать vector для хранения полученных данных вместо динамического массива.
0
║XLR8║
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,361
Записей в блоге: 5
10.02.2018, 21:05 3
root_max, https://github.com/ReneNyffenegger/cpp-base64 можешь посмотреть как люди делают
0
10.02.2018, 21:05
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
10.02.2018, 21:05
Помогаю со студенческими работами здесь

Написать шифратор\дешифратор на С++
Напишите программу, выполняющую следующие действия (в начале программы выводится запрос о том,...

Шифратор методом виженера
Помогите пожалуйста срочно написать программу, на тему шифратор и дешифратор методом виженера на...

Как написать шифратор?
Нужна программа, которая в РУССКОМ тексте заменяет буквы на другие символы. Например: буква &quot;Н&quot; -...

base64
дай пожалуйста рабочий код кодировщика и декодировщика askii &lt; - &gt; base64


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru