Typo3 - indexed search: Unterschied zwischen den Versionen

Aus Wikizone
Wechseln zu: Navigation, Suche
Zeile 16: Zeile 16:
  
 
== Performance in der indexed Search Extension ==
 
== Performance in der indexed Search Extension ==
 +
Wenn es mehr Seiten werden kann die indexed Search Extension zum Performance Killer werden.
 +
Dafür gibt es mehrere Gründe:
  
 +
1. Die Volltextsuche http://bugs.typo3.org/view.php?id=5089
 +
Es gibt aus Gründen der Kompatibilität keinen fulltext index in den Tabellen.
 +
Daher schlägt Peter Russ im Bugtracker vor: fulltext index to index_fulltext.fulltext and index_words.baseword
 +
 +
2. changed query in class.tx_indexedsearch.php to use fulltext
 +
capabilites of MySql.
 +
Das ist im obigen Link im verlinkten diff File beschrieben. Großer Performance Gewinn, allerdings keine Teilsuche (typo findet auch typo2) mehr möglich.
 +
 +
3. Mehrfach indizierte Inhalte bei tt_news
 +
Lösung aus der Mailing Liste:
 +
 +
Die mehrfachindizierung bei tt_news habe ich hoffentlich dadurch
 +
gelöst, indem ich dontUseBackPid = 1 verwende und nur jeweils die
 +
SINGLE-News-Seite indizieren lasse. D. h. ich habe bei den LIST und
 +
LATEST Seiten "Nicht suchen" aktiviert. Ist das so richtig?
  
 
== Ein Suchfeld ins Template einbinden ==
 
== Ein Suchfeld ins Template einbinden ==

Version vom 15. Oktober 2007, 11:46 Uhr

Suchergebnis verbessern

Es gibt einige Problemchen mit der Indexed Search die man beheben kann:

Suchbereich einschränken

Um zu verhindern, daß Metatags, Navigation etc. mit indiziert werden schränkt man den Suchbereich ein. Dafür stehen die Marker für den Suchbereich verwenden.


Ob das bei den Metatags funktioniert bleibt zu testen. Ansonsten kann auch im Quellcode der Bereich auskommentiert werden:

In der class.indexer.php die 6 Zeilen nach Zeile 1215

// get keywords and description metatags 
...

Performance in der indexed Search Extension

Wenn es mehr Seiten werden kann die indexed Search Extension zum Performance Killer werden. Dafür gibt es mehrere Gründe:

1. Die Volltextsuche http://bugs.typo3.org/view.php?id=5089 Es gibt aus Gründen der Kompatibilität keinen fulltext index in den Tabellen. Daher schlägt Peter Russ im Bugtracker vor: fulltext index to index_fulltext.fulltext and index_words.baseword

2. changed query in class.tx_indexedsearch.php to use fulltext capabilites of MySql. Das ist im obigen Link im verlinkten diff File beschrieben. Großer Performance Gewinn, allerdings keine Teilsuche (typo findet auch typo2) mehr möglich.

3. Mehrfach indizierte Inhalte bei tt_news Lösung aus der Mailing Liste:

Die mehrfachindizierung bei tt_news habe ich hoffentlich dadurch gelöst, indem ich dontUseBackPid = 1 verwende und nur jeweils die SINGLE-News-Seite indizieren lasse. D. h. ich habe bei den LIST und LATEST Seiten "Nicht suchen" aktiviert. Ist das so richtig?

Ein Suchfeld ins Template einbinden

Extension einbinden

Indexed Search Engine (indexed_search)installieren (Standardmäßig vorhanden)

Translation Handling -> Übersetzungen aktualisieren

HTML-Template & CSS

Beispiel:

    <div id="searchBox">
    </div>
Einschränken des Suchbereichs im Template

Im Template werden folgende Marker eingesetzt:

 <!--TYPO3SEARCH_begin-->
 ...
 <!--TYPO3SEARCH_end-->

Sind keine Marker vorhanden wird alles Durchsucht ist nur einer der Marker vorhanden wird alles nach (begin Marker) bzw. vor (end Marker) dem Marker durchsucht

CSS
#searchBox input{
  width: 140px;
}
#searchBox input.searchBox-button{
position: relative;
border: none;
width: auto;
top: 2px;
}
div.tx-indexedsearch-whatis{
padding-left: 12px;
}

Konfiguration der Extension

TypoScript indexedSearch-config (V1.1)

Constants

searchRoot = 1
searchResultPage = 4
searchPic = fileadmin/common/images/lupe.gif

Setup

plugin.tx_indexedsearch._CSS_DEFAULT_STYLE >
page.config.index_enable = 1
config{
   # Index-Suche einschalten
   index_enable = 1 
   # Externe Dateien auch durchsuchen (pdf,doc...benötigt Erweiterungen)       
   index_externals = 0
}
plugin.tx_indexedsearch{
   # Startpunkte der Suche (12,45...)
   search.rootPidList = {$searchRoot}
   # Diverse Optionen zur Anzeige im Frontend...
   show.rules = 0
   show.resultNumber = 0
   blind.sections = 1
   show.L1sections = 0
   show.L2sections = 0
   show.advancedSearchLink = 0

   # auf bestimmte Medientypen einschränken
   # search.mediaList = pdf, doc
}

# Temporäres Objekt für das Suchfeld (in neueren Versionen auch Templates möglich 
# es kann auch die macina Searchbox eingesetzt werden (Template Support Mehrsprachigkeit...)

temp.searchBox = TEXT
temp.searchBox.insertData = 1
temp.searchBox.value (
<div class="searchBox">
<form action="index.php?id={$searchResultPage}&tx_indexedsearch[sword]" method="post">
  <input type="text" name="tx_indexedsearch[sword]" value="Suche" class="searchBox-field" title="Suche" />
  <input type="image" src="{$searchPic}" alt="Start" title="Start" class="searchBox-button"/>
  <input type="hidden" name="stype" value="L0" />
  <input type="hidden" name="scols" value="tt_content.header-bodytext-imagecaption" />
  <input type="hidden" name="locationData" value="{$searchResultPage}:pages:{$searchResultPage}" />
</form>
</div>
)

#plugin.tx_macinasearchbox_pi1.pidSearchpage = {$searchResultPage}

im Main Template

Setup:

### SearchBox ###
subparts.searchBox < temp.searchBox


Tutorial von Marlies Cohen

When I first started with Typo3 Indexed Search gave me some problems. It is a very basic extension.


Place this line of code in the Setup of your TypoScript of your rootpage:

   # Indexed Search activated
   page.config.index_enable = 1


Now comes the trick to get your pages indexed.

-> Log out of Typo3

-> Go to your home page

-> Log back in to Typo3

-> Now your pages should be cached and searchable


The reason for this is that as long as you are logged in to Typo3 your pages are not cached, once you log out and view pages they are cached. Knowing this saves a lot of hassles.



Clearing Indexed Search Cache

-> switch to the "Info" module on the left and

-> choose "indexed search" on the right dropdown (in the details view). now you can see all your pages that have been indexed

-> click on the trash-item to delete the indexed record for a specific page-tree (attention: recursive!).