Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
31 / 31 / 2
Регистрация: 06.08.2012
Сообщений: 155

Помощь в реализации шифрования

11.09.2012, 17:43. Показов 2011. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет, хочу реализовать шифрование файла "на лету" с помощью RSA - ключей. Никак не могу додуматься, как правильно сделать. Есть такой код:
PHP
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
<?php
error_reporting(0);
include 'rsa.class.php';
$RSA = new RSA();
$keys = $RSA->generate_keys ('9990454949', '9990450271', 1);
// Достаём первичное зашифрованное содержимое
$f = file_get_contents("myalgo.php");
$ff = "myalgo.php";
// Расшифровываем
$decoded = $RSA->decrypt ($f, $keys[2], $keys[0]);
// echo $decoded.'<br><br>';
// Ложим расшифрованное для последующего использования
$a = file_put_contents($ff, $decoded);
if($a){
// Подрубаем только что расшифрованный файл
include ("myalgo.php");
// Для теста вызываем функу из файла
xxx();
// Опять достаем расшифрованный контент
$f1 = file_get_contents("myalgo.php");
// Шифруем
$encoded = $RSA->encrypt ($f1, $keys[1], $keys[0], 5);
// Ложим обратно
file_put_contents($ff, $encoded);
}
?>
Как не странно - но после одного захода файл пустеет и ничего не работает. Подскажите как подправить, да и вообще, есть ли в этом смысл с защитной точки зрения? ( Если ключи получать удаленно )

P.S. Паблик реализация RSA класса.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
11.09.2012, 17:43
Ответы с готовыми решениями:

Progress bar из картинок [Помощь в реализации]
Доброго времени суток народ! Встал один вопрос, который я не могу решить Есть два изображения - фон (треснутый асфальт) и линия в...

Нужна помощь в реализации шифрования методом Плейфера
Подскажите как написать программу на C# методом Плейфера? Правило: 1. если символы находятся в одной строке, то каждый из символов...

Нужен простой в реализации алгоритм шифрования
Задача такая. Считывается ID камня, записывается в явном виде в файл на SD карту. Пользователь отправляет этот файл на сервер и...

7
7 / 7 / 3
Регистрация: 27.08.2012
Сообщений: 82
12.09.2012, 09:50
Ай да все хрень это. Юзай md5. Круче намного. Знаешь как пользоваться им?
0
31 / 31 / 2
Регистрация: 06.08.2012
Сообщений: 155
12.09.2012, 16:11  [ТС]
Цитата Сообщение от thebaron Посмотреть сообщение
Ай да все хрень это. Юзай md5. Круче намного. Знаешь как пользоваться им?
MD5 - алгоритм необратимого шифрования ( а точнее хэширования ). Мне бы что-нибудь по типу RSA - передал ключик, расшифровал, поюзал и зашифровал.
0
7 / 7 / 3
Регистрация: 27.08.2012
Сообщений: 82
13.09.2012, 08:02
Что ты хочеim Шифровать??? Пример.
0
не Администратор ^_^
 Аватар для Unick
988 / 223 / 23
Регистрация: 03.05.2009
Сообщений: 1,493
Записей в блоге: 1
13.09.2012, 09:49
о, как раз на лекции изучали методы шифрования
а я как дурак записал только один метод
http://ru.wikipedia.org/wiki/Шифр_Плейфера
Остальные методы у меня без названия

при неправильном ключе получится абракадабра

а чтобы тебе помочь...
rsa.class.php в студию
0
31 / 31 / 2
Регистрация: 06.08.2012
Сообщений: 155
13.09.2012, 15:29  [ТС]
Цитата Сообщение от thebaron Посмотреть сообщение
Что ты хочеim Шифровать??? Пример.
php файл с ключевыми функциями.

Содержание rsa.class.php:
Кликните здесь для просмотра всего текста

PHP
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
<?
/* 
* Rivest/Shamir/Adelman (RSA) compatible functions
* to generate keys and encode/decode 
*
*With a great thanks to:
*Ilya Rudev <www@polar-lights.com>
*Glenn Haecker <ghaecker@idworld.net>
*Segey Semenov <sergei2002@mail.ru>
*Suivan <ssuuii@gmx.net>
*
*Prime-Numbers.org provide small prime numbers list. 
*You can browse all small prime numbers(small than 10,000,000,000) there. 
*There's totally 455042511 prime numbers.
*http://www.prime-numbers.org/
*/
 
class RSA{
    /*
    * Function for generating keys. Return array where
    * $array[0] -> modulo N
    * $array[1] -> public key E
    * $array[2] -> private key D
    * Public key pair is N and E
    * Private key pair is N and D
    */
    public function generate_keys ($p, $q, $show_debug=0){
        $n = bcmul($p, $q);
      
        //m (we need it to calculate D and E) 
        $m = bcmul(bcsub($p, 1), bcsub($q, 1));
      
        // Public key  E 
        $e = $this->findE($m);
      
        // Private key D
        $d = $this->extend($e,$m);
      
        $keys = array ($n, $e, $d);
 
        if ($show_debug) {
                echo "P = $p<br>Q = $q<br><b>N = $n</b> - modulo<br>M = $m<br><b>E = $e</b> - public key<br><b>D = $d</b> - private key<p>";
        }
      
        return $keys;
    }
 
    /* 
    * Standard method of calculating D
    * D = E-1 (mod N)
    * It's presumed D will be found in less then 16 iterations 
    */
    private function extend ($Ee,$Em) {
        $u1 = '1';
        $u2 = '0';
        $u3 = $Em;
        $v1 = '0';
        $v2 = '1';
        $v3 = $Ee;
 
        while (bccomp($v3, 0) != 0) {
                $qq = bcdiv($u3, $v3, 0);
                $t1 = bcsub($u1, bcmul($qq, $v1));
                $t2 = bcsub($u2, bcmul($qq, $v2));
                $t3 = bcsub($u3, bcmul($qq, $v3));
                $u1 = $v1;
                $u2 = $v2;
                $u3 = $v3;
                $v1 = $t1;
                $v2 = $t2;
                $v3 = $t3;
                $z  = '1';
        }
 
        $uu = $u1;
        $vv = $u2;
 
        if (bccomp($vv, 0) == -1) {
                $inverse = bcadd($vv, $Em);
        } else {
                $inverse = $vv;
        }
 
        return $inverse;
    }
 
    /* 
    * This function return Greatest Common Divisor for $e and $m numbers 
    */
    private function GCD($e,$m) {
        $y = $e;
        $x = $m;
 
        while (bccomp($y, 0) != 0) {
                // modulus function
            $w = bcsub($x, bcmul($y, bcdiv($x, $y, 0)));;
                $x = $y;
                $y = $w;
        }
 
        return $x;
    }
 
    /*
    * Calculating E under conditions:
    * GCD(N,E) = 1 and 1<E<N
    */
    private function findE($m){
        $e = '3';
        if(bccomp($this->GCD($e, $m), '1') != 0){
            $e = '5';
            $step = '2';
 
            while(bccomp($this->GCD($e, $m), '1') != 0){
                $e = bcadd($e, $step);
 
                if($step == '2'){
                    $step = '4';
                }else{
                    $step = '2';
                }
            }
        }
 
        return $e;
    }
 
    /*
    * ENCRYPT function returns
    * X = M^E (mod N)
    */
    public function encrypt ($m, $e, $n, $s=3) {
        $coded   = '';
        $max     = strlen($m);
        $packets = ceil($max/$s);
        
        for($i=0; $i<$packets; $i++){
            $packet = substr($m, $i*$s, $s);
            $code   = '0';
 
            for($j=0; $j<$s; $j++){
                $code = bcadd($code, bcmul(ord($packet[$j]), bcpow('256',$j)));
            }
 
            $code   = bcpowmod($code, $e, $n);
            $coded .= $code.' ';
        }
 
        return trim($coded);
    }
 
    /*
    ENCRYPT function returns
    M = X^D (mod N)
    */
    public function decrypt ($c, $d, $n) {
        $coded   = split(' ', $c);
        $message = '';
        $max     = count($coded);
 
        for($i=0; $i<$max; $i++){
            $code = bcpowmod($coded[$i], $d, $n);
 
            while(bccomp($code, '0') != 0){
                $ascii    = bcmod($code, '256');
                $code     = bcdiv($code, '256', 0);
                $message .= chr($ascii);
            }
        }
 
        return $message;
    }
    
    // Digital Signature
    public function sign($message, $d, $n){
        $messageDigest = md5($message);
        $signature = $this->encrypt($messageDigest, $d, $n, 3);
        return $signature;
    }
    
    public function prove($message, $signature, $e, $n){
        $messageDigest = $this->decrypt($signature, $e, $n);
        if($messageDigest == md5($message)){
            return true;
        }else{
            return false;
        }
    }
 
    public function signFile($file, $d, $n){
        $messageDigest = md5_file($file);
        $signature = $this->encrypt($messageDigest, $d, $n, 3);
        return $signature;
    }
    
    public function proveFile($file, $signature, $e, $n){
        $messageDigest = $this->decrypt($signature, $e, $n);
        if($messageDigest == md5_file($file)){
            return true;
        }else{
            return false;
        }
    }
}
?>
0
не Администратор ^_^
 Аватар для Unick
988 / 223 / 23
Регистрация: 03.05.2009
Сообщений: 1,493
Записей в блоге: 1
13.09.2012, 17:02
так вот что тебе надо...
1. base64_encode
2. base64_decode
не вариант?
0
31 / 31 / 2
Регистрация: 06.08.2012
Сообщений: 155
13.09.2012, 20:06  [ТС]
Цитата Сообщение от Unick Посмотреть сообщение
так вот что тебе надо...
1. base64_encode
2. base64_decode
не вариант?
Криптостойкость = -0.1/10
Смысла в нем нету ни капельки.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
13.09.2012, 20:06
Помогаю со студенческими работами здесь

Нужен пример реализации алгоритма шифрования DES
Всем доброго времени суток =) Знаю, что во Framework'е есть встроенные средства для шифрования и там реализован DES. Может у кого есть...

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

Нужен пример реализации алгоритма шифрования AES-128
Всем доброго времени суток =) Знаю, что во Framework'е есть встроенные средства для шифрования и там реализован AES. Может у кого есть...

Нужна помощь по системе шифрования
Коллеги, предложите, пожалуйста, систему шифрования, - в которой КАЖДЫЙ символ шифрограммы 'определялся' бы по ВСЕМ символам шифруемого...

Помощь в реализации кода
Есть код, помогите реализовать его в приложение windows forms. using System; using System.Collections.Generic; using...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru