إذا أنشأت واجهة مستخدم للنص البرمجي، يمكنك نشر النص البرمجي كتطبيق ويب. على سبيل المثال، من الأفضل عرض النص البرمجي الذي يسمح للمستخدمين بجدولة المواعيد مع أعضاء فريق الدعم في شكل تطبيق ويب لكي يتمكّن المستخدمون من الوصول إليه مباشرةً من خلال المتصفّحات.
يمكن تحويل كلٍّ من النصوص البرمجية المستقلة والنصوص البرمجية المرتبطة Google Workspace بالتطبيقات إلى تطبيقات ويب، شرط أن تستوفي المتطلبات الواردة أدناه.
متطلبات تطبيقات الويب
يمكن نشر نص برمجي كتطبيق ويب إذا كان يستوفي المتطلبات التالية:
- يحتوي على دالة
doGet(e)
أوdoPost(e)
. - تُعرِض الدالة عنصر خدمة HTML
HtmlOutput
أو عنصر خدمة محتوىTextOutput
.
مَعلمات الطلب
عندما يزور مستخدم تطبيقًا أو يرسل برنامج طلب HTTP GET
إلى التطبيق،
تُنفِّذ Apps Script الدالة doGet(e)
. عندما يرسل برنامج إلى التطبيق طلب HTTP
POST
، ستعمل Apps Script على تنفيذ doPost(e)
بدلاً من ذلك. في كلتا الحالتَين، تمثّل الوسيطة e
مَعلمة حدث يمكن أن تحتوي على معلومات عن أي
مَعلمات طلب. تظهر بنية عنصر الحدث في الجدول أدناه:
الحقول | |
---|---|
e.queryString |
قيمة جزء سلسلة طلب البحث من عنوان URL، أو name=alice&n=1&n=2 |
e.parameter |
عنصر يتضمّن أزواج مفتاح/قيمة تتوافق مع مَعلمات الطلب يتم عرض القيمة الأولى فقط للمعلمات التي تحتوي على قيم متعددة. {"name": "alice", "n": "1"} |
e.parameters |
عنصر مشابه لـ {"name": ["alice"], "n": ["1", "2"]} |
e.pathInfo |
مسار عنوان URL بعد |
e.contextPath |
لا يتم استخدامها، وتكون السلسلة الفارغة دائمًا. |
e.contentLength |
طول محتوى الطلب لطلبات POST أو 332 |
e.postData.length |
هذه القيمة تساوي 332 |
e.postData.type |
نوع MIME لنص POST text/csv |
e.postData.contents |
نص محتوى محتوى POST Alice,21 |
e.postData.name |
القيمة "postData" دائمًا postData |
على سبيل المثال، يمكنك تمرير مَعلمات مثل username
وage
إلى عنوان URL كما هو موضّح أدناه:
https://script.google.com/.../exec?username=jsmith&age=21
بعد ذلك، يمكنك عرض المعلمات كما يلي:
function doGet(e) {
var params = JSON.stringify(e);
return ContentService.createTextOutput(params).setMimeType(ContentService.MimeType.JSON);
}
في المثال أعلاه، تعرض doGet(e)
النتيجة التالية:
{
"queryString": "username=jsmith&age=21",
"parameter": {
"username": "jsmith",
"age": "21"
},
"contextPath": "",
"parameters": {
"username": [
"jsmith"
],
"age": [
"21"
]
},
"contentLength": -1
}
نشر نص برمجي كتطبيق ويب
لنشر نص برمجي كتطبيق ويب، اتّبِع الخطوات التالية:
- في أعلى يسار مشروع النصوص البرمجية، انقر على نشر > نشر جديد.
- بجانب "اختيار النوع"، انقر على "تفعيل أنواع النشر" > تطبيق الويب.
- أدخِل المعلومات عن تطبيق الويب في الحقول ضمن "إعدادات النشر".
- انقر على نشر.
يمكنك مشاركة عنوان URL لتطبيق الويب مع المستخدمين الذين تريد أن يستخدموا تطبيقك، شرط أن تكون قد منحت هؤلاء المستخدمين الإذن بالوصول إلى التطبيق.
اختبار عملية نشر تطبيق ويب
لاختبار النص البرمجي كتطبيق ويب، اتّبِع الخطوات التالية:
- في أعلى يسار مشروع النصوص البرمجية، انقر على نشر > اختبار عمليات النشر.
- بجانب "اختيار النوع"، انقر على تفعيل أنواع عمليات النشر > تطبيق ويب.
- ضمن عنوان URL لتطبيق الويب، انقر على نسخ.
الصِق عنوان URL في المتصفّح واختَبر تطبيق الويب.
ينتهي عنوان URL هذا بـ
/dev
ولا يمكن الوصول إليه إلا للمستخدمين الذين لديهم الإذن بتعديل النص البرمجي. دائمًا ما يشغل هذا المثيل من التطبيق أحدث رمز تم حفظه وهو مخصص للاختبار فقط أثناء التطوير.
الأذونات
تختلف أذونات تطبيق الويب وفقًا للطريقة التي تختارها لتنفيذ التطبيق:
- تنفيذ التطبيق بالنيابة عني: في هذه الحالة، يتم تنفيذ النص البرمجي دائمًا بصفتك مالك النص البرمجي، بغض النظر عمن يصل إلى تطبيق الويب.
- تنفيذ التطبيق بصفتك المستخدم الذي يصل إلى التطبيق المتوافق مع الويب: في هذه الحالة، يتم تنفيذ النص البرمجي باستخدام هوية المستخدم النشط الذي يستخدم التطبيق المتوافق مع الويب. يؤدي أسلوب إذن الولوج هذا إلى عرض التطبيق المتوافق مع الويب لعنوان البريد الإلكتروني الخاص بمالك النص البرمجي عندما يمنح المستخدم الإذن بالوصول.
تضمين تطبيق الويب في "مواقع Google"
لتضمين تطبيق ويب في "مواقع Google"، يجب أن يتم نشره أولاً. ستحتاج أيضًا
إلى عنوان URL المنشور من مربّع حوار Deploy
.
لتضمين تطبيق ويب في صفحة مواقع Google، اتّبِع الخطوات التالية:
- افتح صفحة "مواقع Google" التي تريد إضافة تطبيق الويب إليها.
- اختَر إدراج > تضمين عنوان URL.
- الصِق عنوان URL لتطبيق الويب، ثم انقر على إضافة.
يظهر تطبيق الويب في إطار في معاينة الصفحة. عند نشر الصفحة، قد يحتاج زوّار موقعك الإلكتروني إلى تفويض تطبيق الويب قبل أن يتم تنفيذه بشكلٍ طبيعي. تعرِض تطبيقات الويب غير المصرَّح بها طلبات تفويض للمستخدم.
تطبيقات الويب وسجلّ المتصفّح
قد يكون من المستحسن استخدام تطبيق ويب "برمجة تطبيقات Google" يحاكي تطبيقًا متعدد الصفحات، أو تطبيق واجهة مستخدم ديناميكية يتم التحكم فيها من خلال مَعلمات عناوين URL. ولإجراء ذلك بشكل جيد، يمكنك تحديد عنصر حالة يمثّل واجهة المستخدم أو الصفحة الخاصة بالتطبيق، ثم إضافة الحالة إلى سجلّ المتصفّح أثناء تنقّل المستخدم في التطبيق. ويمكنك أيضًا الاستماع إلى أحداث السجلّ لكي يعرض تطبيق الويب واجهة المستخدم الصحيحة عندما يتنقل ذهابًا وإيابًا باستخدام أزرار المتصفح. من خلال طلب معلمات عنوان URL في وقت التحميل، يمكنك جعل تطبيقك ينشئ واجهة المستخدم ديناميكيًا استنادًا إلى هذه المَعلمات، ما يسمح للمستخدم ب بدء التطبيق في حالة معيّنة.
توفّر "برمجة تطبيقات Google" واجهتَي برمجة تطبيقات JavaScript غير متزامنتَين من جهة العميل للمساعدة في إنشاء تطبيقات ويب مرتبطة بسجلّ المتصفّح:
google.script.history
يوفّر طرقًا للسماح بالاستجابة الديناميكية لتغييرات سجلّ المتصفّح. يشمل ذلك ما يلي: دفع الحالات (كائنات بسيطة يمكنك تحديدها) في سجلّ المتصفّح، واستبدال الحالة العليا في حزمة السجلّ، وإعداد وظيفة استدعاء أداة استماع للاستجابة للتغييرات في السجلّ.يوفّر
google.script.url
الوسائل لاسترداد مَعلمات عنوان URL للصفحة الحالية وجزء عنوان URL، في حال توفّرهما.
لا تتوفّر واجهات برمجة التطبيقات هذه للسجلّ إلّا لتطبيقات الويب. ولا يمكن استخدامها في الأشرطة الجانبية أو مربّعات الحوار أو الإضافات. ولا يُنصح أيضًا باستخدام هذه الوظيفة في تطبيقات الويب المضمّنة في "مواقع Google".