• شنبه, 08 دی 1403
  • آموزش برنامه نویسی جوملا

طراحی ماژول اپلود تصاویر با اجاکس و بوت استراپ

در اینجا به طور مختصر مراحل ایجاد ماژول جوملا برای آپلود تصویر با استفاده از PHP و AJAX را شرح می‌دهم. برای سادگی، ما ابتدا یک ماژول ساده ایجاد می‌کنیم که فرم آپلود تصویر را در آن قرار دهیم. مراحل ایجاد یک ماژول جوملا برای آپلود تصویر ساخت ساختار فایل‌های ماژول برای ایجاد یک ماژول، باید یک دایرکتوری در پوشه modules ایجاد کنید و سپس فایل‌های لازم را در آن قرار دهید. به مسیر زیر بروید: /modules/mod_imageupload ساخت فایل‌های مورد نیاز: در پوشه mod_imageupload، چند فایل اصلی خواهیم داشت: mod_imageupload.php (فایل اصلی ماژول) helper.php (برای کدهای کمکی و پردازش) tmpl/default.php (نمایش فرم آپلود و پروگرس بار) mod_imageupload.xml (فایل نصب و تنظیمات ماژول) 1. فایل mod_imageupload.php: این فایل عملکرد اصلی ماژول را بر عهده دارد. در آن فرم آپلود به همراه پردازش‌ها را قرار می‌دهیم. <?php // دسترسی مستقیم به فایل ممنوع است defined('_JEXEC') or die; // شامل فایل helper require_once dirname(__FILE__) . '/helper.php'; // دریافت خروجی از helper $uploadForm = modImageUploadHelper::getUploadForm(); require JModuleHelper::getLayoutPath('mod_imageupload'); 2. فایل helper.php: در این فایل، می‌توانید منطق پردازش فایل را بنویسید، مثلا بررسی فایل و آپلود آن. برای این‌که کار با این ماژول راحت‌تر باشد، همه کدهای اصلی آپلود را در اینجا قرار می‌دهیم. <?php // دسترسی مستقیم به فایل ممنوع است defined('_JEXEC') or die; class modImageUploadHelper { public static function getUploadForm() { // بررسی ارسال فایل و آپلود if ($_SERVER['REQUEST_METHOD'] == 'POST' && isset($_FILES['image'])) { $uploadDir = JPATH_ROOT . '/images/uploads/'; $maxFileSize = 5 * 1024 * 1024; // حداکثر حجم فایل 5MB $allowedTypes = ['image/jpeg', 'image/png', 'image/gif']; $file = $_FILES['image']; // بررسی نوع فایل if (!in_array($file['type'], $allowedTypes)) { return 'فرمت فایل مجاز نیست.'; } // بررسی اندازه فایل if ($file['size'] > $maxFileSize) { return 'حجم فایل بیش از حد مجاز است.'; } // ساخت نام تصادفی برای فایل $fileName = uniqid('img_') . '.' . pathinfo($file['name'], PATHINFO_EXTENSION); $uploadPath = $uploadDir . $fileName; // انتقال فایل به پوشه مقصد if (move_uploaded_file($file['tmp_name'], $uploadPath)) { return 'فایل با موفقیت آپلود شد!'; } else { return 'خطا در آپلود فایل!'; } } // اگر فایل آپلود نشد، فرم را باز می‌گرداند return null; } } 3. فایل tmpl/default.php: در اینجا فرم HTML و کد AJAX را قرار می‌دهیم. این کد مشابه همان کدی است که قبلاً برای آپلود تصویر طراحی کرده بودیم، اما در قالب ماژول جوملا. <?php // دسترسی مستقیم به فایل ممنوع است defined('_JEXEC') or die; ?> <div class="container mt-5"> <h2 class="text-center mb-4">فرم آپلود تصویر</h2> <!-- نمایش پیغام آپلود --> <?php if ($uploadForm): ?> <div class="alert alert-info"><?php echo $uploadForm; ?></div> <?php endif; ?> <!-- فرم آپلود --> <form id="uploadForm" enctype="multipart/form-data" method="POST"> <div class="mb-3"> <label for="name" class="form-label">نام و نام خانوادگی:</label> <input type="text" class="form-control" id="name" name="name" required> </div> <div class="mb-3"> <label for="image" class="form-label">انتخاب تصویر:</label> <input type="file" class="form-control" id="image" name="image" accept="image/*" required> </div> <button type="submit" class="btn btn-primary">ارسال</button> </form> <!-- نمایش پروگرس بار --> <div id="progressWrapper" style="display: none;"> <p>در حال آپلود: <span id="progressText">0%</span></p> <div id="progressBar" class="progress"> <div id="progress" class="progress-bar" role="progressbar" style="width: 0;"></div> </div> </div> </div> <!-- اسکریپت‌های جاوااسکریپت --> <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script> <script> $(document).ready(function() { $("#uploadForm").submit(function(event) { event.preventDefault(); // نمایش پروگرس بار $("#progressWrapper").show(); var formData = new FormData(this); $.ajax({ url: "<?php echo JURI::root() . 'modules/mod_imageupload/helper.php'; ?>", // مسیر پردازش فایل type: "POST", data: formData, contentType: false, processData: false, xhr: function() { var xhr = new XMLHttpRequest(); xhr.upload.addEventListener("progress", function(e) { if (e.lengthComputable) { var percent = (e.loaded / e.total) * 100; $("#progress").width(percent + "%"); $("#progressText").text(Math.round(percent) + "%"); } }); return xhr; }, success: function(response) { alert("آپلود با موفقیت انجام شد!"); console.log(response); $("#progressWrapper").hide(); }, error: function(xhr, status, error) { alert("خطا در آپلود فایل!"); $("#progressWrapper").hide(); } }); }); }); </script> 4. فایل mod_imageupload.xml: این فایل، فایل نصب و پیکربندی ماژول است که برای نصب ماژول در جوملا استفاده می‌شود. <?xml version="1.0" encoding="utf-8"?> <extension type="module" version="4.0" method="upgrade"> <name>mod_imageupload</name> <author>نام شما</author> <creationDate>2024-12-28</creationDate> <copyright>کپی‌رایت</copyright> <license>GPLv2 or later</license> <version>1.0.0</version> <description>ماژول آپلود تصویر</description> <files> <file plugin="mod_imageupload">mod_imageupload.php</file> <file>helper.php</file> <folder>tmpl</folder> </files> <languages> <language tag="en-GB">language/en-GB/en-GB.mod_imageupload.ini</language> <language tag="fa-IR">language/fa-IR/fa-IR.mod_imageupload.ini</language> </languages> </extension> 5. نصب و استفاده از ماژول در جوملا ماژول را با استفاده از فایل XML در بخش Extension Manager در جوملا نصب کنید. پس از نصب، ماژول را از بخش Module Manager فعال کرده و به یک موقعیت (Position) مناسب در قالب جوملا خود متصل کنید. توضیحات: این ماژول فرم آپلود را در هر موقعیتی که به آن وصل شود نمایش می‌دهد. فایل‌ها در مسیر images/uploads/ ذخیره می‌شوند. شما می‌توانید این مسیر را متناسب با نیاز خود تغییر دهید. برای حفظ امنیت، حتماً بررسی‌هایی مانند محدودیت نوع فایل و اندازه فایل‌ها انجام می‌دهیم. این مراحل به شما کمک می‌کند که یک ماژول ساده برای آپلود تصویر در جوملا ۵ ایجاد کنید.

ادامه مطلب
  • سه شنبه, 13 آذر 1403
  • آموزش برنامه نویسی جوملا

یک کامپوننت جوملا با استفاده از PHP و MySQL بسازید.

 کامپوننت‌های جوملا معمولاً شامل فایل‌ها و ساختار خاصی هستند که باید رعایت شوند. در اینجا یک راهنمای کلی برای ساخت یک کامپوننت ساده جوملا با استفاده از PHP و MySQL آورده شده است. مراحل ساخت کامپوننت جوملا: ساخت پوشه کامپوننت: کامپوننت‌های جوملا در پوشه components قرار می‌گیرند. پوشه کامپوننت خود را در مسیر components/com_yourcomponent ایجاد کنید. ساخت فایل XML: این فایل تنظیمات و متا‌داده کامپوننت را تعریف می‌کند. در این فایل اطلاعاتی مانند نام کامپوننت، نسخه، فایل‌های مورد نیاز و دسترسی‌ها قرار می‌گیرد. فایل XML باید با نام yourcomponent.xml باشد و در پوشه اصلی کامپوننت قرار گیرد. نمونه فایل yourcomponent.xml: <extension type="component" version="3.9" client="site"> <name>Your Component</name> <author>Your Name</author> <description>Describe your component here</description> <files> <folder>models</folder> <folder>views</folder> <folder>controllers</folder> <file type="administration" name="yourcomponent.php">yourcomponent.php</file> <file name="controller.php">controller.php</file> <file name="helper.php">helper.php</file> <file name="view.html.php">view.html.php</file> </files> <administration> <menu>yourcomponent</menu> </administration> </extension> ساخت فایل‌های PHP اصلی: شما به حداقل ۴ فایل برای کامپوننت نیاز دارید: yourcomponent.php: این فایل اصلی است که برای بارگذاری کامپوننت استفاده می‌شود. controller.php: برای کنترل عملیات مربوط به کامپوننت. helper.php: برای نگهداری توابع کمکی (مثلاً اتصال به دیتابیس). view.html.php: برای نمایش نتایج یا داده‌ها. فایل‌های PHP و توضیحات: 1. yourcomponent.php (این فایل برای بارگذاری کامپوننت استفاده می‌شود): <?php defined('_JEXEC') or die('Restricted access'); // Load the controller $controller = JControllerLegacy::getInstance('YourComponent'); $controller->execute(JRequest::getCmd('task')); $controller->redirect(); 2. controller.php: <?php defined('_JEXEC') or die; class YourComponentController extends JControllerLegacy { public function display($cachable = false, $urlparams = false) { parent::display($cachable, $urlparams); } public function addItem() { // Connect to the database and insert an item $model = $this->getModel('Item'); $model->addItem(); $this->setRedirect(JRoute::_('index.php?option=com_yourcomponent', false)); } } 3. helper.php (برای اتصال به دیتابیس و انجام عملیات): <?php defined('_JEXEC') or die; class YourComponentHelper { public static function addItemToDatabase($data) { $db = JFactory::getDbo(); $query = $db->getQuery(true) ->insert($db->quoteName('#__yourcomponent_items')) ->columns($db->quoteName(array('name', 'description'))) ->values($db->quote($data['name']) . ',' . $db->quote($data['description'])); $db->setQuery($query); $db->execute(); } } 4. view.html.php (برای نمایش داده‌ها): <?php defined('_JEXEC') or die; class YourComponentViewYourComponent extends JViewLegacy { public function display($tpl = null) { // Get data from model $model = $this->getModel(); $items = $model->getItems(); // Assign data to the view $this->assignRef('items', $items); parent::display($tpl); } } 5. model.php (برای دریافت داده‌ها از دیتابیس): <?php defined('_JEXEC') or die; class YourComponentModelYourComponent extends JModelLegacy { public function getItems() { $db = JFactory::getDbo(); $query = $db->getQuery(true) ->select('*') ->from($db->quoteName('#__yourcomponent_items')); $db->setQuery($query); return $db->loadObjectList(); } } 6. قابلیت نصب و استفاده از کامپوننت: بعد از آماده‌سازی فایل‌های کامپوننت، می‌توانید آن را به صورت یک بسته ZIP فشرده کنید و در بخش مدیریت جوملا (Install Extension) نصب کنید. نکات و پیشنهادات: امنیت: حتماً از توابع آماده جوملا (مثل JFactory::getDbo() برای دسترسی به دیتابیس و JRequest::getVar() برای دریافت ورودی‌ها) استفاده کنید تا از حملات SQL Injection و Cross-Site Scripting (XSS) جلوگیری شود. جداسازی کدها: بهتر است مدل، ویو و کنترلر را به صورت جداگانه ایجاد کنید تا کدهای شما تمیزتر و قابل نگهداری‌تر باشند. گزارش خطا: برای اشکال‌زدایی و گزارش خطاها از قابلیت‌های گزارش‌گیری جوملا استفاده کنید.

ادامه مطلب
  • سه شنبه, 13 آذر 1403
  • آموزش برنامه نویسی جوملا

مراحل ساخت فایل ZIP قابل نصب در Joomla

می خواهم  گام‌به‌گام آموزش بدهم که چطور یک کد را به صورت دستی در یک فایل ZIP فشرده کنید تا بتوانید آن را در Joomla نصب کنید. مراحل ساخت فایل ZIP قابل نصب در Joomla: ایجاد ساختار دایرکتوری: ابتدا باید ساختار پوشه‌ها و فایل‌های کامپوننت را مطابق با ساختار زیر بسازید: /com_chat_ai/ /admin/ /controllers/ chat.php /models/ chat.php /views/ /chat/ view.html.php tmpl/ default.php /languages/ en-GB.com_chat_ai.ini /site/ /controllers/ chat.php /models/ chat.php /views/ /chat/ view.html.php tmpl/ default.php /media/ com_chat_ai.xml index.php ایجاد فایل‌های PHP و XML: شما باید هر یک از فایل‌های PHP و XML که در کد قبلی ذکر شد را در پوشه‌های مربوطه ایجاد کنید. برای مثال: com_chat_ai.xml: پیکربندی کامپوننت chat.php: فایل‌های کنترلر و مدل view.html.php و default.php: فایل‌های نمایشی ایجاد فایل زبان (اختیاری): شما می‌توانید یک فایل زبان ساده برای جوملا ایجاد کنید. این فایل معمولاً شامل متغیرهای متنی است که در کامپوننت استفاده می‌شود. فایل en-GB.com_chat_ai.ini می‌تواند به این صورت باشد: COM_CHAT_AI="Chat AI" COM_CHAT_AI_SEND_MESSAGE="Send Message" ایجاد فایل index.php: در پوشه اصلی com_chat_ai باید یک فایل index.php ایجاد کنید که برای جلوگیری از دسترسی مستقیم به پوشه‌ها مورد استفاده قرار می‌گیرد. این فایل می‌تواند بسیار ساده باشد و فقط شامل کد زیر باشد: <?php // No direct access defined('_JEXEC') or die; فشرده‌سازی پوشه: پس از ایجاد تمامی فایل‌ها و ساختار پوشه‌ها، حالا باید پوشه com_chat_ai را به یک فایل ZIP فشرده کنید. ابتدا پوشه com_chat_ai را انتخاب کنید. روی آن راست‌کلیک کرده و گزینه Send to > Compressed (zipped) folder را انتخاب کنید. یک فایل ZIP ایجاد می‌شود که می‌توانید آن را در بخش مدیریت افزونه‌ها در Joomla نصب کنید. نصب در Joomla: به مدیریت افزونه‌ها بروید. گزینه نصب را انتخاب کنید. فایل ZIP که ساخته‌اید را بارگذاری کنید. پس از نصب موفق، کامپوننت باید در منوی مدیریت جوملا در دسترس باشد. جمع‌بندی: با انجام مراحل بالا، می‌توانید کامپوننت خود را در Joomla به صورت یک فایل ZIP ایجاد کرده و آن را نصب کنید. اگر همه چیز درست پیش برود، شما یک کامپوننت چت با هوش مصنوعی در جوملا خواهید داشت که می‌توانید آن را از طریق پنل کاربری استفاده کنید!

ادامه مطلب
  • سه شنبه, 13 آذر 1403
  • آموزش برنامه نویسی جوملا

ساخت کامپوننت چت با هوش مصنوعی برای جوملا ۵

ساخت یک کامپوننت چت با هوش مصنوعی برای جوملا 5 (Joomla 5) می‌تواند به صورت مراحل مختلف انجام شود. در اینجا به طور کلی روند ساخت این نوع کامپوننت توضیح داده می‌شود. در نظر داشته باشید که جوملا یک CMS (سیستم مدیریت محتوای) متن باز است و به راحتی می‌توان آن را برای افزودن قابلیت‌های مختلف گسترش داد. مراحل ساخت کامپوننت چت با هوش مصنوعی برای جوملا 5 1. بررسی الزامات پروژه هوش مصنوعی: می‌توانید از سرویس‌هایی مثل OpenAI (GPT-3 یا GPT-4)، Dialogflow، IBM Watson یا هر API هوش مصنوعی دیگر برای پردازش داده‌ها استفاده کنید. پلتفرم چت: شما باید یک سیستم چت با رابط کاربری ساده برای تعامل با کاربران داشته باشید. اینترنت و اتصال API: برای ارتباط با مدل هوش مصنوعی، به اینترنت و یک اتصال API نیاز دارید. 2. ایجاد یک کامپوننت جوملا ابتدا باید یک کامپوننت برای جوملا ایجاد کنید که کاربر بتواند با آن تعامل داشته باشد. ساخت کامپوننت در جوملا نیاز به دانش PHP و نحوه تعامل با API دارد. الف. ایجاد ساختار کامپوننت: برای ساخت یک کامپوننت در جوملا، از ساختار زیر استفاده کنید: components/com_yourchat/ admin/ - قسمت مدیریت کامپوننت site/ - قسمت عمومی و نمایش چت models/, views/, controllers/ - معماری MVC جوملا ب. فایل‌های اصلی: com_yourchat.php: فایل اصلی کامپوننت که در آن ساختار کلی کامپوننت قرار می‌گیرد. yourchat.php: این فایل برای نمایش چت استفاده می‌شود. controller.php: این فایل برای مدیریت درخواست‌ها از کاربر و ارسال آن‌ها به API هوش مصنوعی است. 3. ساخت رابط چت در قسمت Frontend (بخش سایت) در این بخش، شما باید یک چت UI (رابط کاربری) برای کاربران طراحی کنید که به راحتی با آن تعامل داشته باشند. الف. استفاده از HTML و JavaScript برای چت: در بخش views کامپوننت، یک فایل HTML برای نمایش چت ایجاد کنید: <div id="chat-box"> <div id="chat-window"></div> <input type="text" id="chat-input" placeholder="پیام خود را وارد کنید..." /> <button id="send-btn">ارسال</button> </div> <script> document.getElementById('send-btn').addEventListener('click', function() { const message = document.getElementById('chat-input').value; if (message) { sendMessage(message); } }); function sendMessage(message) { // ارسال پیام به سرور (API جوملا) fetch('/index.php?option=com_yourchat&task=chat.sendMessage', { method: 'POST', body: JSON.stringify({ message: message }), headers: { 'Content-Type': 'application/json' } }) .then(response => response.json()) .then(data => { document.getElementById('chat-window').innerHTML += `<div>${data.response}</div>`; document.getElementById('chat-input').value = ''; }); } </script> 4. اتصال به API هوش مصنوعی در قسمت مدیریت کامپوننت، شما باید به یک سرویس هوش مصنوعی متصل شوید. برای مثال، اگر از OpenAI استفاده می‌کنید، می‌توانید از کد زیر استفاده کنید: الف. ارسال درخواست به OpenAI: public function sendMessageToAI($message) { $api_key = 'your_openai_api_key'; $url = 'https://api.openai.com/v1/completions'; $data = [ 'model' => 'gpt-4', // یا مدل دیگری که استفاده می‌کنید 'messages' => [['role' => 'user', 'content' => $message]], 'max_tokens' => 150, ]; $options = [ 'http' => [ 'method' => 'POST', 'header' => "Content-Type: application/json\r\n" . "Authorization: Bearer $api_key\r\n", 'content' => json_encode($data), ], ]; $context = stream_context_create($options); $response = file_get_contents($url, false, $context); return json_decode($response, true); } ب. پردازش درخواست در کامپوننت جوملا: این متد را در کنترلر کامپوننت جوملا قرار دهید تا پیام‌های کاربران را دریافت و به OpenAI ارسال کند. پس از دریافت پاسخ، آن را به کاربر نشان دهید. 5. مدیریت پیام‌ها و ذخیره‌سازی در دیتابیس (اختیاری) شما می‌توانید پیام‌های چت را در دیتابیس جوملا ذخیره کنید تا بتوانید آن‌ها را بعداً مرور کنید. برای این کار باید یک مدل جدید برای ذخیره‌سازی پیام‌ها در دیتابیس جوملا بسازید. 6. امنیت از توکن‌های امنیتی برای جلوگیری از حملات CSRF استفاده کنید. بررسی کنید که داده‌های ورودی از کاربران به طور مناسب فیلتر شوند. 7. آزمایش و بهینه‌سازی بعد از پیاده‌سازی، باید کامپوننت خود را به خوبی آزمایش کنید تا مطمئن شوید که چت به درستی با API هوش مصنوعی ارتباط برقرار می‌کند و عملکرد صحیحی دارد. 8. نصب و راه‌اندازی در جوملا برای نصب این کامپوننت، باید یک فایل XML برای نصب جوملا ایجاد کنید که شامل تنظیمات و اطلاعات کامپوننت باشد. نتیجه‌گیری این یک راهنمای کلی برای ساخت یک کامپوننت چت با هوش مصنوعی برای جوملا 5 است. این فرآیند شامل طراحی رابط کاربری، ارتباط با API هوش مصنوعی، پردازش داده‌ها و پیاده‌سازی امنیت است.

ادامه مطلب
  • شنبه, 28 مرداد 1402
  • آموزش برنامه نویسی جوملا

افزودن دسته بندی در جوملا با php

گاهی توی یه کامپوننت نیاز هست تا شما دسته بندی بسازید ٬ روش زیر یکی از استاندارد ترین حالت های ایجاد دسته بندی در جوملاست: $category_data['id'] = 0; $category_data['parent_id'] = 0; $category_data['title'] = "my title" ; $category_data['alias'] = "my alias"; $category_data['extension'] = 'com_content'; $category_data['published'] = 1; $category_data['language'] = '*'; $category_data['params'] = array('category_layout' => '','image' => ''); $category_data['metadata'] = array('author' => '','robots' => ''); $newapp = JFactory::getApplication(); $mvcFactory = $newapp->bootComponent('com_categories')->getMVCFactory(); $catModel = $mvcFactory->createModel('Category', 'Administrator', ['ignore_request' => true]); $category_id = $catModel->save($category_data); if (!$category_id ){ throw new Exception('Can't create Category...'); }

ادامه مطلب
  • دوشنبه, 08 اسفند 1401
  • آموزش برنامه نویسی جوملا

افزودن متاتگ های دلخواه OG TAG برای جوملا

برای افزودن تگ دلخواه OG میتوانید از کد های زیر در قالب یا در کامپوننت های اختصاصی استفاده کنید.   $doc = JFactory::getDocument(); $images = json_decode($this->item->images); $fbimage = JURI::base() . $images->image_fulltext; $doc->addCustomTag( '<meta property="og:image" content="' . $fbimage . '">' );   به جای $images->image_fulltext; کد تصویر خودتون رو باید صدا بزنید.

ادامه مطلب
  • پنج شنبه, 07 مهر 1401
  • آموزش برنامه نویسی جوملا

بدست آوردن گروه کاربری یک کاربر در جوملا

برای بدست آوردن گروه کاربری یک کاربر در جوملا می توانید از کد زیر استفاده کنید: $user = JFactory::getUser(); $groups = $user->get('groups'); foreach ($groups as $group) { echo '<p>Group = ' . $group . '</p>'; }

ادامه مطلب
  • پنج شنبه, 07 مهر 1401
  • آموزش برنامه نویسی جوملا

آموزش ارسال ایمیل در جوملا با استفاده از php در کامپوننت های اختصاصی

برای ارسال ایمیل در جوملا با استفاده از php در کامپوننت های اختصاصی می توانید از کد زیر استفاده کنید. $from = 'admin@somewhere.com'; $fromname = 'BIGSHOT Blog'; $recipient[] = 'john@somewhere.com'; $recipient[] = 'jane@somewhere.com'; $subject = 'Want to learn about BIGSHOT Blog'; $body = '<p>Check us out!</p><p><a href="http://www.somewhere.com" target="_blank">http://www.somewhere.com</a></p>'; $mode = 1; $cc = 'bob@somewhereelse.com'; $bcc[] = 'simon@somewhereelse.com'; $bcc[] = 'nick@somewhereelse.com'; $attachment[] = '/home/my_site/public_html/images/stories/food/coffee.jpg'; $attachment[] = '/home/my_site/public_html/images/stories/food/milk.jpg'; $replyto = 'no_reply@somewhere.com'; $replytoname = 'NO REPLY - BIGSHOT Blog'; JUtility::sendMail($from, $fromname, $recipient, $subject, $body, $mode, $cc, $bcc, $attachment, $replyto, $replytoname);

ادامه مطلب
  • پنج شنبه, 07 مهر 1401
  • آموزش برنامه نویسی جوملا

انتقال به صفحه یا آدرس در جوملا

برای انتقال یک صفحه در جوملا به صفحه ای دیگر یا یک سایت دیگر از کد زیر می توانید استفاده کنید $app = JFactory::getApplication(); $app->enqueueMessage('Redirect to another page was successful', 'success'); $app->redirect(JRoute::_('index.php')); //or $app = JFactory::getApplication(); $app->redirect("'http://google.com'");

ادامه مطلب