Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
3 / 3 / 0
Регистрация: 23.09.2012
Сообщений: 27
1

Шифрование Эль-Гамаля для клиент-сервера. Исправить код

29.09.2012, 15:27. Показов 975. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Написал программки: Сервер и 2 клиента. Хочу сделать шифрование с помощью метода Эль Гамаля. Но ничего не получается, ключи получаются очень большие и шифрование не получается. Может я что то не так делаю(((
Может кто помочь:
Алиса:
Кликните здесь для просмотра всего текста
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
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Net;
using System.Net.Sockets;
using System.Threading;
 
namespace Client
{
    public partial class From1 : Form
    {
        /*private delegate void Connection();
        private delegate void Send();
 
        string IPser = "192.168.1.102";
        string IPcli = "192.168.1.101";
        string Port = "11000";
        Socket socketClient;
        Socket socketServer;
        Socket client;
        EndPoint endClient;
        byte[] bufferClient;
        EndPoint endServer;
        byte[] bufferServer;
        bool flag; //если true, то клиент*/
        public static int[] primesNumber = {
          2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97,
          101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199,
      211, 223, 227, 229, 233, 239, 241, 251, 257, 263, 269, 271, 277, 281, 283, 293,
      307, 311, 313, 317, 331, 337, 347, 349, 353, 359, 367, 373, 379, 383, 389, 397,
      401, 409, 419, 421, 431, 433, 439, 443, 449, 457, 461, 463, 467, 479, 487, 491, 499,
      503, 509, 521, 523, 541, 547, 557, 563, 569, 571, 577, 587, 593, 599,
      601, 607, 613, 617, 619, 631, 641, 643, 647, 653, 659, 661, 673, 677, 683, 691,
      701, 709, 719, 727, 733, 739, 743, 751, 757, 761, 769, 773, 787, 797,
      809, 811, 821, 823, 827, 829, 839, 853, 857, 859, 863, 877, 881, 883, 887,
      907, 911, 919, 929, 937, 941, 947, 953, 967, 971, 977, 983, 991, 997,
      1009, 1013, 1019, 1021, 1031, 1033, 1039, 1049, 1051, 1061, 1063, 1069, 1087, 1091, 1093, 1097,
      1103, 1109, 1117, 1123, 1129, 1151, 1153, 1163, 1171, 1181, 1187, 1193,
      1201, 1213, 1217, 1223, 1229, 1231, 1237, 1249, 1259, 1277, 1279, 1283, 1289, 1291, 1297,
      1301, 1303, 1307, 1319, 1321, 1327, 1361, 1367, 1373, 1381, 1399,
      1409, 1423, 1427, 1429, 1433, 1439, 1447, 1451, 1453, 1459, 1471, 1481, 1483, 1487, 1489, 1493, 1499,
      1511, 1523, 1531, 1543, 1549, 1553, 1559, 1567, 1571, 1579, 1583, 1597,
      1601, 1607, 1609, 1613, 1619, 1621, 1627, 1637, 1657, 1663, 1667, 1669, 1693, 1697, 1699,
      1709, 1721, 1723, 1733, 1741, 1747, 1753, 1759, 1777, 1783, 1787, 1789,
      1801, 1811, 1823, 1831, 1847, 1861, 1867, 1871, 1873, 1877, 1879, 1889,
      1901, 1907, 1913, 1931, 1933, 1949, 1951, 1973, 1979, 1987, 1993, 1997, 1999, 
      2003, 2011, 2017, 2027, 2029, 2039, 2053};
 
        private delegate void Send();
        TcpListener server = null;
        Int32 portB = 8080;
        TcpClient bobClient;
        IPAddress ipAddrBob;
        NetworkStream bobStream;
        
        long pA; long gA; long xA; long yA;
        long xB; long aA = 0; long bA = 0;
        long aB; long bB; long lsKey;
 
        public From1()
        {
            InitializeComponent();
            System.Windows.Forms.Control.CheckForIllegalCrossThreadCalls = false;
        }
 
        private void From1_Load(object sender, EventArgs e)
        {
            /*socketClient = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
            IPAddress ipClient = IPAddress.Parse(IPser);
            IPEndPoint ipeClient = new IPEndPoint(ipClient, int.Parse(Port));
            endClient = (EndPoint)ipeClient;
 
            try
            {
                socketClient.Connect(ipeClient);
                flag = true;
                label1.Text = "Соединение с сервером установлено!";
            }
            catch
            {
                try
                {
                    socketServer = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
                    IPAddress ipServer = IPAddress.Any;
                    IPEndPoint ipeServer = new IPEndPoint(ipServer, int.Parse(Port));
                    endServer = (EndPoint)ipeServer;
                    socketServer.Bind(ipeServer);
                    socketServer.Listen(1);
                    flag = false;
                    new Connection(delegate() { ConnectServer(); }).BeginInvoke(null, null);
                }
                catch
                {
                    MessageBox.Show("Проблемы с установкой соединения.\nПриложение будет закрыто.", "Ошибка",
                        MessageBoxButtons.OK, MessageBoxIcon.Error);
                }
            }*/
        }
        private void button3_Click(object sender, EventArgs e)
        {
            textBox1.Text = String.Empty;
            try
            {
                //ConnectToServer();
            }
            catch //(SocketException se)
            {
                //newClient.Close();
                //tcpStream.Close();
                //MessageBox.Show("Exception:\n" + se);
            }
            label1.Text = "Соединение с сервером установлено!";
        }
        private void ConnectToServer()
        {
            /*try
            {
                label1.Text = "Соединение с сервером устанавливается. . .";
                Int32 port = 8080;
                ipAddrClient = IPAddress.Parse("192.168.1.100");
                newClient.Connect(ipAddrClient, port);
                tcpStream = newClient.GetStream();
                label1.Text = "Соединение с сервером установлено!";
                //new Send(delegate() { while (true) ReceiveMessege(); }).BeginInvoke(null, null);
            }
            catch (Exception ex)
            {
                MessageBox.Show("Error: \n" + ex);
            }*/
            /*finally
            {
                newClient.Close();
                tcpStream.Close();
            }*/
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
            try
            {
                Int32 port = 8080;
                TcpClient newClient = new TcpClient();
                IPAddress ipAddrClient = IPAddress.Parse("192.168.1.100");
                newClient.Connect(ipAddrClient, port);
                NetworkStream tcpStream = newClient.GetStream();
 
                Random ran = new Random();
                pA = primesNumber[ran.Next(1, 20)];
                int n;
                while (true) if ((n = ran.Next(1, (int)pA)) > 1 && n < pA) { gA = n; break; }
                while (true) if ((n = ran.Next(1, (int)pA)) > 1 && n < pA) { xA = n; break; }
                //pA = 11; gA = 2; xA = 8; //yA = (long)Math.Pow(gA, xA) % pA;
                long temp = gA;
                for (int i = 1; i < xA; i++)
                {
                    temp = (temp * gA) % pA;
                }
                yA = temp;
 
                String masKey = String.Empty;
                masKey += "a" + pA.ToString(); masKey += "." + gA.ToString(); masKey += "." + yA.ToString();
                byte[] buffer = new byte[masKey.Length];
                buffer = Encoding.ASCII.GetBytes(masKey);
                tcpStream.Write(buffer, 0, buffer.Length);
 
                newClient.Close();
                tcpStream.Close();
            }
            catch
            {
                //newClient.Close();
                //tcpStream.Close();
            }
        }
 
        private void button2_Click(object sender, EventArgs e)
        {
            /*socketServer.Shutdown(SocketShutdown.Both);
            socketClient.Close();
            Application.Exit();*/
        }
 
        private void button2_Click_1(object sender, EventArgs e)
        {
            richTextBox1.Text = String.Empty;
            textBox1.Text = String.Empty;
        }
 
        private void button5_Click(object sender, EventArgs e)
        {
            try
            {
                SendMessage();
            }
            catch (InvalidOperationException io)
            {
                MessageBox.Show("Exception:\n" + io);
                Application.Exit();
            }
        }
 
        private void button4_Click(object sender, EventArgs e)
        {
            
            bobClient = new TcpClient();
            ipAddrBob = IPAddress.Parse("192.168.1.102");
            bobClient.Connect(ipAddrBob, portB);
            bobStream = bobClient.GetStream();
 
            String str = aB.ToString() + "." + bB.ToString();
            byte[] buffer = new byte[str.Length];
            buffer = Encoding.ASCII.GetBytes(str);
            bobStream.Write(buffer, 0, buffer.Length);
 
            new Send(delegate() { while (true) ReceiveMessege(); }).BeginInvoke(null, null);
            //bobClient.Close();
            //bobStream.Close();
        }
 
        private void button6_Click(object sender, EventArgs e)
        {
            Int32 port = 8080;
            TcpClient newClient = new TcpClient();
            IPAddress ipAddrClient = IPAddress.Parse("192.168.1.100");
            newClient.Connect(ipAddrClient, port);
            NetworkStream tcpStream = newClient.GetStream();
 
            byte[] buffer = new byte[256];
            buffer = Encoding.ASCII.GetBytes("s");
            tcpStream.Write(buffer, 0, buffer.Length);
 
            tcpStream.Read(buffer, 0, buffer.Length);
            String str = Encoding.ASCII.GetString(buffer);
 
            int j = 0;
            String[] sKey = new String[4]; 
            
            for (int i = 0; i < buffer.Length; i++)
            {
                if (str[i] != '.' && str[i] != '\0') sKey[j] += str[i];
                else
                {
                    if (j == 0) aA = (long)Convert.ToInt32(sKey[j]);
                    if (j == 1) bA = (long)Convert.ToInt32(sKey[j]);
                    if (j == 2) aB = (long)Convert.ToInt32(sKey[j]);
                    if (j == 3) bB = (long)Convert.ToInt32(sKey[j]);
                    j++;
                    if (str[i] == '\0') break;
                }
            }
            long temp = aA;
            for (int i = 1; i < pA - 1 - xA; i++)
            {
                temp = (temp * aA) % pA;
            }
            aA = temp;
            long M = lsKey = (bA * aA) % pA;
            richTextBox1.Text = M.ToString();
 
            newClient.Close();
            tcpStream.Close();
        }
 
 
        private void SendMessage()
        {
            long num = Convert.ToInt32(textBox1.Text);
 
            long temp = gA;
            for (int i = 1; i < lsKey; i++)
            {
                temp = (temp * gA) % pA;
            }
            this.aB = temp;
 
            temp = yA;
            for (int i = 1; i < lsKey; i++)
            {
                temp = (temp * yA);
            }
            this.bB = temp;
            this.bB = (this.bB * num) % pA;
 
            String result = aB.ToString() + "." + bB.ToString();
            byte[] buffer = Encoding.ASCII.GetBytes(result);
            bobStream.Write(buffer, 0, buffer.Length);
            richTextBox1.Text += textBox1.Text + " \n";
            textBox1.Text = "";
        }
 
        //Функция получаем сообщения
        private void ReceiveMessege()
        {
            try
            {
                byte[] buffer = new byte[bobClient.ReceiveBufferSize];
                int bytesRead = bobStream.Read(buffer, 0, bobClient.ReceiveBufferSize);
                if (bytesRead != 0)
                {
                    String str = Encoding.ASCII.GetString(buffer);
 
                    int j = 0;
                    String[] sKey = new String[2];
 
                    for (int i = 0; i < buffer.Length; i++)
                    {
                        if (str[i] != '.' && str[i] != '\0') sKey[j] += str[i];
                        else
                        {
                            if (j == 0) aA = (long)Convert.ToInt32(sKey[j]);
                            if (j == 1) bA = (long)Convert.ToInt32(sKey[j]);
                            j++;
                            if (str[i] == '\0') break;
                        }
                    }
 
                    long temp = aA;
                    for (int i = 1; i < pA - 1 - xA; i++)
                    {
                        temp = (temp * aA) % pA;
                    }
                    aA = temp;
                    long M = (bA * aA) % pA;
                    richTextBox1.Text += "-  " + M.ToString() + "  ||\n";
                }
                else
                {
                    //newClient.Client.Shutdown();
                    label1.Text = "Соединение с клиентом разорвано. . .";
                }
            }
            catch
            {
            }
        }
    }
}

Боб:
Кликните здесь для просмотра всего текста
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
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Net;
using System.Net.Sockets;
using System.Threading;
 
namespace ClientBob
{
    public partial class Form1 : Form
    {
        public static int[] primesNumber = {
          2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97,
          101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199,
      211, 223, 227, 229, 233, 239, 241, 251, 257, 263, 269, 271, 277, 281, 283, 293,
      307, 311, 313, 317, 331, 337, 347, 349, 353, 359, 367, 373, 379, 383, 389, 397,
      401, 409, 419, 421, 431, 433, 439, 443, 449, 457, 461, 463, 467, 479, 487, 491, 499,
      503, 509, 521, 523, 541, 547, 557, 563, 569, 571, 577, 587, 593, 599,
      601, 607, 613, 617, 619, 631, 641, 643, 647, 653, 659, 661, 673, 677, 683, 691,
      701, 709, 719, 727, 733, 739, 743, 751, 757, 761, 769, 773, 787, 797,
      809, 811, 821, 823, 827, 829, 839, 853, 857, 859, 863, 877, 881, 883, 887,
      907, 911, 919, 929, 937, 941, 947, 953, 967, 971, 977, 983, 991, 997,
      1009, 1013, 1019, 1021, 1031, 1033, 1039, 1049, 1051, 1061, 1063, 1069, 1087, 1091, 1093, 1097,
      1103, 1109, 1117, 1123, 1129, 1151, 1153, 1163, 1171, 1181, 1187, 1193,
      1201, 1213, 1217, 1223, 1229, 1231, 1237, 1249, 1259, 1277, 1279, 1283, 1289, 1291, 1297,
      1301, 1303, 1307, 1319, 1321, 1327, 1361, 1367, 1373, 1381, 1399,
      1409, 1423, 1427, 1429, 1433, 1439, 1447, 1451, 1453, 1459, 1471, 1481, 1483, 1487, 1489, 1493, 1499,
      1511, 1523, 1531, 1543, 1549, 1553, 1559, 1567, 1571, 1579, 1583, 1597,
      1601, 1607, 1609, 1613, 1619, 1621, 1627, 1637, 1657, 1663, 1667, 1669, 1693, 1697, 1699,
      1709, 1721, 1723, 1733, 1741, 1747, 1753, 1759, 1777, 1783, 1787, 1789,
      1801, 1811, 1823, 1831, 1847, 1861, 1867, 1871, 1873, 1877, 1879, 1889,
      1901, 1907, 1913, 1931, 1933, 1949, 1951, 1973, 1979, 1987, 1993, 1997, 1999, 
      2003, 2011, 2017, 2027, 2029, 2039, 2053};
 
        TcpListener server = null;
        IPAddress ipAddrServer;
        TcpClient alClient = new TcpClient();
        NetworkStream alStreamAlisa;
        private delegate void Send();
        long pB; long gB; long xB; long yB;
        long aB = 0; long lsKey;
        long bB = 0;
 
        public Form1()
        {
            InitializeComponent();
            System.Windows.Forms.Control.CheckForIllegalCrossThreadCalls = false;
        }
 
        private void button3_Click(object sender, EventArgs e)
        {
            /*textBox1.Text = String.Empty;
            try
            {
                ConnectToServer();
            }
            catch (SocketException se)
            {
                newClient.Close();
                //tcpStream.Close();
                MessageBox.Show("Exception:\n" + se);
            }
            label1.Text = "Соединение с сервером установлено!";*/
        }
 
        /*private void ConnectToServer()
        {
            try
            {
                label1.Text = "Соединение с сервером устанавливается. . .";
                Int32 port = 8080;
                ipAddrClient = IPAddress.Parse("192.168.1.100");
                newClient.Connect(ipAddrClient, port);
                tcpStream = newClient.GetStream();
                label1.Text = "Соединение с сервером установлено!";
                //new Send(delegate() { while (true) ReceiveMessege(); }).BeginInvoke(null, null);
            }
            catch (Exception ex)
            {
                MessageBox.Show("Error: \n" + ex);
            }
            finally
            {
                newClient.Close();
                tcpStream.Close();
            }
        }*/
 
        private void button1_Click(object sender, EventArgs e)
        {
            try
            {
                Int32 port = 8080;
                TcpClient newClient = new TcpClient();
                IPAddress ipAddrClient;
                ipAddrClient = IPAddress.Parse("192.168.1.100");
                newClient.Connect(ipAddrClient, port);
                NetworkStream tcpStream = newClient.GetStream();
 
                Random ran = new Random();
                pB = primesNumber[ran.Next(1, 20)];
                int n;
                while (true) if ((n = ran.Next(1, (int)pB)) > 1 && n < pB) { gB = n; break; }
                while (true) if ((n = ran.Next(1, (int)pB)) > 1 && n < pB) { xB = n; break; }
                //pA = 11; gA = 2; xA = 8; //yA = (long)Math.Pow(gA, xA) % pA;
                long temp = gB;
                for (int i = 1; i < xB; i++)
                {
                    temp = (temp * gB) % pB;
                }
                yB = temp;
 
                String masKey = String.Empty;
                masKey += "b" + pB.ToString(); masKey += "." + gB.ToString(); masKey += "." + yB.ToString();
                byte[] buffer = new byte[masKey.Length];
                buffer = Encoding.ASCII.GetBytes(masKey);
                tcpStream.Write(buffer, 0, buffer.Length);
 
                newClient.Close();
                tcpStream.Close();
 
//--------------------------------------------------------------------------------
                IPAddress ipAddrServer = IPAddress.Any;
                server = new TcpListener(ipAddrServer, 8080);
                server.Start();
 
                TcpClient alClient = server.AcceptTcpClient();
                NetworkStream alStreamAlisa = alClient.GetStream();
 
                byte[] buffer2 = new byte[256];
                alStreamAlisa.Read(buffer2, 0, buffer2.Length);
                String str = Encoding.ASCII.GetString(buffer2);
 
                int j = 0; 
                String[] sKey = new String[2]; 
                
                for (int i = 0; i < buffer.Length; i++)
                {
                    if (str[i] != '.' && str[i] != '\0') sKey[j] += str[i];
                    else
                    {
                        if (j == 0) aB = (long)Convert.ToInt32(sKey[j]);
                        if (j == 1) bB = (long)Convert.ToInt32(sKey[j]);
                        j++;
                        if (str[i] == '\0') break;
                    }
                }
                temp = aB;
                for (int i = 1; i < pB - 1 - xB; i++)
                {
                    temp = (temp * aB) % pB;
                }
                aB = temp;
                long M = lsKey = (bB * aB) % pB;
                richTextBox1.Text = M.ToString();
 
                //alClient.Close();
                //alStreamAlisa.Close();
            }
            catch
            {
                
            }
        }
 
        private void button2_Click(object sender, EventArgs e)
        {
            richTextBox1.Text = String.Empty;
            textBox1.Text = String.Empty;
        }
 
        private void button5_Click(object sender, EventArgs e)
        {
            try
            {
                SendMessage();
            }
            catch (InvalidOperationException io)
            {
                MessageBox.Show("Exception:\n" + io);
                Application.Exit();
            }
        }
 
        private void button4_Click(object sender, EventArgs e)
        {
            ipAddrServer = IPAddress.Any;
            server = new TcpListener(ipAddrServer, 8080);
            server.Start();
 
            alClient = server.AcceptTcpClient();
            alStreamAlisa = alClient.GetStream();
 
            new Send(delegate() { while (true) ReceiveMessege(); }).BeginInvoke(null, null);
        }
 
        private void SendMessage()
        {
            long num = Convert.ToInt32(textBox1.Text);
 
            long temp = gB;
            for (int i = 1; i < lsKey; i++)
            {
                temp = (temp * gB) % pB;
            }
            this.aB = temp;
 
            temp = yB;
            for (int i = 1; i < lsKey; i++)
            {
                temp = (temp * yB);
            }
            this.bB = temp;
            this.bB = (this.bB * num) % pB;
 
            String result = aB.ToString() + "." + bB.ToString();
            byte[] buffer = Encoding.ASCII.GetBytes(result);
            alStreamAlisa.Write(buffer, 0, buffer.Length);
            richTextBox1.Text += textBox1.Text + " \n";
            textBox1.Text = "";
        }
 
        //Функция получаем сообщения
        private void ReceiveMessege()
        {
            try
            {
                byte[] buffer = new byte[alClient.ReceiveBufferSize];
                int bytesRead = alStreamAlisa.Read(buffer, 0, alClient.ReceiveBufferSize);
                if (bytesRead != 0)
                {
                    /*((IPEndPoint)newClient.Client.LocalEndPoint).Address.ToString();
                    richTextBox1.Text += Encoding.ASCII.GetString(buffer);
                    richTextBox1.Text += "\n";*/
 
                    String str = Encoding.ASCII.GetString(buffer);
 
                    int j = 0;
                    String[] sKey = new String[2];
 
                    for (int i = 0; i < buffer.Length; i++)
                    {
                        if (str[i] != '.' && str[i] != '\0') sKey[j] += str[i];
                        else
                        {
                            if (j == 0) aB = (long)Convert.ToInt32(sKey[j]);
                            if (j == 1) bB = (long)Convert.ToInt32(sKey[j]);
                            j++;
                            if (str[i] == '\0') break;
                        }
                    }
 
                    long temp = aB;
                    for (int i = 1; i < pB - 1 - xB; i++)
                    {
                        temp = (temp * aB) % pB;
                    }
                    aB = temp;
                    long M = (bB * aB) % pB;
                    richTextBox1.Text += "-  " + M.ToString() + "  ||\n";
                }
                else
                {
                    //newClient.Client.Shutdown();
                    label1.Text = "Соединение с клиентом разорвано. . .";
                }
 
            }
            catch
            {  
            }
        }
    }
}

Тренд
Кликните здесь для просмотра всего текста
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
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Net;
using System.Net.Sockets;
using System.Threading;
 
namespace mTcpServer
{
    public partial class Form1 : Form
    {
        TcpListener server = null;
        
        long pA; long gA; long sA; long yA;
        long pB; long gB; long sB; long yB;
        long lsKey; long aA, bA, aB, bB;
 
        public Form1()
        {
            InitializeComponent();
            System.Windows.Forms.Control.CheckForIllegalCrossThreadCalls = false;
        }
 
        private void Form1_Load(object sender, EventArgs e)
        {
            IPAddress ipAddrServer = IPAddress.Any;
            server = new TcpListener(ipAddrServer, 8080);
            server.Start();
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
            String[] sKey = new String[3];
            while (true)
            {
                TcpClient tcpClient = server.AcceptTcpClient();
                NetworkStream tcpStream = tcpClient.GetStream();
                byte[] buffer = new byte[512];
                tcpStream.Read(buffer, 0, buffer.Length);
                String str = Encoding.ASCII.GetString(buffer);
                String request = String.Empty;
                int j = 0;
 
                request = str[0].ToString();
 
                switch (request)
                {
                    case "a":
                        {
 
                            // Устанавливаем открытые ключи Алисы
                            j = 0;
                            if (pA == 0 && gA == 0 && yA == 0)
                            {
                                for (int i = 1; i < buffer.Length; i++)
                                {
                                    if (str[i] != '.' && str[i] != '\0') sKey[j] += str[i];
                                    else
                                    {
                                        if (j == 0) pA = (long)Convert.ToInt32(sKey[j]);
                                        if (j == 1) gA = (long)Convert.ToInt32(sKey[j]);
                                        if (j == 2) yA = (long)Convert.ToInt32(sKey[j]);
                                        j++;
                                        if (str[i] == '\0') break;
                                    }
                                }
 
                            }
                            pA = 11; gA = 2; yA = 3;
                            tcpClient.Close();
                            tcpStream.Close();
                            break;
                        }
                    case "b":
                        {
                            // Устанавливаем открытые ключи Боба
                            j = 0;
                            if (pB == 0 && gB == 0 && yB == 0)
                            {
                                for (int i = 1; i < buffer.Length; i++)
                                {
                                    if (str[i] != '.' && str[i] != '\0') sKey[j] += str[i];
                                    else
                                    {
                                        if (j == 0) pB = (long)Convert.ToInt32(sKey[j]);
                                        if (j == 1) gB = (long)Convert.ToInt32(sKey[j]);
                                        if (j == 2) yB = (long)Convert.ToInt32(sKey[j]);
                                        j++;
                                        if (str[i] == '\0') break;
                                    }
                                }
                            }
                            pB = 11; gB = 2; yB = 3;
                            tcpClient.Close();
                            tcpStream.Close();
                            break;
                        }
                    case "s":
                        {
                            //Генерируем сеансовый ключ для Боба и Алисы
                            while (true)
                            {
                                long temp;
                                Random ran = new Random();
                                if (pA < pB) temp = ran.Next(1, (int)pA - 1);
                                else temp = ran.Next(1, (int)pB - 1);
 
                                if (temp > 1 && temp < pA - 1 && temp < pB - 1) { lsKey = 9; /*temp;*/ break; }
                            }
 
                            //Шифруем сеансовый ключ для Алисы
                            //sA = 9;
                            //g^k % pA;
                            long temp2 = gA;
                            for (int i = 1; i < lsKey; i++)
                            {
                                temp2 = (temp2 * gA) % pA;
                            }
                            this.aA = temp2;
 
                            //y^k*M mod p;
                            temp2 = yA;
                            for (int i = 1; i < lsKey; i++)
                            {
                                temp2 = (temp2 * yA);
                            }
                            this.bA = temp2;
                            this.bA = (this.bA * lsKey) % pA;
 
                            //Шифруем сеансовый ключ для Боба
                            //sB = 9;
                            // (long)Math.Pow(gB, sB) % pB;
                            temp2 = gB;
                            for (int i = 1; i < lsKey; i++)
                            {
                                temp2 = (temp2 * gB) % pB;
                            }
                            this.aB = temp2;
 
                            // ((long)Math.Pow(yB, sB));
                            temp2 = yB;
                            for (int i = 1; i < lsKey; i++)
                            {
                                temp2 = (temp2 * yB);
                            }
                            this.bB = temp2;
                            this.bB = (this.bB * lsKey) % pB;
 
                            String result = aA.ToString() + "." + bA.ToString() + "." + aB.ToString() + "." + bB.ToString();
                            byte[] streamKey = new byte[result.Length];
                            streamKey = Encoding.ASCII.GetBytes(result);
                            tcpStream.Write(streamKey, 0, streamKey.Length);
 
                            tcpClient.Close();
                            tcpStream.Close();
                            break;
                        }
                }
            }
        }
 
        private void button2_Click(object sender, EventArgs e)
        {
            /*try
            {
                SendMessage();
            }
            catch (InvalidOperationException io)
            {
                MessageBox.Show("Exception:\n" + io);
                Application.Exit();
            }*/
        }
        /*
        private void ReceiveMessege()
        {
            while (true)
            {
                try
                {
                    byte[] buffer = new byte[newClient.ReceiveBufferSize];
                    int bytesRead = tcpStream.Read(buffer, 0, newClient.ReceiveBufferSize);
                    richTextBox1.Text += Encoding.ASCII.GetString(buffer);
                    richTextBox1.Text += "\n";
                }
                catch
                {
                    tcpStream.Close();
                    newClient.Close();
                    Application.Exit();
                }
            }
        }
 
        private void SendMessage()
        {
            byte[] buffer = Encoding.ASCII.GetBytes(textBox1.Text);
            tcpStream.Write(buffer, 0, buffer.Length);
            richTextBox1.Text += textBox1.Text + " \n";
            textBox1.Text = "";
        }
 
        private void ConnectToClient()
        {
            richTextBox1.Text += "Соединение с клиентом устанавливается. . .\n";
            IPAddress ipAddrServer = IPAddress.Any;
            server = new TcpListener(ipAddrServer, 8080);
            server.Start();
            newClient = server.AcceptTcpClient();
            richTextBox1.Text = "Соединение с клиентом установлено!\n";
            tcpStream = newClient.GetStream();
            richTextBox1.Text += "\n"+ IPAddress.Parse(((IPEndPoint)newClient.Client.LocalEndPoint).Address.ToString()) +
                                            " on port number " + ((IPEndPoint)server.LocalEndpoint).Port.ToString();
            new Send(delegate() { ReceiveMessege(); }).BeginInvoke(null, null);
        }*/
    }
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
29.09.2012, 15:27
Ответы с готовыми решениями:

Шифрование Эль-Гамаля: исправить код расшифровки
Написал функцию шифрования и расшифрования. Но расшифровывает не правильно, не могли бы помочь: //...

Де/шифрование по алгоритму Эль-Гамаля
Суть в чём: мне необходимо реализовать шифрование и дешифрование текста с использованием алгоритма...

Шифрование Эль-Гамаля: исправить ошибку в программе
Помогите исправить программу, не шифруется выдает ошибку

Шифрование Эль Гамаля
Может кто нибудь помочь, я плохо разбираюсь в коде, моей знакомой надо код шифрование, чтоб по...

0
29.09.2012, 15:27
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
29.09.2012, 15:27
Помогаю со студенческими работами здесь

Шифрование методом Эль-Гамаля
Доброго всем времени суток) Нужно в один из проектов встроить шифрование методом Эль-Гамаля. Нашёл...

Шифрование сообщения схемой Эль-Гамаля
Всем привет. Очень сильно нужны пояснения, насчет шифрования текстового сообщения. Если сообщение...

Шифрование текста методом Эль Гамаля
Нет у кого нибудь случайно исходника на Delphi шифрования и дешифрования текстового файла методом...

Генерация параметров (p и g ).Для ЭЦП Эль-Гамаля
Даже не знаю в какой раздел писать. По описанию метода параметрами являются простое число p и...

Использование хеш-функции для ЭЦП Эль-Гамаля
Доброго времени суток. Не могу понять каким образом используются хеш-функции для создания ЭЦП...

реализация ЭЦП Эль-Гамаля на ассемблере для процессора ADSP-2181
Уважаемые! я здесь новенькая, прошу помощи. Задали курсовик написать, тема: эцп по алгоритму...


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

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