Scroll to navigation

EC_KEY_NEW(3SSL) OpenSSL EC_KEY_NEW(3SSL)

الاسم

EVP_EC_gen, EC_KEY_get_method, EC_KEY_set_method, EC_KEY_new_ex, EC_KEY_new, EC_KEY_get_flags, EC_KEY_set_flags, EC_KEY_clear_flags, EC_KEY_new_by_curve_name_ex, EC_KEY_new_by_curve_name, EC_KEY_free, EC_KEY_copy, EC_KEY_dup, EC_KEY_up_ref, EC_KEY_get0_engine, EC_KEY_get0_group, EC_KEY_set_group, EC_KEY_get0_private_key, EC_KEY_set_private_key, EC_KEY_get0_public_key, EC_KEY_set_public_key, EC_KEY_get_conv_form, EC_KEY_set_conv_form, EC_KEY_set_asn1_flag, EC_KEY_decoded_from_explicit_params, EC_KEY_precompute_mult, EC_KEY_generate_key, EC_KEY_check_key, EC_KEY_set_public_key_affine_coordinates, EC_KEY_oct2key, EC_KEY_key2buf, EC_KEY_oct2priv, EC_KEY_priv2oct, EC_KEY_priv2buf - دوال لإنشاء وتدمير ومعالجة كائنات EC_KEY

موجز

 #include <openssl/ec.h>
 EVP_PKEY *EVP_EC_gen(const char *curve);

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

 EC_KEY *EC_KEY_new_ex(OSSL_LIB_CTX *ctx, const char *propq);
 EC_KEY *EC_KEY_new(void);
 int EC_KEY_get_flags(const EC_KEY *key);
 void EC_KEY_set_flags(EC_KEY *key, int flags);
 void EC_KEY_clear_flags(EC_KEY *key, int flags);
 EC_KEY *EC_KEY_new_by_curve_name_ex(OSSL_LIB_CTX *ctx, const char *propq,
                                     int nid);
 EC_KEY *EC_KEY_new_by_curve_name(int nid);
 void EC_KEY_free(EC_KEY *key);
 EC_KEY *EC_KEY_copy(EC_KEY *dst, const EC_KEY *src);
 EC_KEY *EC_KEY_dup(const EC_KEY *src);
 int EC_KEY_up_ref(EC_KEY *key);
 ENGINE *EC_KEY_get0_engine(const EC_KEY *eckey);
 const EC_GROUP *EC_KEY_get0_group(const EC_KEY *key);
 int EC_KEY_set_group(EC_KEY *key, const EC_GROUP *group);
 const BIGNUM *EC_KEY_get0_private_key(const EC_KEY *key);
 int EC_KEY_set_private_key(EC_KEY *key, const BIGNUM *priv_key);
 const EC_POINT *EC_KEY_get0_public_key(const EC_KEY *key);
 int EC_KEY_set_public_key(EC_KEY *key, const EC_POINT *pub);
 point_conversion_form_t EC_KEY_get_conv_form(const EC_KEY *key);
 void EC_KEY_set_conv_form(EC_KEY *eckey, point_conversion_form_t cform);
 void EC_KEY_set_asn1_flag(EC_KEY *eckey, int asn1_flag);
 int EC_KEY_decoded_from_explicit_params(const EC_KEY *key);
 int EC_KEY_generate_key(EC_KEY *key);
 int EC_KEY_check_key(const EC_KEY *key);
 int EC_KEY_set_public_key_affine_coordinates(EC_KEY *key, BIGNUM *x, BIGNUM *y);
 const EC_KEY_METHOD *EC_KEY_get_method(const EC_KEY *key);
 int EC_KEY_set_method(EC_KEY *key, const EC_KEY_METHOD *meth);
 int EC_KEY_oct2key(EC_KEY *eckey, const unsigned char *buf, size_t len, BN_CTX *ctx);
 size_t EC_KEY_key2buf(const EC_KEY *eckey, point_conversion_form_t form,
                       unsigned char **pbuf, BN_CTX *ctx);
 int EC_KEY_oct2priv(EC_KEY *eckey, const unsigned char *buf, size_t len);
 size_t EC_KEY_priv2oct(const EC_KEY *eckey, unsigned char *buf, size_t len);
 size_t EC_KEY_priv2buf(const EC_KEY *eckey, unsigned char **pbuf);
 int EC_KEY_precompute_mult(EC_KEY *key, BN_CTX *ctx);

الوصف

تولد EVP_EC_gen() زوج مفاتيح EC جديد على curve المعطى.

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

يمثل EC_KEY مفتاحاً عاماً، واختيارياً، المفتاح الخاص المرتبط. يمكن إنشاء EC_KEY جديد بدون منحنى مرتبط باستدعاء EC_KEY_new_ex() وتحديد سياق المكتبة المرتبط في ctx (انظر OSSL_LIB_CTX وسلسلة استعلام الخاصية propq. قد يكون المعامل ctx NULL، وفي هذه الحالة يُستخدم سياق المكتبة المبدئي. يُضبط عدد المراجع للكائن EC_KEY المُنشأ حديثاً مبدئياً إلى 1. يمكن ربط منحنى بـ EC_KEY باستدعاء EC_KEY_set_group().

EC_KEY_new() مماثل لـ EC_KEY_new_ex() باستثناء أن سياق المكتبة المبدئي يُستخدم دائماً.

بدلاً من ذلك، يمكن إنشاء EC_KEY جديد باستدعاء EC_KEY_new_by_curve_name_ex() وتوفير nid للمنحنى المرتبط، وسياق المكتبة المراد استخدامه ctx (انظر OSSL_LIB_CTX(3)) وأي سلسلة استعلام خاصية propq. قد يكون المعامل ctx NULL، وفي هذه الحالة يُستخدم سياق المكتبة المبدئي. قد تكون قيمة propq NULL أيضاً. انظر EC_GROUP_new(3) لوصف أسماء المنحنيات. تغلف هذه الدالة ببساطة استدعاءات لـEC_KEY_new_ex() و EC_GROUP_new_by_curve_name_ex().

EC_KEY_new_by_curve_name() مماثل لـ EC_KEY_new_by_curve_name_ex() باستثناء أن سياق المكتبة المبدئي يُستخدم دائماً وسلسلة استعلام خاصية NULL.

يقلل استدعاء EC_KEY_free() عدد المراجع لكائن EC_KEY، وإذا انخفض إلى الصفر، يُحرر الذاكرة المرتبطة به. إذا كان key NULL، لا يُفعل شيء.

ينسخ EC_KEY_copy() محتويات EC_KEY في src إلى dest.

ينشئ EC_KEY_dup() كائن EC_KEY جديد وينسخ ec_key إليه.

يزيد EC_KEY_up_ref() عدد المراجع المرتبط بكائن EC_KEY.

يعيد EC_KEY_get0_engine() مقبضاً إلى ENGINE الذي وُضع لهذا الكائن EC_KEY.

يولد EC_KEY_generate_key() مفتاحاً عاماً وخاصاً جديدين لكائن eckey المزود. يجب أن يكون لكائن eckeyكائن EC_GROUP مرتبط به قبل استدعاء هذه الدالة. المفتاح الخاص هو عدد صحيح عشوائي (ترتيب < priv_key < 0، حيث order هو ترتيب كائن EC_GROUP). المفتاح العام هو نقطة EC_POINT على المنحنى تُحسب بضرب المولد للمنحنى في المفتاح الخاص.

يجري EC_KEY_check_key() فحوصات سلامة متنوعة على كائن EC_KEY لتأكيد صحته.

EC_KEY_set_public_key_affine_coordinates() يضبط المفتاح العمومي لـ key استنادًا إلى إحداثياته التقاربية؛ أي أنه ينشئ كائن EC_POINT بناءً على قيمتي x وy المقدمتين ويضبط المفتاح العمومي ليكون هذا EC_POINT. كما يجري فحوصات سلامة معينة على المفتاح لتأكيد صحته.

الدوال EC_KEY_get0_group() وEC_KEY_set_group() وEC_KEY_get0_private_key() وEC_KEY_set_private_key() وEC_KEY_get0_public_key() وEC_KEY_set_public_key() تحصل وتضبط كائن EC_GROUP والمفتاح الخاص والمفتاح العمومي EC_POINT لـ key على التوالي. الدالة EC_KEY_set_private_key() تقبل NULL كوسيطة priv_key لمسح مكون المفتاح الخاص من EC_KEY بشكل آمن.

الدالتان EC_KEY_get_conv_form() و EC_KEY_set_conv_form() تجلبان وتضبطان point_conversion_form للمفتاح key. لوصف point_conversion_forms، انظر EC_POINT_new(3).

EC_KEY_set_flags() تضبط الأعلام في المعامل flags على كائن EC_KEY. أي أعلام مضبوطة بالفعل تُترك مضبوطة. الأعلام المعرفة حالياً هي EC_FLAG_NON_FIPS_ALLOW و EC_FLAG_FIPS_CHECKED. بالإضافة إلى ذلك، يوجد العلم EC_FLAG_COFACTOR_ECDH الخاص بـ ECDH. EC_KEY_get_flags() تُرجع الأعلام الحالية المضبوطة لهذا EC_KEY. EC_KEY_clear_flags() تمسح الأعلام المشار إليها بالمعامل flags؛ جميع الأعلام الأخرى تُترك في حالتها الحالية.

EC_KEY_set_asn1_flag() تضبط asn1_flag على كائن EC_GROUP الأساسي (إذا كان مضبوطاً). راجع EC_GROUP_copy(3) لمزيد من المعلومات حول asn1_flag.

EC_KEY_decoded_from_explicit_params() تُرجع 1 إذا فُك تشفير مجموعة المفتاح key من بيانات بمعاملات مجموعة مشفرة صراحةً، و -1 إذا كان المفتاح key NULL أو معاملات المجموعة مفقودة، و 0 خلاف ذلك.

EC_KEY_precompute_mult() تخزن مضاعفات مولد EC_GROUP الأساسي لضرب نقاط أسرع. انظر أيضاً EC_POINT_add(3). يجب على الإصدارات الحديثة بدلاً من ذلك التبديل إلى المنحنيات المسماة التي لدى OpenSSL جداول بحث مشفرة لها.

EC_KEY_oct2key() و EC_KEY_key2buf() متطابقتان مع الدالتين EC_POINT_oct2point() و EC_POINT_point2buf() باستثناء أنهما تستخدمان المفتاح العام EC_POINT في eckey.

EC_KEY_oct2priv() و EC_KEY_priv2oct() تحولان بين مكون المفتاح الخاص لـ eckey والشكل الثماني. الشكل الثماني يتكون من ثمانيات المحتوى لسلسلة OCTET STRING الخاصة بـ privateKey في بنية ECPrivateKey ASN.1.

يجب تزويد الدالة EC_KEY_priv2oct() بمخزن طويل بما يكفي لتخزين الشكل الثماني. قيمة الإرجاع توفر عدد الثمانيات المخزنة. استدعاء الدالة بمخزن NULL لن يُجري التحويل بل سيعيد فقط طول المخزن المطلوب.

الدالة EC_KEY_priv2buf() تخصص مخزناً بطول مناسب وتكتب EC_KEY فيه بالشكل الثماني. يُكتب المخزن المخصص إلى *pbuf ويُعاد طوله. يجب على المستدعي تحرير المخزن المخصص باستدعاء OPENSSL_free(). نظراً لأن قيمة المخزن المخصص تُكتب إلى *pbuf، فإن المعامل pbuf يجب ألا يكون NULL.

EC_KEY_priv2buf() تحول مفتاحاً خاصاً لـ EC_KEY إلى مخزن مخصص.

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

EC_KEY_new_ex()، EC_KEY_new()، EC_KEY_new_by_curve_name_ex()، EC_KEY_new_by_curve_name() و EC_KEY_dup() تُرجع مؤشراً إلى كائن EC_KEY المنشأ حديثاً، أو NULL عند الخطأ.

EC_KEY_get_flags() تُرجع الأعلام المرتبطة بكائن EC_KEY كعدد صحيح.

EC_KEY_copy() تُرجع مؤشراً إلى المفتاح الوجهة، أو NULL عند الخطأ.

تُعيد EC_KEY_get0_engine() مؤشرًا إلى ENGINE، أو NULL إذا لم يُضبط.

EC_KEY_up_ref()، EC_KEY_set_group()، EC_KEY_set_public_key()، EC_KEY_precompute_mult()، EC_KEY_generate_key()، EC_KEY_check_key()، EC_KEY_set_public_key_affine_coordinates()، EC_KEY_oct2key() و EC_KEY_oct2priv() تُرجع 1 عند النجاح أو 0 عند الخطأ.

EC_KEY_set_private_key() تُرجع 1 عند النجاح أو 0 عند الخطأ باستثناء عندما تكون وسيطة priv_key NULL، في تلك الحالة تُرجع 0، للتوافق القديم، ولا ينبغي معاملتها كخطأ.

EC_KEY_get0_group() تُرجع EC_GROUP المرتبط بـ EC_KEY.

EC_KEY_get0_private_key() تُرجع المفتاح الخاص المرتبط بـ EC_KEY.

EC_KEY_get_conv_form() تُرجع point_conversion_form لـ EC_KEY.

EC_KEY_key2buf()، EC_KEY_priv2oct() و EC_KEY_priv2buf() تُرجع طول المخزن أو 0 عند الخطأ.

انظر أيضًا

EVP_PKEY_Q_keygen(3) crypto(7), EC_GROUP_new(3), EC_GROUP_copy(3), EC_POINT_new(3), EC_POINT_add(3), EC_GFp_simple_method(3), d2i_ECPKParameters(3), OSSL_LIB_CTX(3)

التاريخ

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

حقوق النسخ

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