table of contents
- trixie-backports 4.31.0-1~bpo13+1
- testing 4.31.0-1
- unstable 4.31.0-1
| EVP_PKEY_CTX_NEW(3SSL) | OpenSSL | EVP_PKEY_CTX_NEW(3SSL) |
الاسم¶
EVP_PKEY_CTX_new, EVP_PKEY_CTX_new_id, EVP_PKEY_CTX_new_from_name, EVP_PKEY_CTX_new_from_pkey, EVP_PKEY_CTX_dup, EVP_PKEY_CTX_free, EVP_PKEY_CTX_is_a - دوال سياق خوارزمية المفتاح العمومي
موجز¶
#include <openssl/evp.h>
EVP_PKEY_CTX *EVP_PKEY_CTX_new(EVP_PKEY *pkey, ENGINE *e);
EVP_PKEY_CTX *EVP_PKEY_CTX_new_id(int id, ENGINE *e);
EVP_PKEY_CTX *EVP_PKEY_CTX_new_from_name(OSSL_LIB_CTX *libctx,
const char *name,
const char *propquery);
EVP_PKEY_CTX *EVP_PKEY_CTX_new_from_pkey(OSSL_LIB_CTX *libctx,
EVP_PKEY *pkey,
const char *propquery);
EVP_PKEY_CTX *EVP_PKEY_CTX_dup(const EVP_PKEY_CTX *ctx);
void EVP_PKEY_CTX_free(EVP_PKEY_CTX *ctx);
int EVP_PKEY_CTX_is_a(EVP_PKEY_CTX *ctx, const char *keytype);
الوصف¶
تخصص الدالة EVP_PKEY_CTX_new() سياق خوارزمية المفتاح العمومي باستخدام نوع المفتاح pkey ومحرك ENGINE e.
تخصص الدالة EVP_PKEY_CTX_new_id() سياق خوارزمية المفتاح العمومي باستخدام نوع المفتاح المحدد بواسطة id ومحرك ENGINE e.
تخصص الدالة EVP_PKEY_CTX_new_from_name() سياق خوارزمية المفتاح العمومي باستخدام سياق المكتبة libctx (انظر OSSL_LIB_CTX(3))، ونوع المفتاح المحدد بواسطة name واستعلام الخاصية propquery. لا تُنسخ أي من الوسائط، لذا يجب أن تبقى دون تغيير طوال عمر EVP_PKEY_CTX المُعاد أو أي من نسخه. اقرأ المزيد عن الأسماء الممكنة في "ملاحظات" أدناه.
تخصص الدالة EVP_PKEY_CTX_new_from_pkey() سياق خوارزمية المفتاح العمومي باستخدام سياق المكتبة libctx (انظر OSSL_LIB_CTX(3)) والخوارزمية المحددة بواسطة pkey واستعلام الخاصية propquery. لا تُنسخ أي من الوسائط، لذا يجب أن تبقى دون تغيير طوال عمر EVP_PKEY_CTX المُعاد أو أي من نسخه.
تُستخدم EVP_PKEY_CTX_new_id() و EVP_PKEY_CTX_new_from_name() عادةً عندما لا يرتبط أي هيكل EVP_PKEY بالعمليات، مثلاً أثناء توليد المعاملات أو توليد المفاتيح لبعض الخوارزميات.
تنسخ EVP_PKEY_CTX_dup() السياق ctx. لا تُدعم لعملية توليد المفاتيح. لكن من الممكن نسخ سياق أُنشئ حديثاً عبر أي من دوال "new" أعلاه، بشرط ألا تُستدعى EVP_PKEY_keygen_init(3) بعد على السياق المصدر، ثم تُستخدم النسخة لتوليد المفاتيح.
تحرر EVP_PKEY_CTX_free() السياق ctx. إذا كان ctx هو NULL، لا يُفعل شيء.
تتحقق EVP_PKEY_is_a() مما إذا كان نوع المفتاح المرتبط بـ ctx هو keytype.
ملاحظات¶
حول EVP_PKEY_CTX¶
هيكل EVP_PKEY_CTX هو سياق خوارزمية مفتاح عمومي غير شفاف يُستخدم بواسطة واجهة برمجة التطبيقات عالية المستوى للمفتاح العمومي في OpenSSL. السياقات يجب ألا تُشارك بين الخيوط: أي أنه لا يُسمح باستخدام نفس السياق في وقت واحد في خيطين.
حول أنواع المفاتيح¶
نذكر "نوع المفتاح" في هذا الدليل، وهو نفس "الخوارزمية" في معظم الحالات، مما يسمح باستخدام أي من المصطلحين بالتبادل. توجد خوارزميات حيث نوع المفتاح و الخوارزمية للعمليات التي تستخدم المفاتيح ليسا نفس الشيء، مثل مفاتيح EC المستخدمة لعمليات ECDSA و ECDH.
تُعطى أنواع المفاتيح بطريقتين مختلفتين:
- نوع NID القديم أو EVP_PKEY
- هذا هو id
المستخدم
مع EVP_PKEY_CTX_new_id().
هذه هي EVP_PKEY_RSA، EVP_PKEY_RSA_PSS، EVP_PKEY_DSA، EVP_PKEY_DH، EVP_PKEY_EC، EVP_PKEY_SM2، EVP_PKEY_X25519، EVP_PKEY_X448، وتُستخدم بواسطة الطرق القديمة.
- سلاسل المحارف الاسمية
- هذا هو
الاسم
المستخدم
مع EVP_PKEY_CTX_new_from_name().
هذه أسماء مثل "RSA"، "DSA"، وما هو متاح يعتمد على المزودين المتاحين حالياً.
يقدم مزودو OpenSSL مجموعة من أنواع المفاتيح المتاحة بهذه الطريقة، يُرجى الاطلاع على OSSL_PROVIDER-FIPS(7) و OSSL_PROVIDER-default(7) والوثائق ذات الصلة لمزيد من المعلومات.
القيم المُرجعة¶
تُرجع EVP_PKEY_CTX_new() و EVP_PKEY_CTX_new_id() و EVP_PKEY_CTX_dup() إما بنية EVP_PKEY_CTX المخصصة حديثاً أو NULL إذا حدث خطأ.
لا تُرجع EVP_PKEY_CTX_free() قيمة.
تُرجع EVP_PKEY_CTX_is_a() 1 للصواب و 0 للخطأ.
انظر أيضًا¶
التاريخ¶
أُضيفت الدوال EVP_PKEY_CTX_new() و EVP_PKEY_CTX_new_id() و EVP_PKEY_CTX_dup() و EVP_PKEY_CTX_free() في OpenSSL 1.0.0.
أُضيفت الدالتان EVP_PKEY_CTX_new_from_name() و EVP_PKEY_CTX_new_from_pkey() في OpenSSL 3.0.
حقوق النسخ¶
حقوق النشر 2006-2025 لمؤلفي مشروع 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.5.6 |