table of contents
- unstable 4.31.0-1
| BIO_F_MD(3SSL) | OpenSSL | BIO_F_MD(3SSL) |
الاسم¶
BIO_f_md, BIO_set_md, BIO_get_md, BIO_get_md_ctx - مرشح BIO لملخص الرسالة
موجز¶
#include <openssl/bio.h> #include <openssl/evp.h> const BIO_METHOD *BIO_f_md(void); int BIO_set_md(BIO *b, EVP_MD *md); int BIO_get_md(BIO *b, EVP_MD **mdp); int BIO_get_md_ctx(BIO *b, EVP_MD_CTX **mdcp);
الوصف¶
BIO_f_md() تُرجع طريقة BIO لملخص الرسالة. هذا مرشح BIO يُلخّص أي بيانات تُمرّر عبره. وهو غلاف BIO لروتينات الملخص EVP_DigestInit() و EVP_DigestUpdate() و EVP_DigestFinal().
أي بيانات تُكتب أو تُقرأ عبر BIO ملخص باستخدام BIO_read_ex() و BIO_write_ex() تُلخّص.
BIO_gets()، إذا كانت معاملتها size كبيرة بما يكفي، تُنهي حساب الملخص وتُرجِع قيمة الملخص. BIO_puts() غير مدعومة.
BIO_reset() تُعيد تهيئة BIO ملخص.
BIO_set_md() تضبط ملخص الرسالة لـ BIO b إلى md: يجب استدعاء هذه الدالة لتهيئة BIO ملخص قبل تمرير أي بيانات عبره. وهي ماكرو BIO_ctrl().
BIO_get_md() تضع مؤشرًا إلى طريقة ملخص BIO الملخص في mdp. وهي ماكرو BIO_ctrl().
BIO_get_md_ctx() تُرجِع سياق BIO الملخص إلى mdcp.
ملاحظات¶
السياق المُرجَع بواسطة BIO_get_md_ctx() يمكن استخدامه في استدعاءات EVP_DigestFinal() وكذلك روتينات التوقيع EVP_SignFinal() و EVP_VerifyFinal().
السياق المُرجَع بواسطة BIO_get_md_ctx() هو بنية سياق داخلية. التغييرات التي تُجرى على هذا السياق ستؤثر على BIO الملخص نفسه، وسيصبح مؤشر السياق غير صالح عند تحرير BIO الملخص.
بعد استرجاع الملخص من BIO ملخص، يجب إعادة تهيئته باستدعاء BIO_reset() أو BIO_set_md() قبل تمرير أي بيانات إضافية عبره.
إذا احتاج تطبيق إلى استدعاء BIO_gets() أو BIO_puts() عبر سلسلة تحتوي على BIOs ملخص، فيمكن فعل ذلك بإضافة BIO تخزين مؤقت في البداية.
استدعاء BIO_get_md_ctx() سيُرجِع السياق ويُهيئ حالة BIO. هذا يسمح للتطبيقات بتهيئة السياق خارجيًا إذا كانت الاستدعاءات القياسية مثل BIO_set_md() ليست مرنة بما يكفي.
القيم المُرجعة¶
BIO_f_md() تُرجع طريقة BIO الملخص.
BIO_set_md() و BIO_get_md() و BIO_md_ctx() تُرجِع 1 عند النجاح و <=0 عند الفشل.
أمثلة¶
المثال التالي يُنشئ سلسلة BIO تحتوي على BIO تلخيص SHA1 و MD5 ويُمرر السلسلة "Hello World" من خلالها. تم حذف التحقق من الأخطاء للتوضيح.
BIO *bio, *mdtmp; char message[] = "Hello World"; bio = BIO_new(BIO_s_null()); mdtmp = BIO_new(BIO_f_md()); BIO_set_md(mdtmp, EVP_sha1()); /* * بالنسبة لـ BIO_push() نريد إلحاق BIO المصدر والاحتفاظ بملاحظة * عن بداية السلسلة. */ bio = BIO_push(mdtmp, bio); mdtmp = BIO_new(BIO_f_md()); BIO_set_md(mdtmp, EVP_md5()); bio = BIO_push(mdtmp, bio); /* ملاحظة: يمكن الآن التخلص من mdtmp */ BIO_write(bio, message, strlen(message));
المثال التالي يُلخص البيانات بالقراءة عبر سلسلة بدلاً من ذلك:
BIO *bio, *mdtmp;
char buf[1024];
int rdlen;
bio = BIO_new_file(file, "rb");
mdtmp = BIO_new(BIO_f_md());
BIO_set_md(mdtmp, EVP_sha1());
bio = BIO_push(mdtmp, bio);
mdtmp = BIO_new(BIO_f_md());
BIO_set_md(mdtmp, EVP_md5());
bio = BIO_push(mdtmp, bio);
do {
rdlen = BIO_read(bio, buf, sizeof(buf));
/* قد يُراد فعل شيء مع البيانات هنا */
} while (rdlen > 0);
المثال التالي يسترجع تلاخيص الرسائل من سلسلة BIO ويُخرجها. يمكن استخدام هذا مع الأمثلة أعلاه.
BIO *mdtmp;
unsigned char mdbuf[EVP_MAX_MD_SIZE];
int mdlen;
int i;
mdtmp = bio; /* افترض أن bio قد وُضعت مسبقًا */
do {
EVP_MD *md;
mdtmp = BIO_find_type(mdtmp, BIO_TYPE_MD);
if (!mdtmp)
break;
BIO_get_md(mdtmp, &md);
printf("%s digest", OBJ_nid2sn(EVP_MD_get_type(md)));
mdlen = BIO_gets(mdtmp, mdbuf, EVP_MAX_MD_SIZE);
for (i = 0; i < mdlen; i++) printf(":%02X", mdbuf[i]);
printf("\n");
mdtmp = BIO_next(mdtmp);
} while (mdtmp);
BIO_free_all(bio);
العلل¶
نقص الدعم لـ BIO_puts() والسلوك غير القياسي لـ BIO_gets() قد يُعتبر شاذًا. يمكن القول إن BIO_gets() و BIO_puts() يجب أن يُمررا إلى BIO التالي في السلسلة ويُلخصا البيانات المارة، وأن التلاخيص يجب أن تُسترجع باستخدام استدعاء منفصل لـ BIO_ctrl().
التاريخ¶
قبل OpenSSL 1.0.0، كان استدعاء BIO_get_md_ctx() يعمل فقط إذا وُهيئ BIO أولاً.
حقوق النسخ¶
حقوق النشر 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 |