File: Zend_Controller-QuickStart.xml

package info (click to toggle)
zendframework 1.12.9%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 133,584 kB
  • sloc: xml: 1,311,829; php: 570,173; sh: 170; makefile: 125; sql: 121
file content (305 lines) | stat: -rw-r--r-- 12,173 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
<sect1 id="zend.controller.quickstart">
    <title>Szybki start z klasą Zend_Controller</title>

    <sect2 id="zend.controller.quickstart.introduction">
        <title>Wprowadzenie</title>
        <para>
            Klasa <code>Zend_Controller</code> jest sercem systemu MVC
            biblioteki Zend Framework. MVC oznacza <ulink
                url="http://pl.wikipedia.org/wiki/Model-widok-kontroler">Model-Widok-Kontroler</ulink>
            i jest wzorcem projektowym mającym na celu oddzielenie logiki
            aplikacji od logiki wyświetlania. Klasa
            <code>Zend_Controller_Front</code> implementuje wzorzec projektowy
            <ulink
                url="http://www.martinfowler.com/eaaCatalog/frontController.html">kontrolera
                frontowego</ulink>. Wszystkie żądania są przechwytywane
            przez kontroler frontowy i na podstawie adresu URL uruchamiany
            jest odpowiedni kontroler akcji.
        </para>
        <para>
            The <code>Zend_Controller</code> system was built with extensibility
            in mind, either by subclassing the existing classes, writing new
            classes that implement the various interfaces and abstract classes
            that form the foundation of the controller family of classes, or
            writing plugins or action helpers to augment or manipulate the
            functionality of the system.
        </para>
    </sect2>

    <sect2 id="zend.controller.quickstart.go">
        <title>Szybki start</title>

        <para>
            If you need more in-depth information, see the following sections.
            If you just want to get up and running quickly, read on.
        </para>

        <sect3 id="zend.controller.quickstart.go.directory">
            <title>Utwórz strukturę katalogów</title>

            <para>
                Pierwszym krokiem jest utworzenie struktury katalogów. Typowa
                struktura wygląda w taki sposób:
            </para>

            <programlisting role="php"><![CDATA[
application/
    controllers/
        IndexController.php
    models/
    views/
        scripts/
            index/
                index.phtml
        helpers/
        filters/
html/
    .htaccess
    index.php
]]>
            </programlisting>

        </sect3>

        <sect3 id="zend.controller.quickstart.go.docroot">
            <title>Ustaw główną ścieżkę serwera</title>

            <para>
                W swoim serwerze www, ustaw główną ścieżkę serwera na katalog
                <code>html</code> znajdujący się w powyższej przykładowej
                strukturze katalogów.
            </para>
        </sect3>

        <sect3 id="zend.controller.quickstart.go.rewrite">
            <title>Ustaw reguły przepisania</title>

            <para>
                Zedytuj plik <code>html/.htaccess</code> aby wyglądał w taki
                sposób:
            </para>

            <programlisting role="php"><![CDATA[
RewriteEngine on
RewriteRule !\.(js|ico|gif|jpg|png|css)$ index.php
]]>
            </programlisting>

            <para>
                The above rules will route any non-resource (images,
                stylesheets) requests to the front controller. If there are
                other extensions you wish to exclude from the front controller
                (PDFs, text files, etc), add their extensions to the switch, or
                create your own rewrite rules.
            </para>

            <note>
                <para>
                    Powyższe reguły przepisania przygotowane sa dla serwera
                    Apache; aby zobaczyć przykładowe reguły dla innych serwerów,
                    zobacz <link
                      linkend="zend.controller.router.introduction">dokumentację
                    routera</link>.
                </para>
            </note>
        </sect3>

        <sect3 id="zend.controller.quickstart.go.bootstrap">
            <title>Utwórz plik ładujący</title>

            <para>
                Plik ładujący jest miejscem, przez którze przechodzą wszystkie
                żądania -- w tym przypadku jest to -- <code>html/index.php</code>.
                Otwórz plik <code>html/index.php</code> w dowolnym edytorze i
                dodaj poniższy kod:
            </para>

            <programlisting role="php"><![CDATA[
Zend_Controller_Front::run('/path/to/app/controllers');
]]>
            </programlisting>

            <para>
                Utworzy to egzemplarz kontrolera frontowego i go uruchomi,
                co spowoduje przekazanie żądań do kontrolerów akcji.
            </para>
        </sect3>

        <sect3 id="zend.controller.quickstart.go.controller">
            <title>Utwórz domyślny kontroler akcji</title>

            <para>
                Before discussing action controllers, you should first
                understand how requests are routed in Zend Framework. By
                default, the first segment of a URL path maps to a controller,
                and the second to an action. For example, given the URL
                <code>http://framework.zend.com/roadmap/components</code>, the
                path is <code>/roadmap/components</code>, which will map to the
                controller <code>roadmap</code> and the action
                <code>components</code>. If no action is provided, the action
                <code>index</code> is assumed, and if no controller is provided,
                the controller <code>index</code> is assumed (following the
                Apache convention that maps a <code>DirectoryIndex</code>
                automatically).
            </para>

            <para>
                <code>Zend_Controller</code>'s dispatcher then takes the
                controller value and maps it to a class. By default, it
                Title-cases the controller name and appends the word
                <code>Controller</code>. Thus, in our example above, the
                controller <code>roadmap</code> is mapped to the class
                <code>RoadmapController</code>.
            </para>

            <para>
                Similarly, the action value is mapped to a method of the
                controller class. By default, the value is lower-cased, and the
                word <code>Action</code> is appended. Thus, in our example
                above, the action <code>components</code> becomes
                <code>componentsAction</code>, and the final method called is
                <code>RoadmapController::componentsAction()</code>.
            </para>

            <para>
                Idąc dalej, utwórzmy teraz domyślny kontroler akcji i metodę
                akcji. Jak wspomniano wcześniej, domyślna nazwa kontrolera oraz
                akcji to <code>index</code>. Otwórz w edytorze plik
                <code>application/controllers/IndexController.php</code>, i
                dodaj poniższy kod:
            </para>

            <programlisting role="php"><![CDATA[
class IndexController extends Zend_Controller_Action
{
    public function indexAction()
    {
    }
}
]]>
            </programlisting>

            <para>
                By default, the <link
                    linkend="zend.controller.actionhelpers.viewrenderer">ViewRenderer</link>
                action helper is enabled. What this means is that by simply
                defining an action method and a corresponding view script, you
                will immediately get content rendered.  By default,
                <code>Zend_View</code> is used as the View layer in the MVC. The
                <code>ViewRenderer</code> does some magic, and uses the
                controller name (e.g., <code>index</code>) and the current
                action name (e.g., <code>index</code>) to determine what
                template to pull. By default, templates end in the
                <code>.phtml</code> extension, so this means that, in the above
                example, the template <code>index/index.phtml</code> will be
                rendered. Additionally, the <code>ViewRenderer</code>
                automatically assumes that the directory <code>views</code> at
                the same level as the controller directory will be the base view
                directory, and that the actual view scripts will be in the
                <code>views/scripts/</code> subdirectory. Thus, the template
                rendered will be found in
                <code>application/views/scripts/index/index.phtml</code>.
            </para>
        </sect3>

        <sect3 id="zend.controller.quickstart.go.view">
            <title>Utwórz własny skrypt widoku</title>

            <para>
                As mentioned <link
                    linkend="zend.controller.quickstart.go.controller">in the
                    previous section</link>, view scripts are found in
                <code>application/views/scripts/</code>; the view script for the
                default controller and action is in
                <code>application/views/scripts/index/index.phtml</code>. Create
                this file, and type in some HTML:
            </para>

            <programlisting role="php"><![CDATA[
<!DOCTYPE html
PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  <title>Pierwsza aplikacja Zend Framework</title>
</head>
<body>
    <h1>Witaj!</h1>
</body>
</html>
]]>
            </programlisting>
        </sect3>

        <sect3 id="zend.controller.quickstart.go.errorhandler">
            <title>Utwórz kontroler błędu</title>

            <para>
                Domyślnie, <link
                    linkend="zend.controller.plugins.standard.errorhandler">wtyczka
                obsługi błędów</link> jest zarejestrowana. Ta wtyczka
                expects that a controller exists to handle errors.
                By default, it assumes an <code>ErrorController</code> in the
                default module with an <code>errorAction</code> method:
            </para>

            <programlisting role="php"><![CDATA[
class ErrorController extends Zend_Controller_Action
{
    public function errorAction()
    {
    }
}
]]>
            </programlisting>

            <para>
                Assuming the already discussed directory layout, this file will
                go in <code>application/controllers/ErrorController.php</code>.
                You will also need to create a view script in
                <code>application/views/scripts/error/error.phtml</code>; sample
                content might look like:
            </para>

            <programlisting role="php"><![CDATA[
<!DOCTYPE html
PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  <title>Błąd</title>
</head>
<body>
    <h1>Wystąpił błąd</h1>
    <p>Wystąpił błąd; spróbuj ponownie później.</p>
</body>
</html>
]]>
            </programlisting>
        </sect3>

        <sect3 id="zend.controller.quickstart.go.finish">
            <title>Zobacz stronę!</title>

            <para>
                With your first controller and view under your belt, you can now
                fire up your browser and browse to the site. Assuming
                <code>example.com</code> is your domain, any of the following
                URLs will get to the page we've just created:
            </para>

            <itemizedlist>
                <listitem><para><code>http://example.com/</code></para></listitem>
                <listitem><para><code>http://example.com/index</code></para></listitem>
                <listitem><para><code>http://example.com/index/index</code></para></listitem>
            </itemizedlist>

            <para>
                Teraz jesteś gotowy do tworzenia kolejnych kontrolerów i metod
                akcji. Gratulacje!
            </para>
        </sect3>
    </sect2>
</sect1>