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

криптография. метод шифрования- Алгебраические методы (матрица*вектор_столбец), объект-пароли в файле паролей

28.11.2013, 17:16. Показов 1564. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
помогите плиз. есть сам метод, как с паролями сделать его не понимаю... программирования толком не было, а задание дали((
вот метод

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
int N = 3;
double round(double d)
{
   double id = int(d);
   return (d<0) ? ((id - d < 0.5) ? id : id-1) : ((d - id < 0.5) ? id : id+1);
}
AnsiString code(AnsiString text)
{
    int i,j=1,m,k,jj;
    double buf1,buf2;
    AnsiString cod;
//---------------------------------------------------------------------------
    double **KEY=new double *[N];
    for(i=0;i<N;i++)
        KEY[i]=new double [N];
    for(i=0;i<N;i++)
        for(j=0;j<N;j++)
            KEY[i][j]=StrToFloat(Form1->StringGrid1->Cells[j][i]);
//---------------------------------------------------------------------------
    if(text.Length()<N)
   {
        for(i=0;i<=(N-text.Length());i++)
        text+=" ";
   }
    if((text.Length()%N)!=0)
   {
        for(i=0;i<=(text.Length()%N);i++)
        text+=" ";
   }
//---------------------------------------------------------------------------
    i=0;m=1;k=1;jj=0;j=0;
    //шифрование текста
    buf2=0;
    buf1=0;
    while(i<text.Length())
    {
        buf2=text[m]+128;
        buf1+=KEY[jj][j]*buf2;
        jj++;m++;
        if(jj==N)
            {jj=0;m=k;i++;cod+=FloatToStr(buf1)+' ';buf1=0;j++;
            if(j==N)
                {j=0;k=i;m=k;}}
    }
return cod;
}
AnsiString decode(AnsiString text)
{
int i,j,m,n,k,jj;double buf1;
AnsiString name,mes,cod,buf;
bool tx=false;
double **KEY=new double *[N];
    for(i=0;i<N;i++)
        KEY[i]=new double [N];
for(i=0;i<N;i++)
    for(j=0;j<N;j++)
        KEY[i][j]=StrToFloat(Form1->StringGrid1->Cells[i][j]);
//---------------------------------------------------------------------------
for(i=0;i<text.Length();i++)
{
    if(text[i]==':'&&text[i+1]==' ')
        {name+=text[i];name+=" ";tx=true;i+=2;}
    if(tx)
    {
        mes+=text[i];
    }
    else name+=text[i];
}
//---------------------------------------------------------------------------
m=0;
for(i=1;i<text.Length();i++)
{
 if(mes[i]==' ') m++;
}
double *MES=new double [m];
cod.SetLength(m);
m=0;
for(i=1;i<=mes.Length();i++)
{
 if(mes[i]==' ')
    {MES[m]=StrToFloat(buf);m++;buf.SetLength(0);}
 else
    buf+=mes[i];
}
 
//---------------------------------------------------------------------------
double **L=new double *[N];
    for(i=0;i<N;i++)
        L[i]=new double [N];
    for (i=0; i<N; i++)
        for (j=0; j<N; j++)
            if (i!=j)
                L[i][j]=0;
            else L[i][j]=1;
 
 j = 0;
 
do
  { // Выбор ведущего элемента ниже элемента [j,j-1]:
    m = j;
    for (n=j+1; n<N; n++)
      if (fabs(KEY[m][j])<fabs(KEY[n][j])) m = n;
    double prm=0;
 
 
    //Переобразования над матрицой:
    for (n=0; n<N; n++)
    { prm = KEY[m][n];
      KEY[m][n] = KEY[j][n];
      KEY[j][n] = prm;
      prm = KEY[m][n];
      KEY[m][n] = KEY[j][n];
      KEY[j][n] = prm;
    }
 
    prm = KEY[j][j];
    for (n=0; n<N; n++)
    { KEY[j][n] = double (KEY[j][n]/prm);
      L[j][n] = double (L[j][n]/prm);
    }
    for (i=0; i<N; i++)
      if (i!=j)
      { prm = KEY[i][j];
    for (n=j; n<N; n++) KEY[i][n] = KEY[i][n]- double (prm*KEY[j][n]);
    for (n=0; n<N; n++) L[i][n] =L[i][n]- double (prm*L[j][n]);
      }
    j++;
    }
  while (j<N);
 
  /*for (i=0;i<N;i++)
  for (j=0;j<N;j++)
  L[i][j]=round(L[i][j]);*/
  for(i=0;i<N;i++)
  for(j=0;j<N;j++)
  Form1->StringGrid2->Cells[i][j]=FloatToStr(L[i][j]);
 
 
    for(i=1;i<=cod.Length();i++)
    cod[i]=0;
    i=1;m=0;k=0;jj=0;j=0;
    buf1=0;
    //расшифрование текста
    while(i<=cod.Length())
    {
     buf1+=L[jj][j]*MES[m];
     jj++;m++;
     if(jj==N)
     {jj=0;m=k;cod[i]=(round(buf1)-128);buf1=0;i++;j++;
      if(j==N)
       {j=0;k=i-1;m=k;}}
    }
 
 
delete KEY;
delete L;
delete MES;
return name+cod;
}
bool test()
{
int i,j,n,m,k;
double max,f,s;
 
for(i=0;i<N;i++)
    for(j=0;j<N;j++)
        if (Form1->StringGrid1->Cells[j][i].Length()==0) {ShowMessage("Ошибка обработки матрицы");return false;}
 
double **KEY=new double *[N];
    for(i=0;i<N;i++)
        KEY[i]=new double [N];
        //double KEY[3][3];
for(i=0;i<N;i++)
    for(j=0;j<N;j++)
        KEY[i][j]=StrToFloat(Form1->StringGrid1->Cells[j][i]);
 
 for (n=0;n<N;n++) //прямой ход Гаусса, приведение матрицы коэффициентов к треугольному виду
     {
       for (m=n+1;m<N;m++)
          {
 
             max=KEY[n][n];i=n;
             for (k=n;k<N;k++)
              {
                if (KEY[n][k]>max) {max=KEY[n][k];i=k;}
              }
 
              if ((max!=0)&&(i!=n))
               {
               for (k=0;k<N;k++)
                {
                 f=KEY[k][i];
                 KEY[k][i]=KEY[k][n];
                 KEY[k][n]=f;
                }
               }
 
 
          if(KEY[n][n]!=0)
          {s=KEY[m][n]/KEY[n][n];}
          else
          {ShowMessage("Ошибка обработки матрицы");return false;}
 
            for (k=n;k<N;k++)
               {
                 f=KEY[m][k]-(s*KEY[n][k]);
                 if ((f<0.0000001)&&(f>0))f=0;
                 KEY[m][k]=f;
               }
          }
     }
     s=KEY[0][0];
     for(i=1;i<N;i++)
     {
      s=s*KEY[i][i];
     }
     if(s==0){ShowMessage("Ошибка обработки матрицы");return false;}
     else
     delete KEY;
     return true;
 
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.11.2013, 17:16
Ответы с готовыми решениями:

Криптография метод шифрования Triple-DES
Может кто-нибудь объяснить на подобном языке с примером шифровки (входные данные и исходные) как происходит шифровка, читал MSDN, плохо...

Метод Шифрования Паролей Notepad++
Всем Доброго времени суток. Думаю, многим известен текстовый редактор NotePad++. А так же один из его модулей NppFTP думаю, так же не...

Криптография: как и можно ли поменять ключ шифрования
Стандартная функция шифрования: public string encrypt(string encryptionString) { byte clearTextBytes =...

7
 Аватар для Kulgar
511 / 196 / 26
Регистрация: 07.08.2013
Сообщений: 814
29.11.2013, 09:44
Asya_1, а теперь ещё раз и по-русски. В чём помочь?
0
0 / 0 / 0
Регистрация: 28.11.2013
Сообщений: 5
29.11.2013, 16:35  [ТС]
у меня есть в бд поле с паролями(числа), с помощью этого метода их зашифровать и дешифровать нужно в бд..
нужно помочь именно с шифрованием паролей (делаю в С++ Builder 2006). Я не знаю как правильно написать это в обаботчике кнопок
0
 Аватар для Kulgar
511 / 196 / 26
Регистрация: 07.08.2013
Сообщений: 814
29.11.2013, 16:37
Цитата Сообщение от Asya_1 Посмотреть сообщение
нужно помочь именно с шифрованием паролей
С какой сложностью Вы столкнулись?
0
0 / 0 / 0
Регистрация: 28.11.2013
Сообщений: 5
29.11.2013, 23:13  [ТС]
знаю как написать это, т.к. не сильна в программировании
0
91 / 91 / 22
Регистрация: 02.07.2013
Сообщений: 332
30.11.2013, 15:30
Asya_1, по-моему, в приведённом коде есть достаточно "говорящие" функции code и decode. Осталось только дать им то, что нужно, и получить искомое...
0
0 / 0 / 0
Регистрация: 28.11.2013
Сообщений: 5
30.11.2013, 15:36  [ТС]
я написала, что у меня неправильно шифруется, а не понимаю где ошибка в методе!
0
 Аватар для Kulgar
511 / 196 / 26
Регистрация: 07.08.2013
Сообщений: 814
02.12.2013, 10:44
Asya_1, Вы бы хоть мельком описали логику своей программы. Не понятно какие данные надо вводить в StringGrid1.
В какой версии компилятора Вы работаете?
Приведите весь проект.
Полностью задание своё тоже.

Не по теме:

Цитата Сообщение от Asya_1 Посмотреть сообщение
программирования толком не было
=-O Однако... в коде присутствуют двумерные динамические массивы, пользовательские функции и ещё программная реализация "прямой ход Гаусса, приведение матрицы коэффициентов к треугольному виду". Без опыта программирования писать такой код - респект и уважуха, чо. :bravo::good:

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.12.2013, 10:44
Помогаю со студенческими работами здесь

Криптография: приведите пример шифрования алгоритма Serpent
Приведите пожалуйста пример шифрования алгоритма Serpent

Как получить пароли на соединения в Win2000/XP, или почему вместо паролей показываются звездочки?
Народ! Нужно получить кэшируемые пароли на соединения в Windows 2000/XP, и я даже знаю как это сделать: #include &lt;windows.h&gt; ...

Средства для шифрования паролей
Я храню в базе пароли пользователей, пока в открытом виде. Какие лучше использовать средства их шифрования? Есть ли для этого...

Найти алгебраические дополнения. Треугольная матрица
Дан StringGrid который может быть как 3х3 так 4х4, я его могу заполнить руками или рандомно(это всё есть, я делаю проэкт по решению СЛАУ...

Принципы шифрования данных и применения системы паролей
вопрос не совсем по билдеру, в билдере просто пишу, вопрос по оформлению скажем так... я пишу небольшую базу данных (курсач), данные...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru