0 / 0 / 0
Регистрация: 22.12.2022
Сообщений: 33
1

<error LNK2019: ссылка на неразрешенный внешний символ>- в чём причина ошибки?

31.07.2023, 22:00. Показов 457. Ответов 2

Author24 — интернет-сервис помощи студентам
Доброй ночи! подскажите пожалуйста, свежим взглядом, где мог ошибиться. Заранее благодарен!

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
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
#include <iostream>
#include <fstream>
#include <string>
 
 
using namespace std;
 
typedef uint8_t vect[4];
 
vect iter_key[32];
 
void
GOST_Magma_Expand_Key(const uint8_t* key);
 
void
GOST_Magma_Encrypt(const uint8_t* blk, uint8_t* out_blk);
 
void
GOST_Magma_Decrypt(const uint8_t* blk, uint8_t* out_blk);
 
static unsigned char Pi[8][16] =
{
    {12,4,6,2,10,5,11,9,14,8,13,7,0,3,15,1},
    {6,8,2,3,9,10,5,12,1,14,4,7,11,13,0,15},
    {11,3,5,8,2,15,10,13,14,1,7,4,12,9,6,0},
    {12,8,2,1,13,4,15,6,7,0,10,5,3,14,9,11},
    {7,15,5,10,8,1,6,13,0,9,3,14,11,4,2,12},
    {5,13,15,6,9,2,12,10,11,7,8,1,4,3,14,0},
    {8,14,2,5,6,9,1,12,15,4,11,0,13,10,3,7},
    {1,7,14,13,0,5,8,3,4,15,10,6,9,12,11,2}
};
 
static const unsigned char key[32] = 
{
    0xff, 0xfe, 0xfd, 0xfc,
    0xfb, 0xfa, 0xf9, 0xf8,
    0xf7, 0xf6, 0xf5, 0xf4,
    0xf3, 0xf2, 0xf1, 0xf0,
    0x00, 0x11, 0x22, 0x33,
    0x44, 0x55, 0x66, 0x77,
    0x88, 0x99, 0xaa, 0xbb,
    0xcc, 0xdd, 0xee, 0xff
};
 
int main(void)
{
    setlocale(LC_ALL, "ru");
 
    {
        string str;
 
        ifstream in("open.txt");
        if (in.is_open())
        {
            while (getline(in, str))
            {
                cout << "Данные из файла считаны: "; cout << str;
            }
        }
        in.close();
 
        const unsigned char* buffer = reinterpret_cast<const unsigned char*>(str.c_str());
 
        uint8_t out_blk[4];
        GOST_Magma_Expand_Key(key);
        GOST_Magma_Encrypt(buffer, out_blk);
        //GOST_Magma_Decrypt(decrypt_test_string, out_blk);
 
        cin.get();
        return 0;
    }
}
 
static void GOST_Magma_Blk_4_PrintDebug(uint8_t* state)
{
    int i;
    for (i = 0; i < 4; i++)
        cout << "%02x", state[i]; cout << endl;
}
 
static void GOST_Magma_Blk_8_PrintDebug(uint8_t* state)
{
    int i;
    for (i = 0; i < 8; i++)
        cout << "%02x", state[i]; cout << endl;
}
 
static void GOST_Magma_T(const uint8_t* in_data, uint8_t* out_data)
{
    uint8_t first_part_byte, sec_part_byte;
    int i;
    for (i = 0; i < 4; i++)
    {
        first_part_byte = (in_data[i] & 0x0f);
        sec_part_byte = (in_data[i] & 0xf0) >> 4;
        first_part_byte = Pi[i * 2][first_part_byte];
        sec_part_byte = Pi[i * 2 + 1][sec_part_byte];
        out_data[i] = (sec_part_byte << 4) | first_part_byte;
    }
}
 
static void GOST_Magma_Add(const uint8_t* a, const uint8_t* b, uint8_t* c)
{
    int i;
    for (i = 0; i < 4; i++)
        c[i] = a[i] ^ b[i];
}
 
static void GOST_Magma_Add_32(const uint8_t* a, const uint8_t* b, uint8_t* c)
{
    int i;
    unsigned int internal = 0;
    for (i = 0; i < 4; i++)
    {
        internal = a[i] + b[i] + (internal >> 8);
        c[i] = internal & 0xff;
    }
}
 
static void GOST_Magma_g(const uint8_t* k, const uint8_t* a, uint8_t* out_data)
{
    uint8_t internal[4];
    uint32_t out_data_32;
    GOST_Magma_Add_32(a, k, internal);
    GOST_Magma_T(internal, internal);
    out_data_32 = internal[3];
    out_data_32 = (out_data_32 << 8) + internal[2];
    out_data_32 = (out_data_32 << 8) + internal[1];
    out_data_32 = (out_data_32 << 8) + internal[0];
    out_data_32 = (out_data_32 << 11) | (out_data_32 >> 21);
    out_data[0] = out_data_32;
    out_data[1] = out_data_32 >> 8;
    out_data[2] = out_data_32 >> 16;
    out_data[3] = out_data_32 >> 24;
}
 
static void GOST_Magma_G(const uint8_t* k, const uint8_t* a, uint8_t* out_data)
{
    uint8_t a_0[4]{};
    uint8_t a_1[4]{};
    uint8_t G[4];
    int i;
    for (i = 0; i < 4; i++)
    {
        a_1[i] = a[4 + i];
        a_0[i] = a[i];
    }
    GOST_Magma_g(k, a_0, G);
    GOST_Magma_Add(a_1, G, G);
    for (i = 0; i < 4; i++)
    {
        a_1[i] = a_0[i];
        a_0[i] = G[i];
    }
    for (i = 0; i < 4; i++)
    {
        out_data[i] = a_0[i];
        out_data[4 + i] = a_1[i];
    }
 
}
 
static void GOST_Magma_G_Fin(const uint8_t* k, const uint8_t* a, uint8_t* out_data)
{
    uint8_t a_0[4]{};
    uint8_t a_1[4]{};
    uint8_t G[4];
    int i;
    for (i = 0; i < 4; i++)
    {
        a_1[i] = a[4 + i];
        a_0[i] = a[i];
    }
    GOST_Magma_g(k, a_0, G);
    GOST_Magma_Add(a_1, G, G);
    for (i = 0; i < 4; i++)
        a_1[i] = G[i];
    for (i = 0; i < 4; i++)
    {
        out_data[i] = a_0[i];
        out_data[4 + i] = a_1[i];
    }
}
 
void GOST_Magma_Expand_Key(const uint8_t* key)
{
    memcpy(iter_key[7], key, 4);
    memcpy(iter_key[6], key + 4, 4);
    memcpy(iter_key[5], key + 8, 4);
    memcpy(iter_key[4], key + 12, 4);
    memcpy(iter_key[3], key + 16, 4);
    memcpy(iter_key[2], key + 20, 4);
    memcpy(iter_key[1], key + 24, 4);
    memcpy(iter_key[0], key + 28, 4);
    memcpy(iter_key[15], key, 4);
    memcpy(iter_key[14], key + 4, 4);
    memcpy(iter_key[13], key + 8, 4);
    memcpy(iter_key[12], key + 12, 4);
    memcpy(iter_key[11], key + 16, 4);
    memcpy(iter_key[10], key + 20, 4);
    memcpy(iter_key[9], key + 24, 4);
    memcpy(iter_key[8], key + 28, 4);
    memcpy(iter_key[23], key, 4);
    memcpy(iter_key[22], key + 4, 4);
    memcpy(iter_key[21], key + 8, 4);
    memcpy(iter_key[20], key + 12, 4);
    memcpy(iter_key[19], key + 16, 4);
    memcpy(iter_key[18], key + 20, 4);
    memcpy(iter_key[17], key + 24, 4);
    memcpy(iter_key[16], key + 28, 4);
    memcpy(iter_key[31], key + 28, 4);
    memcpy(iter_key[30], key + 24, 4);
    memcpy(iter_key[29], key + 20, 4);
    memcpy(iter_key[28], key + 16, 4);
    memcpy(iter_key[27], key + 12, 4);
    memcpy(iter_key[26], key + 8, 4);
    memcpy(iter_key[25], key + 4, 4);
    memcpy(iter_key[24], key, 4);
 
    cout << "Итерационные ключи:\n";
    int i;
    for (i = 0; i < 32; i++)
    {
        printf("K%d=", i + 1);
        GOST_Magma_Blk_4_PrintDebug(iter_key[i]);
    }
}
 
void GOST_Magma_Encrypt(uint8_t* blk, uint8_t* out_blk)
{
    cout << "Текст для зашифрования: \n";
    GOST_Magma_Blk_8_PrintDebug(blk);
 
    int i;
    GOST_Magma_G(iter_key[0], blk, out_blk);
    for (i = 1; i < 31; i++)
        GOST_Magma_G(iter_key[i], out_blk, out_blk);
    GOST_Magma_G_Fin(iter_key[31], out_blk, out_blk);
 
    cout << "Зашифрованный текст:\n";
    GOST_Magma_Blk_8_PrintDebug(out_blk);
}
 
void GOST_Magma_Decrypt(uint8_t* blk, uint8_t* out_blk)
{
    cout << "Зашифрованный текст:\n";
    GOST_Magma_Blk_8_PrintDebug(blk);
 
    int i;
    GOST_Magma_G(iter_key[31], blk, out_blk);
    for (i = 30; i > 0; i--)
        GOST_Magma_G(iter_key[i], out_blk, out_blk);
    GOST_Magma_G_Fin(iter_key[0], out_blk, out_blk);
 
    cout << "Расшифрованный текст:\n";
    GOST_Magma_Blk_8_PrintDebug(out_blk);
}
Миниатюры
<error LNK2019: ссылка на неразрешенный внешний символ>- в чём причина ошибки?  
Вложения
Тип файла: txt open.txt (16 байт, 0 просмотров)
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
31.07.2023, 22:00
Ответы с готовыми решениями:

Найти причины и способы исправления ошибки "error LNK2019: ссылка на неразрешенный внешний символ"
Добрый день! Подскажите пожалуйста, писала программу. Но при компиляции выдает ошибку: error...

Error LNK2019 ссылка на неразрешенный внешний символ
Здравствуйте, дорогие форумчане :gsmile: Очень сильно нужна ваша помощь! не понимаю, почему...

error LNK2019: ссылка на неразрешенный внешний символ
Доброго времени суток. При написании курсового проекта в Microsoft Visual Studio 2010 возникла...

Error LNK2019: ссылка на неразрешенный внешний символ
Список ошибок Ошибка 1 error LNK2019: ссылка на неразрешенный внешний символ &quot;public: __thiscall...

error LNK2019: ссылка на неразрешенный внешний символ
есть исходник .cpp ---------------------------------------------------------------------...

2
0 / 0 / 0
Регистрация: 31.07.2023
Сообщений: 1
31.07.2023, 22:11 2
187 | memcpy(iter_key[7], key, 4);
| ^~~~~~
0
шКодер самоучка
2227 / 1921 / 927
Регистрация: 09.10.2013
Сообщений: 4,259
Записей в блоге: 7
31.07.2023, 22:37 3
Лучший ответ Сообщение было отмечено Tessay как решение

Решение

Имплементация void GOST_Magma_Encrypt(uint8_t* blk, uint8_t* out_blk)
Отличается от декларации void GOST_Magma_Encrypt(const uint8_t* blk, uint8_t* out_blk);
По типу параметров.
2
31.07.2023, 22:37
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
31.07.2023, 22:37
Помогаю со студенческими работами здесь

Error LNK2019: ссылка на неразрешенный внешний символ
Всем доброго времени суток. Помогите пожалуйста разобраться с проблемой. Честно просматривал форму,...

Error LNK2019: ссылка на неразрешенный внешний символ
Person.obj : error LNK2019: ссылка на неразрешенный внешний символ &quot;public: __thiscall...

error LNK2019: ссылка на неразрешенный внешний символ
A.h #pragma once #include &lt;vector&gt; #include &lt;iostream&gt; template&lt;class B, class C&gt; class A {...

Error LNK2019: ссылка на неразрешенный внешний символ
Здравствуйте, пишу небольшую консольную игру для саморазвития. Вроде бы не успел толком начать, но...

Error LNK2019: ссылка на неразрешенный внешний символ
умелые люди помогите исправить ошибку, сегодня надо сдать класс, подправил и упростил код unrar'a...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

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