مواقع أفضل
تم تصميم FastSitePHP من أجل الأداء السريع ، ومرونة الترميز ، والاستقرار على المدى الطويل ، وسهولة الاستخدام ، وتجربة تطوير شاملة أفضل. باستخدام FastSitePHP ، يمكنك إنشاء مواقع أفضل بشكل أسرع من أي وقت مضى.
تم تصميم FastSitePHP من أجل الأداء السريع ، ومرونة الترميز ، والاستقرار على المدى الطويل ، وسهولة الاستخدام ، وتجربة تطوير شاملة أفضل. باستخدام FastSitePHP ، يمكنك إنشاء مواقع أفضل بشكل أسرع من أي وقت مضى.
مع FastSitePHP يمكن إنشاء صفحات معقدة في غضون آلاف من الثانية باستخدام كمية صغيرة فقط من الذاكرة.يتيح هذا المستوى من الأداء حتى تشغيل المواقع بسرعة على أجهزة الكمبيوتر منخفضة الطاقة.
تم تصميم FastSitePHP بحيث يسهل الإعداد على أي نظام تشغيل ، وسهل قراءة الكود ، وسهل التطوير ، والمزيد.مع FastSitePHP ، يمكن تطوير مواقع الويب والتطبيقات عالية الجودة بوتيرة سريعة باستخدام عدد أقل من سطور التعليمات البرمجية والحد الأدنى من التهيئة.
تم توثيق FastSitePHP جيدًا ويأتي مع عينات عملية.يوفر FastSitePHP رسائل خطأ سهلة للمطور بحيث يمكن إصلاح الأخطاء بسرعة حتى إذا لم يكن لديك أي خبرة في البرمجة باستخدام PHP.
تم التخطيط للأمان بعناية في جميع ميزات FastSitePHP بحيث تكون آمنة وسهلة الاستخدام.تشمل ميزات الأمان التشفير (النص ، الكائنات ، والملفات) ، ملفات تعريف الارتباط الموقعة ، JWT ، CORS ، التحقق من خادم الوكيل ، تحديد الأسعار ، وأكثر من ذلك.
يتم اختبار معظم الأطر من جهاز كمبيوتر مطور باستخدام أدوات CLI الخاصة ؛لكن هذا لا يضمن أنه سيعمل في بيئتك.يوفر FastSitePHP's طريقة تعتمد على الويب للاختبار بحيث يمكن تأكيد جميع الشفرات وسرعة الصفحة بسهولة في أي بيئة.
<?php
// -------------------------------
// اقامة
// -------------------------------
// إعداد PHP Autoloader
// هذا يسمح ليتم تحميل الفئات بشكل ديناميكي
require '../vendor/autoload.php';
// أو بالنسبة لموقع الحد الأدنى ، يجب تضمين الملفين التاليين فقط
// require '../vendor/fastsitephp/src/Application.php';
// require '../vendor/fastsitephp/src/Route.php';
// إنشاء كائن التطبيق مع معالجة الأخطاء و UTC للمنطقة الزمنية
$app = new \FastSitePHP\Application();
$app->setup('UTC');
// -------------------------------
// تحديد الطرق
// -------------------------------
// أرسل ردًا من "مرحبا بالعالم!" للطلبات الافتراضية
$app->get('/', function() {
return 'مرحبا بالعالم!';
});
// Send a response 'Hello World!' for the URL '/hello' or in the case of the
// optional [name] variable safely escape and return a message with the name
// (example: '/hello/FastSitePHP' will output 'Hello FastSitePHP!')
$app->get('/hello/:name?', function($name = 'World') use ($app) {
return 'Hello ' . $app->escape($name) . '!';
});
// إرسال استجابة JSON التي تحتوي على كائن مع معلومات الموقع الأساسية
$app->get('/site', function() use ($app) {
return [
'rootUrl' => $app->rootUrl(),
'rootDir' => $app->rootDir(),
'requestedPath' => $app->requestedPath(),
];
});
// إرسال استجابة JSON تحتوي على معلومات الطلب الأساسية
$app->get('/request', function() {
$req = new \FastSitePHP\Web\Request();
return [
'acceptEncoding' => $req->acceptEncoding(),
'acceptLanguage' => $req->acceptLanguage(),
'origin' => $req->origin(),
'userAgent' => $req->userAgent(),
'referrer' => $req->referrer(),
'clientIp' => $req->clientIp(),
'protocol' => $req->protocol(),
'host' => $req->host(),
'port' => $req->port(),
];
});
// Send the contents of this file as a plain text response using
// HTTP Response Headers that allow for the end user to cache the
// page until the file is modified
$app->get('/cached-file', function() {
$file_path = __FILE__;
$res = new \FastSitePHP\Web\Response();
return $res->file($file_path, 'text', 'etag:md5', 'private');
});
// Return the user's IP Address as a JSON Web Service that supports
// Cross-Origin Resource Sharing (CORS) and specifically tells the browser
// to not cache the results. In this example the Web Server is assumed to
// be behind a proxy server (for example a Load Balancer) and the IP Address
// is safely read from it. Additionally the cors() function is called from a
// filter function which only gets called if the route is matched and allows
// for correct handling of an OPTIONS request.
$app->get('/whats-my-ip', function() {
$req = new \FastSitePHP\Web\Request();
return [
'ipAddress' => $req->clientIp('from proxy', 'trust local'),
];
})
->filter(function() use ($app) {
$app
->noCache()
->cors('*');
});
// Define a function that returns true if the web request is coming
// from a local network (for example 127.0.0.1 or 10.0.0.1). This
// function will be used in a filter to show or hide routes.
$is_local = function() {
// Compare Request IP using Classless Inter-Domain Routing (CIDR)
$req = new \FastSitePHP\Web\Request();
$private_ips = \FastSitePHP\Net\IP::privateNetworkAddresses();
return \FastSitePHP\Net\IP::cidr(
$private_ips,
$req->clientIp('from proxy')
);
};
// Provide detailed environment info from PHP for users requesting the page
// from a local network. If the request is coming from someone on the internet
// then a 404 Response 'Page not found' would be returned. Calling [phpinfo()]
// outputs an HTML response so the route does not need to return anything.
$app->get('/phpinfo', function() {
phpinfo();
})
->filter($is_local);
// توفير استجابة نصية مع معلومات الخادم للمستخدمين المحليين
$app->get('/server', function() {
$config = new \FastSitePHP\Net\Config();
$req = new \FastSitePHP\Web\Request();
$res = new \FastSitePHP\Web\Response();
return $res
->contentType('text')
->content(implode("\n", [
"Host: {$config->fqdn()}",
"Server IP: {$req->serverIp()}",
"Network IP: {$config->networkIp()}",
str_repeat('-', 80),
$config->networkInfo(),
]));
})
->filter($is_local);
// If the requested url starts with '/examples' then load a PHP file for
// the matching routes from the current directory. This is a real file
// that provides many more examples. If you download this site, this code
// and other examples can be found in [app_data/sample-code].
$app->mount('/examples', 'home-page-en-examples.php');
// -------------------------------
// قم بتشغيل التطبيق
// -------------------------------
$app->run();