Web tarayıcıları üzerinde animasyonların, reklamların, videoların görüntülemesini sağlayan, birçok oyunu çalıştıran tarayıcı eklentisi Adobe Flash Player’ın kullanımına 31 Aralık 2020 tarihi itibariyle son verildiği açıklandı.
1996 yılından bu yana tarayıcılarda videoların oynatılması ve online oyunların oynanmasını sağlamak amacıyla kullanılan Flash, yıllar içerisinde güvenlik sorunları nedeniyle hem yeni nesil tarayıcılarda hem de akıllı telefonlarda istenilen verimi sağlayamadı.
Bununla beraber geliştiricisi Adobe firması, Flash için daha fazla güvenlik güncellemesi sunmayacağını açıklayarak, “Adobe Flash Player’i kullandığınız için teşekkür ederiz. 31 Aralık itibarıyla Flash Player’e destek vermeyi kestik. Sisteminizin güvenliğini sağlamaya yardımcı olmak için, Flash Player içeriğini acilen kaldırmanızı tavsiye ediyoruz.” mesajı ile kullanıcılarından uygulamayı silmesini istedi.
Flash ilk ortaya çıktığı yıllarda internet çok daha düşük hızlardaydı ancak Flash, kullanıcılara içeriği daha yüksek hızda indirebilme imkânı sunuyordu.
Flash, animasyonlardan çok daha fazlası olmakla beraber YouTube gibi web sitelerinin yüksek kaliteli videolar yayımlamasına da izin veriyordu. 2009’a kadar internete bağlı masaüstü bilgisayarların neredeyse tamamına Flash yüklenmişti.
Ancak internet dünyası mobil cihazlara doğru kayarken Adobe yeterli seviyede teknolojiye ayak uyduramadı.
Dönemin popüler cihazlarının üreticisi Apple’ın kurucusu Steve Jobs, Flash’ın dokunmatik bir ekranda kullanımının zahmetli ve güvenilmez olduğunu söylerken Flash’ın telefonun pil ömrünü de azalttığını savunuyordu.
Videoların, animasyonların Flash yerine HTML5 ve diğer açık teknolojilerle sunulabileceğini aktaran Jobs, bunun da Flash’ı bir akıllı telefon veya tablette gereksiz hale getirebileceğini söylüyordu.
Sonrasında Adobe, Flash Player’ın akıllı telefonlarda çalışan bir sürümünü geliştirdi ancak internet değişmişti. Facebook, Netflix ve YouTube gibi büyük markalar halihazırda Flash olmadan akıllı telefonlara video oynatabilir hale gelmişti bile.
Bunun üzerinde Kasım 2011’de Adobe, mobil cihazlar için Flash’ın geliştirilmesini sonlandırdı ve sadece masaüstü bilgisayarlar için Flash üretilmeye devam etti, ancak yazılım birçok güvenlik açığı hala mevcuttu.
Sırasıyla 2015 yılında Apple Safari web tarayıcısında eklentiyi varsayılan olarak devre dışı bıraktı, Google’ın tarayıcı uygulaması Chrome da Flash içeriklerini engellemeye başladı ve diğer tarayıcılar da takip etti.
Bunlar üzerine Adobe 2017 yılında yaptığı açıklamada, 2020’de Flash’ı kullanımdan kaldıracağını ilan etmişti.
Web siteniz ya da herhangi bir web sitesinin tasarım aşamasında düzeltmeler yapabilmek, hataları tespit edebilmek için mobil veya değişik ölçülerde geniş ekranlarda nasıl göründüğünü görebilmek önemlidir.
Bu hizmeti veren web siteleri ve tarayıcı eklentileri mevcut olmakla beraber Mozilla Firefox tarayıcısının temel özelliği olarak bu uygulama mevcuttur.
Yapmanız gereken ilgili web sitesi açıkken klavyede “CTRL” + “SHIFT” + “M” tuşlarına basmak. Bu işlemin ardından üstte açılan menüde istediğiniz ölçüleri girebilir, ekran yönünü belirtebilir ve dokunma simülasyonu ile sayfanın dokunmatik ekranda nasıl çalıştığını kontrol edebilirsiniz.
EBA canlı ders uygulamasını Windows 7 üzerinde sorunsuz çalıştırmak için bazı ayarlamalar ve güncelleştirmeleri yapmanız gerekmekte.
Öncelikle bu bağlantıdan EBA CANLI DERS uygulamasını indirin. Mevcut sürüm güncellemelere göre değişiklik gösterebilir.
Windows 7 güncelleştirme desteğini kesmiş olsa da destek çekildiği ana kadar çıkan güncellemeleri hala otomatik olarak alabilmekte. Öncelikle tüm Windows 7 güncelleştirmelerini yaparak en güncel haline getirin.
Ardından “Denetim Masası” > “Windows Güvenlik Duvarı” > “Windows Güvenlik Duvarını Etkinleştir veya Devre Dışı Bırak” bölümüne girip, çıkan ekranda güvenlik duvarını kapat seçeneklerini seçip “Tamam” a tıklayın.
“Başlat” a tıklayıp arama bölümüne “inetcpl.cpl” yazarak Internet Explorer ayarlarına erişin. Bu ekranda üst menüden “Gelişmiş” bölümüne girin ve TLS 1.0 kullan, TLS 1.1 kullan ve TLS 1.2 kullan seçeneklerini seçip “Uygula” ve ardından “Tamam” ı seçerek çıkış yapın.
Devamında eğer MSVCP140.dll hatası alıyorsanız, işletim sisteminize göre
Kurulum sırasında problem yaşadıysanız ve sıfırdan sistem kurmadan Sentora Web Panel kurulumunu tekrar yapmak istiyorsanız öncelikle sistemden tamamen kaldırmanız gerekmekte. Üste tekrar kurulum mümkün olmadığı için girmeniz gereken komutlar şu şekilde;
Sentora eski adıyla Zpanel web panelini linux kurulu sisteminize ücretsiz olarak kurabilirsiniz.
Öncelikle Centos veya Ubuntu dağıtımlarından birini kullanmanız gerekmekte. Diğer linux dağıtımlarına da kurulum mümkün olmakla beraber hatalar oluşabiliyor. Centos için 6.0 sürümünde 7.0 sürümüne göre Sentora Web Panel daha sağlıklı çalışıyor. Kurulum için sırasıyla yapmanız gerekenler:
Centos 7.4 ve üstü sürümlerde kurulum öncesi Proftpd kontrolü yapmanızda fayda var. Sentora kurulumunda proftpd hatası alırsanız çözüm için temiz bir Centos kurulumu üzerinden işlem yapmanız gerekecektir.
Bu yüzden önce;
yum info proftpd
ile proftpd mevcut mu kontrol edin. Yoksa;
yum install epel-release
yum install proftpd
Proftpd kurulumunu gerçekleştirin.
1- root yetkisiyle komut satırı ekranına girin.
2- “bash <(curl -L -Ss http://sentora.org/install)” komutu ile kurulumu başlatın. Eğer bu komut sonrası hata alıyorsanız kurulumu tek tek şu şekilde gerçekleştirebilirsiniz:
3- Kurulum sırasında domain adı, zaman dilimi gibi bilgileri girip kurulumu tamamlayın. Yeniden başlatma işlemi öncesi verilen şifre bilgilerini kaydedin.
4- zadmin şifresi bazen çalışmamakta. Bu durumda yine root yetkisiyle “setzadmin –set şifre” şeklinde panel erişiminde kullanacağınız zadmin kullanıcısının şifresini belirleyin.
/**
* @copyright 2014-2015 Sentora Project (http://www.sentora.org/)
* Sentora is a GPL fork of the ZPanel Project whose original header follows:
*
* ZPanel – A Cross-Platform Open-Source Web Hosting Control panel.
*
* @package ZPanel
* @version $Id$
* @author Bobby Allen – [email protected]
* @copyright (c) 2008-2014 ZPanel Group – http://www.zpanelcp.com/
* @license http://opensource.org/licenses/gpl-3.0.html GNU Public License v3
*
* This program (ZPanel) is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
class module_controller extends ctrl_module
{
/**
* The ‘worker’ methods.
*/
static function ListClients($uid)
{
global $zdbh;
$sql = “SELECT * FROM x_ftpaccounts WHERE ft_acc_fk=:userid AND ft_deleted_ts IS NULL”;
$numrows = $zdbh->prepare($sql);
$numrows->bindParam(‘:userid’, $uid);
$numrows->execute();
static function ListCurrentClient($uid)
{
global $zdbh;
$sql = “SELECT * FROM x_ftpaccounts WHERE ft_id_pk=:userid AND ft_deleted_ts IS NULL”;
$numrows = $zdbh->prepare($sql);
$numrows->bindParam(‘:userid’, $uid);
$numrows->execute();
static function ListMasterDirs($uid)
{
$currentuser = ctrl_users::GetUserDetail($uid);
$res = array();
$handle = @opendir(ctrl_options::GetSystemOption(‘hosted_dir’) . $currentuser[‘username’] . “”);
$chkdir = ctrl_options::GetSystemOption(‘hosted_dir’) . $currentuser[‘username’] . “/”;
if (!$handle) {
// Log an error as the folder cannot be opened…
} else {
while ($file = @readdir($handle)) {
if ($file != ‘.’ && $file != ‘..’ && $file != ‘_errorpages’) {
if (is_dir($chkdir . $file)) {
$res[] = array(‘domains’ => runtime_xss::xssClean($file));
}
}
}
closedir($handle);
}
return $res;
}
static function ListDomainDirs($uid)
{
$currentuser = ctrl_users::GetUserDetail($uid);
$res = array();
$handle = @opendir(ctrl_options::GetSystemOption(‘hosted_dir’) . $currentuser[‘username’] . “/public_html”);
$chkdir = ctrl_options::GetSystemOption(‘hosted_dir’) . $currentuser[‘username’] . “/public_html/”;
if (!$handle) {
// Log an error as the folder cannot be opened…
} else {
while ($file = @readdir($handle)) {
if ($file != “.” && $file != “..” && $file != “_errorpages”) {
if (is_dir($chkdir . $file)) {
$res[] = array(‘domains’ => runtime_xss::xssClean($file));
}
}
}
closedir($handle);
}
return $res;
}
static function ExecuteResetPassword($ft_id_pk, $password)
{
global $zdbh;
global $controller;
// Verify if Current user can Edit FTP Account.
$currentuser = ctrl_users::GetUserDetail($uid);
$sql = “SELECT * FROM x_ftpaccounts WHERE ft_acc_fk=:userid AND ft_id_pk=:editedUsrID AND ft_deleted_ts IS NULL”;
$numrows = $zdbh->prepare($sql);
$numrows->bindParam(‘:userid’, $currentuser[‘userid’]);
$numrows->bindParam(‘:editedUsrID’, $ft_id_pk);
$numrows->execute();
if( $numrows->rowCount() == 0 ) {
return;
}
// Change User Password
runtime_hook::Execute(‘OnBeforeResetFTPPassword’);
$rowftpsql = “SELECT * FROM x_ftpaccounts WHERE ft_id_pk=:ftIdPk”;
$rowftpfind = $zdbh->prepare($rowftpsql);
$rowftpfind->bindParam(‘:ftIdPk’, $ft_id_pk);
$rowftpfind->execute();
$rowftp = $rowftpfind->fetch();
$sql = $zdbh->prepare(“UPDATE x_ftpaccounts SET ft_password_vc=:password WHERE ft_id_pk=:ftpid”);
$sql->bindParam(‘:password’, $password);
$sql->bindParam(‘:ftpid’, $ft_id_pk);
$sql->execute();
self::$reset = true;
// Include FTP server specific file here.
$FtpModuleFile = ‘modules/’ . $controller->GetControllerRequest(‘URL’, ‘module’) . ‘/code/’ . ctrl_options::GetSystemOption(‘ftp_php’);
if (file_exists($FtpModuleFile)) {
include($FtpModuleFile);
}
$retval = TRUE;
runtime_hook::Execute(‘OnAfterResetFTPPassword’);
return $retval;
}
static function ExecuteCreateFTP($uid, $username, $password, $destination, $domainDestination, $access_type, $home)
{
global $zdbh;
global $controller;
$currentuser = ctrl_users::GetUserDetail($uid);
$username = $currentuser[‘username’] . ‘_’ . $username;
runtime_hook::Execute(‘OnBeforeCreateFTPAccount’);
if (fs_director::CheckForEmptyValue(self::CheckForErrors($username, $password))) {
// Check to see if its a new home directory or use a current one…
if ($home == 1) {
$homedirectory_to_use = ‘/’ . str_replace(‘.’, ‘_’, $username);
$full_path = ctrl_options::GetSystemOption(‘hosted_dir’) . $currentuser[‘username’] . $homedirectory_to_use . ‘/’;
// Create the new home directory… (If it doesnt already exist.)
if (!file_exists($full_path)) {
@mkdir($full_path, 777);
@chmod($full_path, 0777);
}
} else if ($home == 3) {
$homedirectory_to_use = ‘/’ . $domainDestination;
} else {
$homedirectory_to_use = ‘/’ . $destination;
}
// Check if Path is inside user home directory.
$full_homeDir = ctrl_options::GetSystemOption(‘hosted_dir’) . $currentuser[‘username’] . $homedirectory_to_use . ‘/’;
$baseDir = ctrl_options::GetSystemOption(‘hosted_dir’) . $currentuser[‘username’];
$realPath = realpath($full_homeDir);
static function CheckForErrors($username, $password)
{
global $zdbh;
$retval = FALSE;
// Check to make sure the username and password is not blank before we go any further…
if ($username == ” || $password == ”) {
self::$blank = TRUE;
$retval = TRUE;
}
// Check for invalid username
if (!self::IsValidUserName($username)) {
self::$badname = true;
$retval = TRUE;
}
// Check to make sure the cron is not a duplicate…
$sql = “SELECT COUNT(*) FROM x_ftpaccounts WHERE ft_user_vc=:userid AND ft_deleted_ts IS NULL”;
$numrows = $zdbh->prepare($sql);
$numrows->bindParam(‘:userid’, $username);
if ($numrows->execute()) {
if ($numrows->fetchColumn() <> 0) {
self::$alreadyexists = TRUE;
$retval = TRUE;
}
}
return $retval;
}
static function ExecuteDeleteFTP($ft_id_pk, $uid = null)
{
global $zdbh;
global $controller;
// Verify if Current user can Edit FTP Account.
$currentuser = ctrl_users::GetUserDetail($uid);
$sql = “SELECT * FROM x_ftpaccounts WHERE ft_acc_fk=:userid AND ft_id_pk=:editedUsrID AND ft_deleted_ts IS NULL”;
$numrows = $zdbh->prepare($sql);
$numrows->bindParam(‘:userid’, $currentuser[‘userid’]);
$numrows->bindParam(‘:editedUsrID’, $ft_id_pk);
$numrows->execute();
if( $numrows->rowCount() == 0 ) {
return;
}
// Delete User
runtime_hook::Execute(‘OnBeforeDeleteFTPAccount’);
$rowftpsql = “SELECT * FROM x_ftpaccounts WHERE ft_id_pk=:ftIdPk”;
$rowftpfind = $zdbh->prepare($rowftpsql);
$rowftpfind->bindParam(‘:ftIdPk’, $ft_id_pk);
$rowftpfind->execute();
$rowftp = $rowftpfind->fetch();
$sql = $zdbh->prepare(“UPDATE x_ftpaccounts SET ft_deleted_ts=:time WHERE ft_id_pk=:ftpid”);
$sql->bindParam(‘:ftpid’, $ft_id_pk);
$sql->bindParam(‘:time’, $ft_id_pk);
$sql->execute();
self::$delete = true;
// Include FTP server specific file here.
$FtpModuleFile = ‘modules/’ . $controller->GetControllerRequest(‘URL’, ‘module’) . ‘/code/’ . ctrl_options::GetSystemOption(‘ftp_php’);
if (file_exists($FtpModuleFile)) {
include($FtpModuleFile);
}
$retval = TRUE;
runtime_hook::Execute(‘OnAfterDeleteFTPAccount’);
return $retval;
}
// Verify if Current user can Edit FTP Account.
// This shall avoid exposing ftp username based on ID lookups.
$currentuser = ctrl_users::GetUserDetail($uid);
$sql = ” SELECT * FROM x_ftpaccounts WHERE ft_acc_fk=:userid AND ft_id_pk=:editedUsrID AND ft_deleted_ts IS NULL”;
$numrows = $zdbh->prepare($sql);
$numrows->bindParam(‘:userid’, $currentuser[‘userid’]);
$numrows->bindParam(‘:editedUsrID’, $urlvars[‘other’]);
$numrows->execute();
if( $numrows->rowCount() == 0 ) {
return;
}
// Show User Info
return (isset($urlvars[‘show’])) && ($urlvars[‘show’] == “Delete”);
}
static function getisEditFTP($uid = null)
{
global $controller;
global $zdbh;
// Verify if Current user can Edit FTP Account.
// This shall avoid exposing ftp username based on ID lookups.
$currentuser = ctrl_users::GetUserDetail($uid);
$sql = ” SELECT * FROM x_ftpaccounts WHERE ft_acc_fk=:userid AND ft_id_pk=:editedUsrID AND ft_deleted_ts IS NULL”;
$numrows = $zdbh->prepare($sql);
$numrows->bindParam(‘:userid’, $currentuser[‘userid’]);
$numrows->bindParam(‘:editedUsrID’, $urlvars[‘other’]);
$numrows->execute();
if( $numrows->rowCount() == 0 ) {
return;
}
// Show User Info
return (isset($urlvars[‘show’])) && ($urlvars[‘show’] == “Edit”);
}
static function getEditCurrentName()
{
global $controller;
if ($controller->GetControllerRequest(‘URL’, ‘other’)) {
$current = self::ListCurrentClient($controller->GetControllerRequest(‘URL’, ‘other’));
return $current[0][‘username’];
} else {
return “”;
}
}
static function getEditCurrentID()
{
global $controller;
if ($controller->GetControllerRequest(‘URL’, ‘other’)) {
$current = self::ListCurrentClient($controller->GetControllerRequest(‘URL’, ‘other’));
return $current[0][‘id’];
} else {
return “”;
}
}
static function getResult()
{
if (!fs_director::CheckForEmptyValue(self::$blank)) {
return ui_sysmessage::shout(ui_language::translate(“You must enter a valid username and password to create your FTP account.”), “zannounceerror”);
}
if (!fs_director::CheckForEmptyValue(self::$alreadyexists)) {
return ui_sysmessage::shout(ui_language::translate(“An FTP account with that name already exists.”), “zannounceerror”);
}
if (!fs_director::CheckForEmptyValue(self::$error)) {
return ui_sysmessage::shout(ui_language::translate(“There was an error updating your FTP accounts.”), “zannounceerror”);
}
if (!fs_director::CheckForEmptyValue(self::$badname)) {
return ui_sysmessage::shout(ui_language::translate(“Your ftp account name is not valid. Please enter a valid ftp account name.”), “zannounceerror”);
}
if (!fs_director::CheckForEmptyValue(self::$invalidPath)) {
return ui_sysmessage::shout(ui_language::translate(“Invalid Folder.”), “zannounceok”);
}
if (!fs_director::CheckForEmptyValue(self::$ok)) {
return ui_sysmessage::shout(ui_language::translate(“FTP accounts updated successfully.”), “zannounceok”);
}
return;
}