Scroll to navigation

RSA_SET_METHOD(3SSL) OpenSSL RSA_SET_METHOD(3SSL)

الاسم

RSA_set_default_method, RSA_get_default_method, RSA_set_method, RSA_get_method, RSA_PKCS1_OpenSSL, RSA_flags, RSA_new_method - اختيار طريقة RSA

موجز

 #include <openssl/rsa.h>

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

 void RSA_set_default_method(const RSA_METHOD *meth);
 const RSA_METHOD *RSA_get_default_method(void);
 int RSA_set_method(RSA *rsa, const RSA_METHOD *meth);
 const RSA_METHOD *RSA_get_method(const RSA *rsa);
 const RSA_METHOD *RSA_PKCS1_OpenSSL(void);
 int RSA_flags(const RSA *rsa);
 RSA *RSA_new_method(ENGINE *engine);

الوصف

جميع الدوال الموصوفة في هذه الصفحة مهملة. يجب على التطبيقات استخدام واجهات برمجة OSSL_PROVIDER بدلاً من ذلك.

يحدد RSA_METHOD الدوال التي يستخدمها OpenSSL لعمليات RSA. بتعديل الطريقة، يمكن استخدام تطبيقات بديلة مثل المسرعات العتادية. مهم: راجع قسم الملاحظات للحصول على معلومات مهمة حول كيفية تأثر دوال واجهة RSA هذه باستخدام استدعاءات واجهة ENGINE.

مبدئياً، يكون RSA_METHOD المبدئي هو التطبيق الداخلي لـ OpenSSL، كما يُعاد بواسطة RSA_PKCS1_OpenSSL().

يجعل RSA_set_default_method() meth الطريقة المبدئية لجميع هياكل RSA التي تُنشأ لاحقاً. ملاحظة: هذا صحيح فقط طالما لم يُضبط أي ENGINE كمبدئي لـ RSA، لذا لم تعد هذه الدالة موصى بها. هذه الدالة غير آمنة للخيوط ولا ينبغي استدعاؤها في نفس الوقت مع دوال OpenSSL الأخرى.

يعيد RSA_get_default_method() مؤشراً إلى RSA_METHOD المبدئي الحالي. ومع ذلك، تعتمد جدوى هذه النتيجة على ما إذا كانت واجهة ENGINE قيد الاستخدام، لذا لم تعد هذه الدالة موصى بها.

يختار RSA_set_method() meth لأداء جميع العمليات باستخدام المفتاح rsa. سيستبدل هذا RSA_METHOD المستخدم بواسطة مفتاح RSA، وإذا كانت الطريقة السابقة مزودة بواسطة ENGINE، فسيُحرر مقبض ذلك ENGINE أثناء التغيير. من الممكن وجود مفاتيح RSA تعمل فقط مع تطبيقات RSA_METHOD معينة (مثل وحدة ENGINE تدعم مفاتيح محمية بعتاد مضمن)، وفي مثل هذه الحالات، قد يؤدي محاولة تغيير RSA_METHOD للمفتاح إلى نتائج غير متوقعة.

يعيد RSA_get_method() مؤشراً إلى RSA_METHOD المستخدم بواسطة rsa. قد تكون هذه الطريقة مزودة أو غير مزودة بواسطة تطبيق ENGINE، ولكن إذا كانت كذلك، فلا يمكن ضمان صحة القيمة المعادة إلا طالما أن مفتاح RSA نفسه صالح ولم يتغير تطبيقه بواسطة RSA_set_method().

تُعيد RSA_flags() flags المضبوطة لـ RSA_METHOD الحالي لـ rsa. انظر قسم BUGS.

يخصص ويهيئ RSA_new_method() هيكل RSA بحيث يُستخدم engine لعمليات RSA. إذا كان engine فارغاً، يُستخدم ENGINE المبدئي لعمليات RSA، وإذا لم يُضبط أي ENGINE مبدئي، يُستخدم RSA_METHOD المُتحكم به بواسطة RSA_set_default_method().

تُعيد RSA_flags() flags المضبوطة للطريقة الحالية لـ rsa.

يخصص ويهيئ RSA_new_method() هيكل RSA بحيث تُستخدم method لعمليات RSA. إذا كانت method هي NULL، تُستخدم الطريقة المبدئية.

هيكل RSA_METHOD

 typedef struct rsa_meth_st
 {
     /* name of the implementation */
     const char *name;
     /* encrypt */
     int (*rsa_pub_enc)(int flen, unsigned char *from,
                        unsigned char *to, RSA *rsa, int padding);
     /* verify arbitrary data */
     int (*rsa_pub_dec)(int flen, unsigned char *from,
                        unsigned char *to, RSA *rsa, int padding);
     /* sign arbitrary data */
     int (*rsa_priv_enc)(int flen, unsigned char *from,
                         unsigned char *to, RSA *rsa, int padding);
     /* decrypt */
     int (*rsa_priv_dec)(int flen, unsigned char *from,
                         unsigned char *to, RSA *rsa, int padding);
     /* compute r0 = r0 ^ I mod rsa->n (May be NULL for some implementations) */
     int (*rsa_mod_exp)(BIGNUM *r0, BIGNUM *I, RSA *rsa);
     /* compute r = a ^ p mod m (May be NULL for some implementations) */
     int (*bn_mod_exp)(BIGNUM *r, BIGNUM *a, const BIGNUM *p,
                       const BIGNUM *m, BN_CTX *ctx, BN_MONT_CTX *m_ctx);
     /* called at RSA_new */
     int (*init)(RSA *rsa);
     /* called at RSA_free */
     int (*finish)(RSA *rsa);
     /*
      * RSA_FLAG_EXT_PKEY        - rsa_mod_exp is called for private key
      *                            operations, even if p,q,dmp1,dmq1,iqmp
      *                            are NULL
      * RSA_METHOD_FLAG_NO_CHECK - don't check pub/private match
      */
     int flags;
     char *app_data; /* ?? */
     int (*rsa_sign)(int type,
                     const unsigned char *m, unsigned int m_length,
                     unsigned char *sigret, unsigned int *siglen, const RSA *rsa);
     int (*rsa_verify)(int dtype,
                       const unsigned char *m, unsigned int m_length,
                       const unsigned char *sigbuf, unsigned int siglen,
                       const RSA *rsa);
     /* keygen. If NULL built-in RSA key generation will be used */
     int (*rsa_keygen)(RSA *rsa, int bits, BIGNUM *e, BN_GENCB *cb);
 } RSA_METHOD;

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

تعيد RSA_PKCS1_OpenSSL() و RSA_PKCS1_null_method() و RSA_get_default_method() و RSA_get_method() مؤشرات إلى RSA_METHODs الخاصة بها.

لا تعيد RSA_set_default_method() أي قيمة.

تعيد RSA_set_method() 1 للنجاح. تنجح دائماً.

تُعيد RSA_new_method() القيمة NULL وتضبط رمز خطأ يمكن الحصول عليه بواسطة ERR_get_error(3) إذا فشل التخصيص. وإلا فإنها تُعيد مؤشرًا إلى البنية المُخصصة حديثًا.

العلل

سلوك RSA_flags() هو ميزة خاطئة تُركت كما هي حاليًا لتجنب خلق مشاكل توافق. وظائف RSA، مثل دوال التعمية، تُتحكم بقيمة flags في مفتاح RSA نفسه، وليس بقيمة flags في RSA_METHOD المرتبط بمفتاح RSA (وهو ما تُعيده هذه الدالة). إذا غُيّر عنصر flags لمفتاح RSA، فستُكرّم التغييرات بواسطة وظائف RSA لكنها لن تنعكس في قيمة إرجاع دالة RSA_flags() - في الواقع تتصرف RSA_flags() أكثر مثل دالة RSA_default_flags() (التي لا توجد حاليًا).

انظر أيضًا

RSA_new(3)

التاريخ

كل هذه الدوال أصبحت مهجورة في OpenSSL 3.0.

استُبدلت RSA_null_method()، التي كانت محاولة جزئية لتجنب مشاكل براءات الاختراع، لتُعيد دائمًا NULL في OpenSSL 1.1.1.

حقوق النسخ

حقوق النشر 2000-2026 لمؤلفي مشروع 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