Popular Tags:

Einführung in Magento

2. November 2009 at 19:11

magento

Magento ist eine sich schnell entwickelnde sehr professionellen Open-Source-E-Commerce-Plattform mit einer ständig wachsenden User- & Fan-Gemeinschaft. Die erste Version 1.0 wurde am 31. März 2008 veröffentlicht. Seit dem hat sich viel getan, die Veröffentlichung der Version 1.4 steht kurz bevor.

Trotz der guten Usability und der mittlerweile guten Dokumentation, macht vor allem die gute Skalierbarkeit einigen Benutzern zu schaffen. Geht die Installation und Basiskonfiguration noch sehr einfach, spätere Template-Anpassungen oder das Schreiben bzw. Anpassen von Erweiterungen wird zur Qual.

Sehr schnell wird über Magento geschimpft und gar das Konzept bzw. die Struktur in Frage gestellt. Der wirkliche Grund ist allerdings meist das fehlende Basis-Wissen. Installiert sich Magento noch fast von selbst, so gehört bei der Anpassung ein gewisses Basiswissen einfach dazu. Gerne bieten wir Ihnen Dienstleistungen rund um Magento an.

In folgende Themen sollten Sie über entsprechendes Basis-Wissen verfügen:

  1. HTML/XHTML
  2. CSS
  3. Javascript, AJAX (Prototype & jQuery)
  4. XML, JSON
  5. PHP / OO-Programmierung
  6. MySQL Datenbank
  7. Magento basiert auf dem Zend-Framework – Erfahrung mit dem Framework ist von Vorteil
  8. sehr zu Empfehlen: SEO & SEM Basis-Wissen

Bei der Anbindung an externe Systeme, z.B. mit einem ERP-System, ist ggf. zusätzliche Kenntniss von Notwendig!
Mit dem genannten Fähigkeiten sollten die gängisten Anpassungen, Installation, Support & Wartung des Systems möglich sein.

Sie Benötigen Unterstützung bei der Erstellung oder Anpassung eines Magento eCommerce Shop System?

Fly2Mars-Media unterstützt Sie in diesem und vielen anderen Bereichen rund um das Thema Internet & IT!

Für ein individuelles Angebot nehmen Sie noch heute Kontakt mit uns auf.

Joomla 1.6 – Was gibt es Neues?

2. November 2009 at 18:57

joomla-1-6Das bekannte Joomla Content-Management-System (CMS) ist aktuell in Version 1.5.x verfügbar. Version 1.6 befindet sich aktuell im Status Alpha 2 und kann bereits herunter geladen werden.

Was ist neu in Joomla 1.6?

  • Einer der größten Änderungen in der 1.6 ist das Rechte-Management welches auf verbesserten Zugriffssteuerungslisten (Access Control List, kurz: ACL) basiert. Damit ist es möglich individuell fest zu legen welcher Benutzer was darf. Damit wird das derzeitig starre Rollenschema von Autor, Publisher und Administrator mit den vorgegebenen, nicht frei konfigurierbaren Rollen, aufgehoben.
  • Die Beschränkung auf eine zweistufige Hierarchie mit Bereichen und Kategorien fällt weg. Zukünftig können Kategorien beliebig tief ineinander verschachteln werden.
  • Die URLs welche Joomla erzeugt, werden für Menschen und Suchmaschinen besser lesbar. Mit diesen  suchmaschinenfreundlichen URLs (Search Engine Friendly, SEF) trägt Joomla zur Suchmaschinenoptimierung (Search Engine Optimization, SEO) der Website bei. Bisher ist die Suchmaschinenoptimierung von Joomla im Vergleich zu anderen Web-CMS eher mäßig und nur mit Erweiterungen auf dem Stand der Technik gehalten.
  • Bei Kontaktformularen ist es jetzt möglich selbiges durch frei wählbare Felder zu ergänzen.
  • Der Quelltext wurde aufgeräumt und einige Erweiterungen wie z.B. die PDF-Ausgabe, wurden aus Joomla entfernt. Damit schrumpft die Dateigröße des Joomla-Downloads um etwa 30 Prozent und das Risiko von Sicherheitslücken sinkt – allerdings kann es dadurch passieren, dass einige für Joomla 1.5 geschriebene Erweiterungen nicht ohne Anpassung mit Joomla 1.6 laufen.
  • Ähnlich WordPress werden jetzt die Erweiterungen automatisch aktualisiert. Dadurch kann eine Erweiterungen mit nur wenigen Klicks aktualisieren werden. Geplant ist sogar ein Joomla-Auto-Update, so dass auch Joomla selbst mit nur wenigen Klicks aktualisiert werden kann.
  • Inhalte der Website können versioniert werden. Das bedeutet, bestimmte Stände eines Inhalts werden als jeweils eine Version gespeichert, die jederzeit wiederhergestellt oder mit der aktuellen Version verglichen werden kann (bekannt aus z.B. WordPress oder Wikipedia).
  • Joomla 1.6 wird nur noch zur Skriptsprache PHP in Version 5.2 und aufwärts kompatibel sein. Dadurch steigt die Sicherheit Ihrer Website, denn PHP 4 gilt mittlerweile als veraltet und unsicher.

Viele Änderungen waren schon lange hinfällig und wurden meist durch Plugins nachgerüstet, welche nun überflüssig werden.

Seit 24.10.22009 steht die Alpha 2 zum Download bereit.

Sie Benötigen Unterstützung bei der Erstellung, Anpassung oder Migration einer auf dem Joomla CMS basierten Webseite?

Fly2Mars-Media unterstützt Sie in diesem und vielen anderen Bereichen rund um das Thema Internet & IT!

Für ein individuelles Angebot nehmen Sie noch heute Kontakt mit uns auf.

Magento Resources – Coding Tipps – Magento Cheat Sheet – Magento Hints

29. Oktober 2009 at 20:45

php code

Eine MySQL Datenbank kopieren als Linux Root

Mit dem folgendem Befehlt könnt ihr erfolgreich eine Magento Datenbank kopieren:

$ mysqldump -u root –password=pass db1 | mysql -u root –password=pass db2

Aktuelle Store ID abfragen

Manchmal ist es notwendig die aktuelle Store-ID abzufragen, das geht wie folgt:

Mage::app()->getStore()->getCode()

Aktuelles Land des gewählten Stores ausgeben / get current country of the selected store in Magento

    public function getStoreCountry()
    {
    	return Mage::getStoreConfig('general/country/default', Mage::app()->getStore()->getId());
    }

Heraus finden ob ein Benutzer am System angemeldet ist

Das ist wirklich nützlich wenn Sie z.B. eine spezielle Nachricht oder Gutschein-Code nur für eingeloggte Kunden anzeigen wollen

Mage::getSingleton( 'customer/session' )->isLoggedIn()

Blocks anzeigen welche in dem Bereich nicht geladen sind (Template)

In dem Beispiel binden wir die Top-Suche außerhalb der header.phtml ein. Sie können die Methode überall in den Template-Dateien aufrufen, um Blücke anzuzeigen welche an der Stelle nicht geladen werden.

$this->getChildHtml()
<?php echo $this->getLayout()->getBlock('top.search')->toHtml()?>

Auch das Einbinden von Blocks ohne Template-Datei

Auch das Einbinden von Blocks ohne Template-Datei ist möglich, in der Layout-XML (z.B. page.xml) definiert ihr unter

<layout>
<default>
<block type="page/html" name="root" output="toHtml" template="page/2columns-left.phtml">
<block type="module_name/folder_one" name="folder_one" as="folder_one" />
</block>
</defaul>
</layout>

Beachtet dabei dass der Type „folder_one“ die Verzeichnis-Struktur im Modul-Ordner unter „Block“ ist.

Die Ausgabe erfolgt dann im entsprechenden Template (in diesem Fall page/2columns-left.phtml) durch:

echo $this->getLayout()->getBlock('etracker_track')->toHtml();

Ein bestimmtes Attribut ausgeben

Um den Namen eines Attributes in einer Bestellung anzuzeigen, folgenden Code aufrufen (z.B. in template/catalog/product/view.phtml ):

 <?php echo $_product->getAttributeText('furniture_type') ?> 

Wie gibt man den aktuellen Layout Ordner (theme folder) ausgeben?

 <?php echo $this->getSkinUrl('') ?> 

Die Ausgabe ist ähnlich: http://www.yoursite.com/skin/frontend/default/default/

Warum das sinnvoll ist:
Falls Sie ein neuen CSS Style hinzufügen wollen um z.B. ein Hintergrundbild anzuzeigen, ist der Beste Weg dieses in das Ihr Template Bilder Ordner zu packen und eine Referenz über diesen Aufruf zu setzen:

.className {
background-image: url( }

Oder eine JavaScript Datei einzubinden:

<script type="text/javascript" src="<?php echo $this->getSkinUrl('js/Script.js')?>">

Abfrage von Daten aus der Datenbank (ohne SQL-Abfrage)

Einige Module haben ein Resoure-Model definiert, über das Ihr Daten direkt von der Datenbank abfragen könnt (mapping). Der Zugriff erfolgt in der Regel dann für die Spalte xy über das die Methode getXy() des Models.

Abfrage von Daten aus der Datenbank (per SQL-Abfrage)

Im Rahmen der Entwicklung von Erweiterungen ist es ggf. notwendig Daten aus der Datenbank abzufragen.
Da Magento auf das ZendFramework basiert, ist der Aufruf identisch und zwar wie folgt:

$select = '';
$table = 'table_name';
$where = 'id=' . $id;
$order = '';
// read data
$connection = Mage::getSingleton('core/resource')
->getConnection('core_read');
$select = $connection->select()
->from($table)
->where($where)
->order($order);
$data = $connection->fetchAll($select);

Session Variable in Magento setzen und abfragen

Mage::getSingleton('core/session')->setYourVariable('data');
 $Data = Mage::getSingleton('core/session')->getYourVariable();

Hier noch eine Übersicht von diversen häufig gebrauchten Funktionen (wird zukünftig noch erweitert):

Diverse Werte

<?php
$storeId     = Mage::app()->getStore()->getId();
$storeName   = Mage::app()->getStore()->getName();
$storeCode   = Mage::app()->getStore()->getCode();
$groupId     = Mage::app()->getStore()->getGroupID();
$groupName   = Mage::app()->getStore()->getGroup()->getName();
$websiteName = Mage::app()->getWebsite()->getName();

Models

<?php
$customer = Mage::getModel('customer/customer');
$order    = Mage::getModel('sales/order');
$product  = Mage::getModel('catalog/product');
/* own modul in local */
Mage::getModel('namespace_modul/model')->init($item);

Blocks

<?php
$block = Mage::app()->getLayout()->createBlock('Namespace_Module_Block_BlockName');

Helpers

<?php
$helper = Mage::helper('helper');

Logging

<?php
Mage::log('Schreibe das ins Logfile');

Globale Variable setzen & auslesen

Globale Variable in Magento definieren:

Mage::register('globaleVariable', 'Inhalt');
Mage::log('log-message', Zend_Log::DEBUG, 'logefile.log');

Globale Variable in Magento auslesen:

Mage::registry('globaleVariable');

Globale Variable in Magento löschen:

Mage::unregister('globaleVariable');

Website ID anzeigen (website_id)

<?php echo  Mage::app()->getWebsite()->getID(); ?>

StoreGroup ID anzeigen (group_id)

<?php echo  Mage::app()->getStore()->getGroupID(); ?>

Website Name anzeigen (name)

<?php echo  Mage::app()->getWebsite()->getName(); ?>

Store Name anzeigen (name)

<?php echo  Mage::app()->getStore()->getGroup()->getName(); ?>

StoreView Name anzeigen (name)

<?php echo  Mage::app()->getStore()->getName(); ?>

Skin URL

<?php echo $this->getSkinUrl('images/test.jpg')  ?>

SKU anzeigen

<?php echo  $this->htmlEscape($_product->getSku()) ?>

Hersteller anzeigen

<?php echo  $_product->getAttributeText('manufacturer') ?>

Link zur anzeige einer Kategorie erzeugen

// die Zahl bei load() ist die Category-ID
Mage::getModel('catalog/category')->load('1000')->getUrl();

Link zu einem bestimmen Pfad erzeugen

$this->getUrl('checkout/cart/')

Alternativ

Mage::getBaseDir('lib');  // lib folder
Mage::getBaseDir('media'); // media folder

die aktuelle Action (ActionName) auslesen

// liefert als return zB. &quot;new&quot;
$this->getRequest()->getActionName());

den aktuellen Controller (ControllerName) auslesen

// liefert als return zB. &quot;catalog&quot;
$this->getRequest()->getControllerName());

Module überschreiben (config.xml)

Wenn ihr ein Model überschreiben möchtet so sieht dazu die Config wie folgt aus. Hier am Beispiel des Catalog Model Mage_Catalog_Model_Config welches durch die neu angelegte Klasse Namespace_Catalog_Model_Config erweitert wird, welche im neu angelegten Module Ordner unter /app/code/local/Namespace/Catalog/Model/Config.php abgelegt ist ):

<?xml version=&quot;1.0&quot;?>
<config>
 <modules>
 <Namespace_Catalog>
 <version>0.0.1</version>
 </Namespace_Catalog>
 </modules>
 <global>
 <models>
 <catalog>
 <rewrite>
 <config>Namespace_Catalog_Model_Config</config>
 </rewrite>
 </catalog>
 </models>
 </global>
</config>

Magento: Alle aktiven Sprachen anzeigen / show Available Languages

$availLangs = Mage::getStoreConfig('general/locale/available_languages');
 if (!is_array($availLangs)) {
 $availLangs = explode(',', $availLangs);
 }

Magento: Liste aller verfügbaren Länder / show list of available countries

if (!$countryCollection) {
$countryCollection = Mage::getModel('directory/country_api')->items();
}
foreach($countryCollection as $country) {
var_dump($country);
}

Magento: Filter Attribute erweitern / entfernen (Filter List on Product/Category/Search List)

// $this = Mage_Catalog_Block_Product_List_Toolbar
$this->addOrderToAvailableOrders('price', $this->__('Price'));
// $this = Mage_Catalog_Block_Product_List_Toolbar
// remove attribute
$this->removeOrderFromAvailableOrders('price');

Im Editor Path setzen

{{store direct_url='datenschutzerklaerung'}}

Get the current category name in Magento / Aktuellen Kategorie Namen in Magento ausgeben

Mage::registry('current_category')->getName();

Get the current category in Magento / Aktuellen Kategorie in Magento

Mage::registry('current_category');

Get the current category level in Magento / aktuell Ebene der Kategorie in Magento ausgeben

$currCat = Mage::registry('current_category');
echo $currCat->getLevel();

Display all sub-categories from the actual category in Magento / Unterkategorien der aktuellen Kategorie anzeigen in Magento ausgeben

$currCat = Mage::registry('current_category');
$_categories = Mage::getModel('catalog/category')->getCategories($currCat->getEntityId());
foreach($_categories as $_category)
	echo $_category->getName();

Get Request Param

$this->getRequest()->getParam('website');

Daten auslesen / Filtern / Collection / getResourceModel

$collection = Mage::getResourceModel('sales/order_collection')
 ->addFieldToSelect('grand_total')
 ->addFieldToFilter('customer_id', Mage::getSingleton('customer/session')->getId());
 $collection->load();
 return $collection->getSize();

Index Management – Reindex starten aus php-script

// e.g. for flat-catalog 1
$mageFilename = '../app/Mage.php';
require_once $mageFilename;
$indexer = Mage::getSingleton('catalog/product_flat_indexer')->rebuild(1);

den Aktuell Block im Layout / Template ausgeben – get the current block name in layout

$this->getNameInLayout()

Variable von z.b. controller an Template übergeben

Variable definieren

// load xml layout
 $this->loadLayout();
 // load layout block
 $this->getLayout()
 ->getBlock('block_name')
 ->setVariableName($value);

im template ruft ihr die variable ab mit

$this->getVariableName();

Zugriff auf die Config (config values in core_config_data table)

// e.g. the cookie domain value - enter the "path"-value from the "core_config_data table" in the database
Mage::getStoreConfig('web/cookie/cookie_domain')

Dabei ist egal ob die Paramter in der Datenbank oder in der config.xml hinterlegt ist.

Um die folgenden Werte aus der config.xml auszulesen …

<config>
<default>
<namespace_modulename>
<value>asdf</value>
</namespace_modulename>
</config>
</default>

… verwendet diesen PHP-Snipped:

Mage::getStoreConfig('namespace_modulename/value');

die aktuelle Action (ActionName) auslesen

// liefert als return zB. &quot;new&quot;
$this->getRequest()->getActionName());

Link in einer CMS-Page setzen

// z.b. zur Kontakt-Seite
{{store url='contacts'}}

load parent category by product id / Hauptkategorie anhand der Produkt ID laden in Magento

if(!empty($_product)) {
$_categories = Mage::getModel('catalog/product')
->load($_product)
->getCategoryCollection()
->addAttributeToSelect('name')
->addAttributeToFilter('level', 2);
foreach ($_categories as $_category) {
// get parent category name
echo Mage::getModel('catalog/category')->load($_category->getId())->getName();
// get parent category id
echo Mage::getModel('catalog/category')->load($_category->getId())->getId();
}
}

load current currency code in magento / aktuelle Währungs Kürzel des Stores in Magento auslesen

$baseCurrencyCode = Mage::app()->getStore((int)$this->getParam('store'))->getBaseCurrencyCode();

The current url of the page you are in magento / die aktuelle Seiten URL in Magento

$currentUrl = $this->helper('core/url')->getCurrentUrl();

function to get the real country name of a country-code (e.g. ‚gb‘) set in store-view as code

	public function get_country_name()
	{
		// Mage::app()->getWebsite()->getCode() is 'gb'
                $collection = Mage::getModel('directory/country')->loadByCode(Mage::app()->getWebsite()->getCode());
		return Mage::app()->getLocale()->getCountryTranslation($collection->getId());
	}

get country name for country code (e.g. ‚gb‘ or ‚de‘)

$countryName = Mage::getModel('directory/country')->load('gb')->getName();

Attribute & Entity hinzufügen, EAV-Model erweitern in Magento

Ausführliche Infos zu diesem Punkt im Magento Wiki

get product type in Magento

$_product->getTypeId();

isXmlHttpRequest

// $this = Mage_Core_Controller_Request_Http
$this->getRequest()->isXmlHttpRequest();

Getting the Secure (HTTPS) url for Magento

// first opportunity
Mage::getUrl('datacargofactory', array('_secure'=>true)
// second opportunity about the config
Mage::getStoreConfig('web/secure/base_url')

Check Magento Shop Url is Currently Secure

// return true or false
Mage::app()->getStore()->isCurrentlySecure();

Add customer attribute in Magento

$customer = Mage::getModel('customer/customer')->load($customerId);
$customer->setAttributeName($value);
$customer->save();

get current time in Magento / aktuelle Zeit in Magento

$now = Mage::getModel('core/date')->timestamp(time());

get products collection by category in Magento

$productCollection = Mage::getResourceModel('catalog/product_collection')
->addCategoryFilter($category);

show sql select statement from collection

$collection->getSelect()->__toString();

get magento root path / magento root pfad ausgeben

echo Mage::getRoot();

get magento base path / magento base pfad ausgeben

echo Mage::getBaseDir();

load magento store view / magento store view laden

 Mage::app()->getStore()->load(0);

load customer greater than customer_id 5 / magento Kunden laden ab Kunden-ID 5

                $customerItemsCollection = Mage::getModel('customer/customer')->getCollection()
                    ->addAttributeToFilter('entity_id', array('gt' => 5))
                    ->getAllIds();

get magento store url

Mage::getBaseUrl(Mage_Core_Model_Store::URL_TYPE_WEB)

save current product url in session / get current product url

$productId  = (int) $this->getRequest()->getParam('id');
$product    = Mage::getModel('catalog/product')->load($productId);
if($productId != '' && !empty($product)) {
Mage::getSingleton('customer/session')->setBeforeReviewRegUrl($product->getProductUrl());
}

beliebige tempaltes einbinden über xml config files in Magento

<fly2mars_catalog_order>
<remove name="right"/>
<remove name="left"/>
<reference name="root">
<action method="setTemplate"><template>page/1column.phtml</template></action>
</reference>
<reference name="content">
<block type="core/template" name="catalog.order" template="fly2mars/catalog/order.phtml"/>
</reference>
</fly2mars_catalog_order>
<fly2mars_newsletter_subscribe>
<remove name="right"/>
<remove name="left"/>
<reference name="root">
<action method="setTemplate"><template>page/1column.phtml</template></action>
</reference>
<reference name="content">
<block type="core/template" name="catalog.order" template="fly2mars/newsletter/subscribe.phtml"/>
</reference>
</fly2mars_newsletter_subscribe>

alternativ  nur einbinden einer phtml-datei in den header

<default>
<reference name="head">
<block type="core/template" name="marin_tracking" template="fly2mars/tracking.phtml" />
</reference>
<default>

get cms/page collection with filter in magento /cms/page collection mit filter in magento abfrage

$this->_cmsPaqgesCollection = Mage::getModel('cms/page')->getCollection()->addStoreFilter(Mage::app()->getStore()->getId());
$this->_cmsPaqgesCollection->getColumnValues('page_id');
$this->_cmsPaqgesCollection->getColumnValues('title');
$this->_cmsPaqgesCollection->getSelect()->where('page_id=5' );
foreach ($this->_cmsPaqgesCollectiona as $page) {
$PageData = $page->getData();
}

current url with(out) param or store code in url / canonical url / current cms url

$currentUrl = Mage::getUrl('', array(
'_current' => false,
'_use_rewrite' => true,
'_secure' => true,
'_store' => $storeId,
'_store_to_url' => false
));

get store home url / URL der Store Startseite in Magento

echo Mage::helper('core/url')->getHomeUrl();

get create date of a product in magento/ Produkt Erstellungsdatum eines Produktes in Magento

echo $product->getCreatedAt();   // get create date
echo $product->getUpdatedAt();  // get update date

rewrite magento resource-model / Magento Resource Model überschreiben

<config>
<global>
<models>
<sitemap_resource>
<rewrite>
<sitemap>Fly2marsmedia_Sitemap_Model_Resource_Sitemap</sitemap>
</rewrite>
</sitemap_resource>
</models>
</global>
</config>

Get full merged config.xml in magento / In Magento die final erzeugte config.xml ausgeben

Die einzelnen Module enthalten jeweils diverse config.xml-Dateien. Diese werden final von Magento zu einer einzigen config-xml-datei zusammen gefügt. Diese könnt ihr euch mit folgendem PHP-Code ausgeben lassen:

Mage::log(Mage::app()->getConfig()->getNode()->asNiceXml(), Zend_Log::DEBUG, "config-xml.log");

Magento SQL: Get attribute_id and update value from eav with sql select

SELECT * FROM eav_attribute WHERE entity_type_id=10;
UPDATE catalog_product_entity_varchar SET value="new page layout" WHERE attribute_id=929;
// entity_id = product id
select * from catalog_product_entity_int WHERE attribute_id=929 AND `store_id`=2 AND `entity_id`=158

Magento config.xml: rewrite an adminhtml controller

<config>
  <admin>
        <routers>
            <fly2marsmedia_customer>
                <use>admin</use>
                <args>
                    <module>fly2marsmedia_customer</module>
                    <frontName>fly2marscustomer</frontName>
                </args>
            </fly2marsmedia_customer>
            <adminhtml>
                <args>
                    <modules>
                        <fly2marsmedia_customer before="Mage_Adminhtml">fly2marsmedia_customer_Adminhtml</fly2marsmedia_customer>
                    </modules>
                </args>
            </adminhtml>
        </routers>
    </admin>
</config>

Blöcke überschreiben / overwrite blocks

Blöcke werden in Magento wie folgt überschrieben:

Die Klasse (Datei) in ein neuen Namespace kopieren, dort die klasse entsprechend umbenennen.

In der config.xml des neuen Modules gebt ihr folgendes an:

<global>

<blocks>

<fly2marsmedia_review>

<class>Fly2marsmedia_Review_Block</class>

</fly2marsmedia_review>

</blocks>

</global>

Unbedingt die entsprechende Layout-XML unter app/design/template-path/layout/ anpassen, so dass der neue geänderte

block bei „type“ eingetragen wird.

z.b.

<block type=“review/product_view“ name=“product.info“ template=“catalog/product/view.phtml“>

ändern zu

<block type=“fly2marsmedia_review/product_view“ name=“product.info“ template=“catalog/product/view.phtml“>

Magento Function to check if is referred from customer last order area

    /**
     * check if page is reffered from the customer account (last orders)
     *
     * @return true|false
     */
    public function isReferredFromCustomerAccount()
    {
        $refererUrl     = $this->getRequest()->getServer('HTTP_REFERER');
        if (strpos(strtolower($refererUrl), strtolower('sales/order/view/order_id')) !== false
        ) {
	        return true;
        } else {
            return false;
        }
    }

Aufbau der Datei robots.txt – Seiten für die Robots konfigurieren

29. Oktober 2009 at 14:04

Oft ist es sinnvoll bestimmte Seiten oder gar Bereiche einer Web-Seite vor der Indizierung von Suchmaschinen zu schützen. Zum Beispiel wenn es sich um Administrative, oder Seiten an denen noch gearbeitet wird, handelt.
Ggf. wollen Sie auch bestimmte Bilder, Logfiles oder Programmdateien vor der Indizierung der Suchmaschinen schützen damit diese nicht in den Suchergebnissen angezeigt werden.

Um dem gerecht zu werden wurde der Robots Exclusion Standard eingeführt, an den sich seriöse Suchmaschinen wie Google, Bing oder Yahoo! orientieren.

Nach diesem Standard muss eine Textdatei mit dem Namen robots.txt erstellt und diese im Stammverzeichnis der Domain platziert werden, so dass die Robots sie finden und beachten können.

<pre>http://www.beispiel.de/robots.txt
http://download.beispiel.de/robots.txt
http://beispiel.de:8080/robots.txt
</pre>

Der Aufbau der robots.txt erfolgt nach dem folgendem Shema. Zuerst gibt man an für welchen Crwaler eine Anweisung gelten soll, gefolgt von den einzelnen Anweisungen:

# robots.txt fuer http://www.beispiel.de/
User-agent: BeispielRobot
Disallow: /temp/       # Die Dateien sind nur Temporär und nicht von Bedeutung
Disallow: /logfiles/   # Sollen nicht allg. Verfügbar sein
Disallow: /bilder/     # Bilder sind teilweise geschützt und nicht zum download bestimmt
Disallow: /cgi-bin/    # CGI Ausgaben nicht indizieren
Disallow: /privat.html # Die pirivat.html soll nicht über die Suchmaschine gefunden werden

Mit User-agent: BeispielRobot bestimmt man, dass die Anweisungen nur für den genannten Crawler (BeispielRobot) gelten. Mit Hilfe der einzelnen Disallow Einträgen werden Verzeichnisse und Dateien bestimmt, welche nicht indiziert werden sollen. Mit Hilfe des Raute-Symbol (#)können Kommentare definiert werden, diese werden von den Robots ignoriert.

Ein Ausschluss aller Crawler ist mit Hilfe des sog. Wildchar * möglich:

# Alle Robots ausschließen
User-agent: *
Disallow: /temp/

Sollen nur bestimmte Crawler ausgeschlossen werden, sondern kann man diese wie folgt realisieren:

# Download-Tools vom CGI Verzeichnis fernhalten
User-agent: webmirror
User-agent: webzip
User-agent: webcopy
User-agent: wget
Disallow: /cgi-bin/

Eine Seite ganz von der Indizierung durch Suchmaschinen auszuschließen geht wie folgt:

# Komplette Webseite für alle Robots sperren
User-agent: *
Disallow: /

Durch entfernen des Slash (/) wird die Seite ganz für die Indizierung frei gegeben:

# Ganze Seite für Robots freigeben
User-agent: *
Disallow:

Die Groß- und Kleinschreibung wird bei Disallow Einträgen nicht durch die Robots berücksichtigt.

Sie Benötigen Unterstützung bei der Anpassung Ihrer robots.txt oder Optimierung (SEO) Ihrer Webseite bzw. Optimierung der Inhalte?

Fly2Mars-Media unterstützt Sie in diesen und vielen anderen Bereichen rund um das Thema Internet & IT!

Für ein individuelles Angebot nehmen Sie noch heute Kontakt mit uns auf.

Video Erstellung für Virales Marketing

29. Oktober 2009 at 11:04

Erfolgreichen Social-Media-Marketing basiert meist auf Viral- oder/und Guerilla-Marketing.

Wichtig ist es so viele User aus den verschiedensten Communitys bzw. Portalen zu erreichen, wie irgendwie möglich. Neben interessanten Gewinnspielen eignen sich Videos (für Youtube oder ähnlich) mit als Bestes Medium zur Verbreitung einer Message. Hat das Video zu dem ein hohen Unterhaltungswert, so verbreitet es sich wie von selbst (Viral-Marketing).

Ein gutes Beispiel findet ihr im folgendem Werbe-Video von Olympus:

Ein weiteres gutes Beispiel von Heinecken:

Der Erfolg von Social-Media-Kampagnen steht außer Frage. Die Jugend ist im Internet sehr aktiv und alte Medien wie Radio oder TV geraten immer mehr in den Hintergrund.

Hier noch eine Vorstellung einiger erfolgreicher SocialMedia Marketing Kampagnen:

http://www.slideshare.net/conceptbakery.de/social-media-marketing-sucess-stories

Gerne hilft Ihnen Fly2Mars-Media bei der Umsetzung einer erfolgreichen Social-Media-Strategie, für ein individuelles Angebot nehmen Sie noch heute Kontakt mit uns auf.

Unterschied PHP 5 zu PHP 6

28. Oktober 2009 at 10:19

Eine gute Zusammenstellung der Unterschiede von PHP 5 zu PHP 6 findet ihr hier !

Photoshop Tutorial: Bild vektorisieren

28. Oktober 2009 at 10:01

Hier findet ihr eine Anleitung wie ihr in Photoshop ein Bild vektorisiert.

Cheet Sheets für Web-Entwickler

28. Oktober 2009 at 09:10

Hier findet ihr ein paar nützliche Cheet-Sheets für Web-Entwickler für HTML, XHTML, CSS, Apache, mod_rewrite, reguläre Ausdrücke, Java-Script, MySQL, Smarty und Jquery.

Paypal Direct endlich in Deutschland verfügbar – Zahlung ohne Paypal Konto

28. Oktober 2009 at 09:04

Ab sofort ist die schon lange erwartete Funktion „Paypal Direct“ auch in Deutschland unter den Namen „Paypal-Gastzahlung“ verfügbar.
Damit ist die Bezahlung für Käufer ohne PayPal-Konto möglich. Ein großer Mehrwert für Shopbetreiber und eine starke Konkurenz auf dem Markt der Bezahldienst-Anbieter im Kreditkarten-Bereich.

Mehr Infos bei Paypal (Link 1)

Mehr Infos bei Paypal (Link 2)

30 wichtige Magento Extensions

26. Oktober 2009 at 14:42

magento

Eine Übersicht der derzeit 30 wichtigsten Magento Extensions findet ihr unter folgenden Links:

Teil 1

Teil 2