20 minut zeszło mi nad wymyśleniem jakiegoś sensownego tytułu tego wpisu, całe 20 minut! Każda z tych bardziej popularnych przeglądarek internetowych posiada możliwość utworzenia własnych wyszukiwarek. Dzięki skorzystaniu z takiego rozwiązania w formie dodatkowej wyszukiwarki, bez konieczności wchodzenia na stronę możemy przeszukać jej zawartość. Oczywiście po wklepaniu keyworda i naciśnięciu entera zostaniemy przeniesieni na stronę z wynikami, jednakże nie musimy tego robić na samym początku.
Rozwiązanie to działa doskonale na takich przeglądarkach, jak: Mozilla Firefox, Internet Explorer, oraz Google Chrome. Wydawać by się mogło, że skoro te 3 przeglądarki radzą sobie w zadowalającym stopniu z takim „dodatkiem” to również dla Opery nie powinno być to wielkim wyzwaniem. A tu peszek niestety. Twórcy Opery widać, że lubią wprowadzać swoje własne trendy, które mijają się z nurtem idei postawionych przez inne przeglądarki.
Ale oso chodzi
Domyślnie użytkownicy odwiedzający naszą stronę/bloga mogą użyć wyszukiwarki w formie formularza na stronie. Dokładnie tak, jak na tym blogu, gdzie w górnym prawym rogu znajduje się formularz wyszukiwarki – tak ma to miejsce na tysiącach innych stron i blogach (niekoniecznie w prawym górnym rogu). Jednakże jeśli dzielimy się pożytecznymi informacjami i posiadamy bardzo wielu czytelników, to dlaczego by nie uprościć im i sobie życia dodając prosty kod na serwer, dzięki któremu już nie będzie musiał każdorazowo wchodzić na naszą witrynę by coś wyszukać. Zrobi to – korzystając z wyszukiwarki przeglądarki internetowej.
Każdy na pewno na przykładzie domyślnych wyszukiwarek wie, jak działa pasek wyszukiwarki. Po prostu klikamy na nim, bądź korzystamy z shortkey’a CTRL+K, a następnie wpisujemy szukaną frazę, wciskamy enter i tyle. Przeglądarka sama przeniesie nas na stronę z wynikami wyszukiwania. To samo osiągnąć chcemy w naszych przeglądarkach.
Tworzenie pliku *.xml
Pierwszą czynnością, którą wykonamy będzie utworzenie pliku XML ze zdefiniowanymi przez nas informacjami, takimi jak (kolejność przypadkowa):
- Nazwa wyszukiwarki
- Opis (opcjonalne)
- Adres formularza
- Metoda przesyłania danych
- Ikonka (opcjonalne)
- Kodowanie znaków
Otwieramy nowy plik w dowolnym edytorze tekstu (ja preferuję Notepad++) i wklejamy do niego poniższą zawartość.
<OpenSearchDescription> <ShortName></ShortName> <Description></Description> <InputEncoding></InputEncoding> <Image width="16" height="16">data:image/x-icon;base64,</Image> <!-- należy usunąć, jeśli nie chcemy favikonki --> <Url type="text/html" method="GET" template=""/> </OpenSearchDescription>
Pierwsza i ostatnia linia otwiera mechanizm, można by to porównać do <html>…</html>. Następnie ShortName przesyła informacje o nazwie naszej wyszukiwarki, może to być nazwa strony, slogan, cokolwiek. Description jest opisem strony, np. moja prywatna strona o niczym. InputEncoding odpowiada za kodowanie przesyłanych znaków. Image przesyła obrazek/faviconkę.
A na końcu zostaje Url, który odpowiedzialny jest za przesłanie informacji o metodzie przesyłu formularza i za sam formularz.
Na przykładzie mojego bloga, całość wygląda, tak:
<OpenSearchDescription> <ShortName>inzaghi89 weblog</ShortName> <Description>Wyszukiwarka inzaghi89 weblog - blog.keepmind.eu</Description> <InputEncoding>UTF-8</InputEncoding> <Image width="16" height="16">  </Image> <Url type="text/html" method="GET" template="http://blog.keepmind.eu/?s={searchTerms}"/> </OpenSearchDescription>
Jak zakodować faviconę w Base64?
Czynność zakodowania ikony do Base64 jest bardzo prosta. Musimy mieć dwie rzeczy, by móc tego dokonać:
- Ikonkę o rozmiarach 16x16px w png;
- Notepad++ z pluginem MIME Tools (który to jest domyślnie w tym programie).
Odpowiednio przygotowaną ikonę, zapisaną już na dysku otwieramy w Notepadzie. Zobaczymy tam tzw. krzaki, ale tak… o to chodzi. Zaznaczamy cały tekst (CTRL+A), a następnie z menu Pluginy / MIME Tools wybieramy Base64 Encode. Całość ponownie zaznaczamy i wklejamy do naszego pliku *.xml przed </Image>.
Co to jest Url, z czym to się je?
Ostatnim elementem do omówienia jest Url, który jak już wcześniej wspomniałem odpowiedzialny jest za przesyłanie naszych zapytań na stronę/do formularza. Blogi oparte na silniku WordPress domyślnie przesyłają zapytania wyszukania metodą GET, oznacza to iż nas dotyczy jedynie modyfikacja końcowego elementu z zawartością {searchTerms}.
Dla nas istotne jest to, co wpiszemy przed {searchTerms}, bowiem będzie to odnośnik do naszej strony/bloga/formularza. Po prostu należy podmienić http://blog.keepmind.eu/ → http://adresem.naszego.bloga.pl. To tyle! Zapisujemy zmiany.
Efekt końcowy
Nim jednak sprawdzimy działanie w praktyce, musimy dodać odpowiednie metadane, tak by przeglądarki wiedziały: Aha! Ta strona ma wyszukiwarkę dla mnie!
Otwieramy plik header.php i w dowolnym miejscu w sekcji <head>…</head> wklejamy poniższą linijkę:
<link title="<?php echo get_bloginfo('name'); ?>" rel="search" type="application/opensearchdescription+xml" href="<?php echo get_bloginfo('url'); ?>/search.xml" />
Title zwróci nam nazwę naszego bloga, rel informuje o tym iż jest to wyszukiwarka, type o jej typie, a href wskazuje lokalizację pliku xml.
To koniec. Żadnych więcej modyfikacji nie musimy wprowadzać. A jak wygląda to w praktyce?
Mozilla Firefox
Dodajemy ręcznie wyszukiwarkę klikając w rozwijaną listę wyszukiwarek (prawy górny róg, obok paska adresu).
Google Chrome
W przypadku tej przeglądarki, wyszukiwarka dodaje się automatycznie, musimy jedynie zmienić słowo kluczowe.
Internet Explorer
Podobnie, jak w przypadku Firefoksa musimy rozwinąć pasek wyszukiwarek i dodać naszą wyszukiwarkę ręcznie.
Opera
Tutaj jednak musimy zrobić wyszukiwarkę własnoręcznie, nie da się kliknąć i dodać gotowca. Przechodzimy do preferencji (CTRL+F12) / Wyszukiwanie. Klikamy na „Dodaj” i uzupełniamy kolejno formularz, jak na zrzucie.
Kilka informacji
To co tutaj opisałem to jest tylko zalążek możliwości tego mechanizmu. Więcej informacji można znaleźć na stronie: http://www.opensearch.org/Specifications/OpenSearch/1.1. Swoją drogą wpis ten napisałem, bo chciałem napisać w końcu coś bardziej przydatnego, a przy okazji przetestować Shortcode (Custom, to przez Ciebie! Bo to u Ciebie je podpatrzyłem).
Dodaj komentarz