Scroll to navigation

RSA_GENERATE_KEY(3SSL) OpenSSL RSA_GENERATE_KEY(3SSL)

الاسم

EVP_RSA_gen, RSA_generate_key_ex, RSA_generate_key, RSA_generate_multi_prime_key - توليد زوج مفاتيح RSA

موجز

 #include <openssl/rsa.h>
 EVP_PKEY *EVP_RSA_gen(unsigned int bits);

الدوال التالية أصبحت مهجورة منذ OpenSSL 3.0، ويمكن إخفاؤها تماماً عن طريق تعريف OPENSSL_API_COMPAT بقيمة إصدار مناسبة، انظر openssl_user_macros(7):

 int RSA_generate_key_ex(RSA *rsa, int bits, BIGNUM *e, BN_GENCB *cb);
 int RSA_generate_multi_prime_key(RSA *rsa, int bits, int primes, BIGNUM *e, BN_GENCB *cb);

الدالة التالية أُهملت منذ OpenSSL 0.9.8، ويمكن إخفاؤها كليًا بتعريف OPENSSL_API_COMPAT بقيمة إصدار مناسبة، انظر openssl_user_macros(7):

 RSA *RSA_generate_key(int bits, unsigned long e,
                       void (*callback)(int, int, void *), void *cb_arg);

الوصف

EVP_RSA_gen() يولد زوج مفاتيح RSA جديد بحجم معامل bits.

جميع الدوال الموصوفة أدناه أُهملت. يجب على التطبيقات استخدام EVP_RSA_gen()، أو EVP_PKEY_Q_keygen(3)، أو EVP_PKEY_keygen_init(3) و EVP_PKEY_keygen(3) بدلاً منها.

RSA_generate_key_ex() يولد زوج مفاتيح RSA بأوليين اثنين ويخزنه في بنية RSA المقدمة في rsa.

RSA_generate_multi_prime_key() يولد زوج مفاتيح RSA متعدد الأوليات ويخزنه في بنية RSA المقدمة في rsa. يُعطى عدد الأوليات بواسطة معامل primes. إذا فشلت البذر الآلي أو إعادة البذر لمولد الأعداد العشوائية الزائفة الآمنة CSPRNG في OpenSSL بسبب ظروف خارجية (انظر RAND(7))، ستفشل العملية.

سيكون حجم المعامل بطول bits، وعدد الأوليات المكونة للمعامل سيكون primes، والأس العام سيكون e. أحجام المفاتيح ذات num < 1024 يجب اعتبارها غير آمنة. الأس هو عدد فردي، عادةً 3 أو 17 أو 65537.

للحفاظ على مستوى أمان كافٍ، يعتمد الحد الأقصى المسموح به من primes على طول المعامل بالبت:

   <1024 | >=1024 | >=4096 | >=8192
   ------+--------+--------+-------
     2   |   3    |   4    |   5

يمكن استخدام دالة استدعاء لتقديم تغذية راجعة حول تقدم توليد المفتاح. إذا كان cb ليس NULL، ستُستدعى كما يلي باستخدام دالة BN_GENCB_call() الموصوفة في صفحة BN_generate_prime(3).

RSA_generate_key() مشابهة لـ RSA_generate_key_ex() لكنها تتوقع دالة استدعاء بالنمط القديم؛ انظر BN_generate_prime(3) للحصول على معلومات حول الاستدعاء بالنمط القديم.

  • أثناء توليد عدد أولي عشوائي، تُستدعى كما هو موصوف في BN_generate_prime(3).
  • عند رفض العدد الأولي العشوائي المُولد رقم n لعدم ملاءمته للمفتاح، تُستدعى BN_GENCB_call(cb, 2, n).
  • عند إيجاد عدد أولي عشوائي p مع p-1 أولي نسبيًا لـ e، تُستدعى كـ BN_GENCB_call(cb, 3, 0).

ثم تُكرر العملية للعدد الأولي q والأوليات الأخرى (إن وجدت) مع BN_GENCB_call(cb, 3, i) حيث i يشير إلى العدد الأولي رقم i.

القيم المُرجعة

EVP_RSA_gen() تُرجع EVP_PKEY أو NULL عند الفشل.

RSA_generate_multi_prime_key() تُرجع 1 عند النجاح أو 0 عند الخطأ. RSA_generate_key_ex() تُرجع 1 عند النجاح أو 0 عند الخطأ. يمكن الحصول على رموز الخطأ بواسطة ERR_get_error(3).

RSA_generate_key() تُرجع مؤشرًا إلى بنية RSA أو NULL إذا فشل توليد المفتاح.

العلل

BN_GENCB_call(cb, 2, x) يُستخدم بمعنيين مختلفين.

انظر أيضًا

EVP_PKEY_Q_keygen(3) BN_generate_prime(3), ERR_get_error(3), RAND_bytes(3), RAND(7)

التاريخ

EVP_RSA_gen() أُضيفت في OpenSSL 3.0. جميع الدوال الأخرى الموصوفة هنا أُهملت في OpenSSL 3.0. للاستبدال، انظر EVP_PKEY-RSA(7).

حقوق النسخ

حقوق النشر 2000-2021 لمؤلفي مشروع OpenSSL. جميع الحقوق محفوظة.

مرخص بموجب رخصة Apache 2.0 (المشار إليها فيما يلي بـ ”الرخصة“). لا يجوز لك استخدام هذا الملف إلا وفقًا لشروط الرخصة. يمكنك الحصول على نسخة منها في الملف LICENSE الموجود في حزمة التوزيع المصدرية أو على الرابط <https://www.openssl.org/source/license.html>.

ترجمة

تُرجمت هذه الصفحة من الدليل بواسطة زايد السعيدي <zayed.alsaidi@gmail.com>

هذه الترجمة هي وثيقة مجانية؛ راجع رخصة جنو العامة الإصدار 3 أو ما بعده للاطلاع على شروط حقوق النشر. لا توجد أي ضمانات.

إذا وجدت أي أخطاء في ترجمة صفحة الدليل هذه، يرجى إرسال بريد إلكتروني إلى قائمة بريد المترجمين: kde-l10n-ar@kde.org.

7 أبريل 2026 3.6.2