summaryrefslogtreecommitdiffstats
path: root/docs/manual/env.xml.tr
blob: f3b812ad179c38c40fcfc0aefd5772f770d06e9c (plain)
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
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE manualpage SYSTEM "./style/manualpage.dtd">
<?xml-stylesheet type="text/xsl" href="./style/manual.tr.xsl"?>
<!-- English Revision: 1300910:1330883 (outdated) -->
<!-- =====================================================
 Translated by: Nilgün Belma Bugüner <nilgun belgeler.org>
   Reviewed by: Orhan Berent <berent belgeler.org>
========================================================== -->

<!--
 Licensed to the Apache Software Foundation (ASF) under one or more
 contributor license agreements.  See the NOTICE file distributed with
 this work for additional information regarding copyright ownership.
 The ASF licenses this file to You under the Apache License, Version 2.0
 (the "License"); you may not use this file except in compliance with
 the License.  You may obtain a copy of the License at

     http://www.apache.org/licenses/LICENSE-2.0

 Unless required by applicable law or agreed to in writing, software
 distributed under the License is distributed on an "AS IS" BASIS,
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 See the License for the specific language governing permissions and
 limitations under the License.
-->

<manualpage metafile="env.xml.meta">

  <title>Apache’de Ortam Değişkenleri</title>

  <summary>
    <p>Apache HTTP Sunucusunu etkileyen ortam değişkenleri iki çeşittir.</p>

    <p>İlki, işletim sisteminin denetimindeki ortam değişkenleridir. Bu
      değişkenlere değer atama işlemi sunucu başlatılmadan önce yapılır.
      Bunlar yapılandırma dosyalarının içinde kullanılabilir. Ayrıca,
      istenirse PassEnv yönergesi kullanılarak bunlar CGI betiklerine ve
      SSI sayfalarına da aktarılabilir.</p>

    <p>İkincisi ise, Apache HTTP Sunucusunun kendi ortam değişkenleridir.
      Bu değişkenlerde saklanan bilgi erişim denetimi, günlük kaydı gibi
      çeşitli işlemleri denetlemekte kullanılabilir. Değişkenler ayrıca, CGI
      betikleri gibi harici uygulamalarla iletişim mekanizması olarak da
      kullanılabilir. Bu belgede bu değişkenler üzerindeki işlemlere ve
      kullanım şekillerine değinilmiştir.</p>

    <p>Bu değişkenlere <em>ortam değişkenleri</em> dense de işletim sisteminin
      ortam değişkenleri gibi değillerdir. Bunlar sadece Apache ortamında
      geçerli değişkenler olup işletim sisteminin bu değişkenlerden haberi
      olmaz. Sadece CGI betikleri ve SSI sayfaları gibi harici uygulamalar
      tarafından üretilen ortam değişkenleri sistem ortamının değişkenleri
      haline gelirler. İşletim sistemi ortamına çalışmakta olan sunucudan
      müdahale etmek isterseniz işletim sisteminizin kabuğu tarafından sağlanan
      standart ortam müdahale mekanizmalarını kullanmalısınız.</p>
  </summary>

  <section id="setting">
    <title>Ortam Değişkenlerinin Atanması</title>
    <related>
      <modulelist>
        <module>mod_cache</module>
        <module>mod_env</module>
        <module>mod_rewrite</module>
        <module>mod_setenvif</module>
        <module>mod_unique_id</module>
      </modulelist>
      <directivelist>
        <directive module="mod_setenvif">BrowserMatch</directive>
        <directive module="mod_setenvif">BrowserMatchNoCase</directive>
        <directive module="mod_env">PassEnv</directive>
        <directive module="mod_rewrite">RewriteRule</directive>
        <directive module="mod_env">SetEnv</directive>
        <directive module="mod_setenvif">SetEnvIf</directive>
        <directive module="mod_setenvif">SetEnvIfNoCase</directive>
        <directive module="mod_env">UnsetEnv</directive>
      </directivelist>
    </related>

    <section id="basic-manipulation">
        <title>Temel Ortamda Değişiklik</title>

        <p>Apache ortamında bir ortam değişkenine müdahale etmenin en temel
          yolu hiçbir koşula tabi olmayan <directive module="mod_env"
          >SetEnv</directive> yönergesini kullanmaktır. Bu değişkenleri Apache
          başlatılırken sistem ortam değişkenleri haline getirmek için
          <directive module="mod_env">PassEnv</directive> yönergesi
          kullanılabilir.</p>

    </section>
    <section id="conditional">
        <title>İsteğe Bağlı Şartlı Atamalar</title>

        <p>Esnekliği arttırmak için, <module>mod_setenvif</module> modülü ile
          isteğin özelliklerine uygun olarak her isteğe özel değişkenler
          atayabilmek mümkün kılınmıştır. Örneğin, bir değişken sadece isteği
          yapan tarayıcıya özgü bir değerle veya sadece belli bir başlık
          alanınına bağlı olarak atanabilir. Daha da esnek bir mekanizma,
          ortam değişkeni atamak için <code>[E=...]</code> seçeneğinin
          kullanıldığı <module>mod_rewrite</module> modülünün <directive
          module="mod_rewrite" >RewriteRule</directive> yönergesi ile
          sağlanmıştır.</p>

    </section>
    <section id="unique-identifiers">
        <title>Eşsiz Betimleyiciler</title>

        <p>Son olarak, <module>mod_unique_id</module> <code>UNIQUE_ID</code>
          ortam değişkenine her istek için o isteğin çok özel koşullar altında
          tüm diğer istekler arasında eşsizliğini garanti edecek bir değer
          atar.</p>

    </section>
    <section id="standard-cgi">
        <title>Standart CGI Değişkenleri</title>

        <p>Apache yapılandırmasıyla atanan ve kabuğa aktarılan ortam
          değişkenlerinden başka <a href="http://www.ietf.org/rfc/rfc3875">CGI
          Belirtimi</a>nin gerektirdiği istekler hakkında temel bilgileri
          içeren ortam değişkenlerinin CGI betikleri ve SSI sayfalarınca
          atanabilmesi sağlanmıştır.</p>

    </section>
    <section id="caveats">
        <title>Bazı Yetersizlikler</title>

        <ul>
          <li>Standart CGI değişkenlerini ortam değişkenlerine müdahale
            yönergelerini kullanarak değiştirmek veya geçersiz kılmak mümkün
            değildir.</li>

          <li>CGI betiklerini çalıştırmak için <program>suexec</program>
            kullanıldığında ortam, CGI betikleri çalıştırılmadan önce
            <em>güvenilir</em> değişkenler kalacak şekilde temizlenir.
            <em>Güvenilir</em> değişken listesi <code>suexec.c</code> içinde
            derleme sırasında tanımlanır.</li>

          <li>Taşınabilirlik adına, ortam değişkenlerinin isimleri sadece
            harfler, rakamlar ve alt çizgi imlerini içerebilir. Bunlara ek
            olarak ismin ilk karakteri bir rakam olmamalıdır. Değişkenler CGI
            betiklerine ve SSI sayfalarına aktarılırken bu sınırlamalara uygun
            olmayan karakterlerin yerlerine alt çizgi imleri konur.</li>

          <li>Bir özel durum, CGI betiklerine ve benzerlerine ortam
            değişkenleri üzerinden aktarılan HTTP başlıklarıdır (aşağıya
            bakın). Bunlar büyük harfe dönüştürülür ve sadece tireler
            altçizgilere dönüştürülür. Eğer HTTP başlığı geçersiz karakter
            içeriyorsa başlığın tamamı yoksayılır. Böyle bir durumda ne
            yapılacağı öğrenmek için <a href="#fixheader">aşağıya</a>
            bakın.</li>

          <li>İsteklerin işleme konması sırasında <directive
            module="mod_env">SetEnv</directive> yönergesi geç çalıştırılır,
            yani <directive module="mod_setenvif">SetEnvIf</directive> ve
            <directive module="mod_rewrite">RewriteCond</directive> gibi
            yönergeler <directive module="mod_env">SetEnv</directive> ile
            atanan değişken değerlerini görmezler.</li>
        </ul>
    </section>
  </section>
  <section id="using">
    <title>Ortam Değişkenlerinin Kullanımı</title>

    <related>
      <modulelist>
        <module>mod_authz_host</module>
        <module>mod_cgi</module>
        <module>mod_ext_filter</module>
        <module>mod_headers</module>
        <module>mod_include</module>
        <module>mod_log_config</module>
        <module>mod_rewrite</module>
      </modulelist>
      <directivelist>
        <directive module="mod_access_compat">Allow</directive>
        <directive module="mod_log_config">CustomLog</directive>
        <directive module="mod_access_compat">Deny</directive>
        <directive module="mod_ext_filter">ExtFilterDefine</directive>
        <directive module="mod_headers">Header</directive>
        <directive module="mod_log_config">LogFormat</directive>
        <directive module="mod_rewrite">RewriteCond</directive>
        <directive module="mod_rewrite">RewriteRule</directive>
      </directivelist>
    </related>

    <section id="cgi-scripts">
        <title>CGI Betikleri</title>

        <p>Ortam değişkenlerinin başlıca amaçlarından biri CGI betikleriyle
          iletişim kurmaktır. Yukarıda bahsedildiği gibi CGI betiklerine
          aktarılan ortam Apache yapılandırmasında atanan değişkenlere ek
          olarak istek hakkında standart temel bilgileri de içerir. Bu konuda
          ayrıntılı bilgi edinmek için <a href="howto/cgi.html">CGI
          Öğreticisi</a>ne bakabilirsiniz.</p>

    </section>
    <section id="ssi-pages">
        <title>SSI Sayfaları</title>

        <p>Sunucu tarafında <module>mod_include</module> modülünün
          <code>INCLUDES</code> süzgeci ile yorumlanan SSI sayfalarında ortam
          değişkenleri <code>echo</code> elemanı ile basılabilir ve sayfayı
          isteğin özelliklerine uygun olarak oluşturmak için ortam
          değişkenleri akış denetim elemanları içinde kullanılabilir. Apache
          ayrıca, yukarıda bahsedildiği gibi standart CGI ortam değişkenli SSI
          sayfalarını da sağlayabilmektedir. Daha ayrıntılı bilgi edinmek için
          <a href="howto/ssi.html" >SSI Öğreticisi</a>ne bakabilirsiniz.</p>

    </section>
    <section id="access-control">
        <title>Erişim Denetimi</title>

        <p><code>allow from env=</code> ve <code>deny from env=</code>
          yönergeleri sayesinde ortam değişkenlerine dayalı olarak sunucuya
          erişim denetim altında tutulabilir. Bunlar <directive
          module="mod_setenvif">SetEnvIf</directive> yönergesi ile birlikte
          kullanılmak suretiyle sunucuya erişim isteğin özelliklerine bağlı
          olarak daha esnek bir tarzda denetlenebilir. Örneğin, belli bir
          tarayıcının sunucuya erişimi bu yönergelerle engellenebilir.</p>

    </section>
    <section id="logging">
        <title>Şartlı Günlük Kaydı</title>

        <p>Ortam değişkenleri <directive module="mod_log_config"
          >LogFormat</directive> yönergesinin <code>%e</code> seçeneği
          kullanılarak erişim günlüğüne kaydedilebilir. Bundan başka,
          <directive module="mod_log_config">CustomLog</directive> yönergesi
          sayesinde isteklerin günlüğe kaydedilip kaydedilmeyeceğine ortam
          değişkenlerine dayalı olarak karar verilmesi sağlanabilir. Bunlar
          <directive module="mod_setenvif">SetEnvIf</directive> yönergesi ile
          birlikte kullanılmak suretiyle günlük kayıtları isteğin
          özelliklerine bağlı olarak daha esnek bir tarzda denetlenebilir.
          Örneğin, <code>gif</code> uzantılı dosyalar için yapılan isteklerin
          günlüğe kaydedilmemesi veya sadece alt ağınızın dışından gelen
          isteklerin günlüğe kaydedilmesini isteyebilirsiniz.</p>

    </section>
    <section id="response-headers">
        <title>Şartlı Yanıt Başlıkları</title>

        <p><directive module="mod_headers">Header</directive> yönergesi belli
          bir yanıt başlığının istemciye gönderilip gönderilmeyeceğine belli
          bir ortam değişkeninin varlığına bakarak karar vermek için
          kullanılabilir. Böylece örneğin, belli bir başlığın istemciye
          gönderilmesine istemciden belli bir başlığın alınıp alınmadığına
          bağlı olarak karar verilebilir.</p>

    </section>

    <section id="external-filter">
        <title>Harici Süzgeçlerin Etkinleştirilmesi</title>

        <p><module>mod_ext_filter</module> tarafından yapılandırılan harici
          süzgeçler <directive module="mod_ext_filter"
          >ExtFilterDefine</directive> yönergesinin <code>disableenv=</code> ve
          <code>enableenv=</code> seçenekleri kullanılarak bir ortam
          değişkenine bağlı olarak etkinleştirilebilir.</p>
    </section>

    <section id="url-rewriting">
        <title>URL Kurgulaması</title>

        <p><directive module="mod_rewrite">RewriteCond</directive>
          yönergesinin <em>SınamaDizgesi</em> olarak kullanılan
          <code>%{ENV:<em>değişken</em>}</code> biçemi
          <module>mod_rewrite</module> yeniden yazma motorunun ortam
          değişkenlerine bağlı kararlar almasını mümkün kılar. Yalnız şuna
          dikkat ediniz: <module>mod_rewrite</module>’ta <code>ENV:</code>
          öneki kullanılmadan belirtilen değişkenler ortam değişkenleri
          değillerdir. Onlar <module>mod_rewrite</module>’a özgü diğer
          modüllerden erişilemeyen özel değişkenlerdir.</p>
    </section>
  </section>

  <section id="special">
    <title>Özel Amaçlı Ortam Değişkenleri</title>

        <p>Birlikte çalışabilirlik sorunları Apache’nin belli istemcilerle
          veri alışverişi sırasında davranışını değiştirmesini gerektirebilir.
          Genellikle <directive module="mod_env" >SetEnv</directive> ve
          <directive module="mod_env" >PassEnv</directive> yönergelerinden
          başka <directive module="mod_setenvif" >BrowserMatch</directive>
          gibi yönergelerle ortam değişkenleri atanarak bunu sağlayan
          mekanizmaların olabildiğince esnek davranabilmesi sağlanabilir.</p>

    <section id="downgrade">
        <title><code>downgrade-1.0</code></title>

        <p>İstek, daha yüksek bir HTTP protokolüyle yapılmış olsa bile
          HTTP/1.0 isteği olarak ele alınır.</p>

    </section>
    <section id="force-gzip">
        <title><code>force-gzip</code></title>
          <p><code>DEFLATE</code> süzgeci etkinse tarayıcının tercih ettiği
            kodlama koşulsuz olarak yoksayılarak sıkıştırılmış çıktı
            gönderilir.</p>
    </section>
    <section id="force-no-vary">
        <title><code>force-no-vary</code></title>

        <p>İstemciye gönderilmeden önce yanıttan <code>Vary</code> alanının
          çıkarılmasına sebep olur. Bazı istemciler bu alanı gerektiği gibi
          yorumlayamazlar, bu değişken atanarak bu sorunla karşılaşılmamaya
          çalışılır. Bu değişkenin atanması ayrıca
          <strong>force-response-1.0</strong> değişkeninin de atanmasına sebep
          olur.</p>

    </section>
    <section id="force-response">
        <title><code>force-response-1.0</code></title>

      <p>HTTP/1.0 isteği yapan istemcilere HTTP/1.0 yanıtı verilmesini zorunlu
        kılar. AOL vekillerindeki bir sorun nedeniyle gerçeklenmiştir. Bazı
        HTTP/1.0 istemciler HTTP/1.1 yanıtlarında doğru davranmayabilirler; bu
        değişken atanarak bunların sorunları giderilebilir.</p>

    </section>

    <section id="gzip-only-text-html">
        <title><code>gzip-only-text/html</code></title>

        <p>Bu değişkene "1" değeri atandığında <code>text/html</code>’den
          farklı içerik türleri için <module>mod_deflate</module> modülü
          tarafından sağlanan <code>DEFLATE</code>  çıktı süzgeci iptal
          edilir. Sıkıştırılmış olarak saklanan dosyalar kullanıyorsanız bu
          değişkeni <module>mod_negotiation</module> modülü de dikkate alır
          (kimliğine bakarak sadece gzip için değil, tüm kodlamalar için bunu
          yapar).</p>
    </section>

    <section id="no-gzip"><title><code>no-gzip</code></title>

        <p>Bu değişken atandığında, <module>mod_deflate</module> modülünün
          <code>DEFLATE</code> süzgeci kapatılır ve
          <module>mod_negotiation</module> modülü kodlanmış kaynak teslimatını
          reddeder.</p>

    </section>

    <section id="no-cache"><title>no-cache</title>
        <p><em>2.2.12 sürümünden beri kullanılabilmektedir.</em></p>

        <p>Atandığı takdirde, <module>mod_cache</module> artık
        önbelleklenebilecek yanıtları kaydetmeyecektir. Bu ortam değişkeni bir
        yanıtın halihazırda mevcut bir isteğe sunulmak üzere önbellekte olup
        olmadığından etkilenmez.</p>

    </section>

    <section id="nokeepalive">
        <title><code>nokeepalive</code></title>

        <p>Bu değişken atandığında, <directive module="core"
          >KeepAlive</directive> yönergesi iptal edilir.</p>

    </section>

    <section id="prefer-language">
        <title><code>prefer-language</code></title>

        <p>Değer olarak <code>en</code>, <code>ja</code> veya
          <code>x-klingon</code> gibi bir dil kısaltması verilerek atanmışsa
          <module>mod_negotiation</module> modülünün normal davranışını
          değiştirerek belirtilen dilde bir teslimat yapılmaya çalışılır.
          Böyle bir belge yoksa normal <a
          href="content-negotiation.html">uzlaşım</a> süreci uygulanır.</p>

    </section>

    <section id="redirect-carefully">
        <title><code>redirect-carefully</code></title>

        <p>İstemciye bir yönlendirme gönderirken sunucuyu daha dikkatli olmaya
          zorlar. Bu genellikle istemcinin yönlendirmeler konusunda sorunlu
          olduğu bilindiği takdirde yararlı olur. Bu değişkenin gerçeklenme
          sebebi, dizin kaynaklarına yönlendirmeler için DAV yöntemlerini
          kullanan Microsoft'un WebFolders yazılımındaki bir sorundur.</p>

    </section>

   <section id="suppress-error-charset">
       <title><code>suppress-error-charset</code></title>

    <p><em>2.0.54 sürümünden beri mevcuttur.</em></p>

    <p>Apache bir isteğe bir yönlendirme ile yanıt verdiğinde istemci
      yönlendirmeyi kendiliğinden yapmaz veya yapamazsa kullanıcıya yanıtla
      birlikte gönderilen metin gösterilir. Apache normal olarak bu metni
      ISO-8859-1 ile kodlar.</p>

    <p>Ancak, yönlendirmenin yapıldığı sayfa farklı bir karakter kümesine
      sahipse bazı tarayıcı sürümleri asıl sayfanın karakter kodlaması yerine
      yönlendirmenin kodlamasını kullanmaya çalışırlar. Bu özellikle Yunanca
      gibi dillerde hedef sayfanın hatalı yorumlanmasına yol açar.</p>

    <p>Bu ortam değişkeninin atanması Apache’nin yönlendirme için karakter
      kümesi belirtmemesini sağlamak suretiyle hatalı tarayıcıların hedef
      sayfayı yanlış karakter kodlamasıyla yorumlamasını önler.</p>

    <note type="warning">
      <title>Güvenlik Uyarısı</title>

      <p>Hata sayfalarının bir karakter kümesi belirtilmeksizin yollanması,
        HTTP/1.1 belirtimine uymayan ve karakter kümesini içeriğe bakarak
        tahmin etmeye çalışan tarayıcılarda (MSIE) karşı siteden betik
        saldırısı yorumuna sebep olabilir.  Girdi verisindeki UTF-7 içerik
        (istek betimleyici gibi) karşı siteden betik saldırılarını engellemek
        için tasarlanmış normal önceleme mekanizmalarıyla öncelenmeyeceği için
        böyle tarayıcılar UTF-7 karakter kodlaması kullanılarak kolayca
        aldatılabilir.</p>
    </note>

   </section>

   <section id="proxy"><title><code>force-proxy-request-1.0</code>,
    <code>proxy-nokeepalive</code>, <code>proxy-sendchunked</code> ve
    <code>proxy-sendcl</code>, <code>proxy-chain-auth</code>,
    <code>proxy-interim-response</code>, <code>proxy-initial-not-pooled</code>
    </title>

   <p>Bu yönergeler <module>mod_proxy</module> modülünün normal protokol
    davranışını değiştirirler. Daha ayrıntılı bilgi için
    <module>mod_proxy</module> ve <module>mod_proxy_http</module>
    belgelerine bakınız.</p>
   </section>

  </section>

  <section id="examples">
    <title>Örnekler</title>

    <section id="fixheader">
      <title>Bozuk başlıkların CGI betiklerine aktarılması</title>

      <p>2.4 sürümünden itibaren, <module>mod_cgi</module> modülü ve diğer
        modüllerde HTTP başlıklarının ortam değişkenlerine dönüştürülmesi
        bağlamında Apache daha seçici davranmaktadır. Önce HTTP başlığındaki
        geçersiz karakterlerin tamamı altçizgilere dönüştürülür. Bu, başlık
        zerki yoluyla yapılan karşı-site-betiklerini-çalıştırma saldırısını
        önlemeye yöneliktir. (Bakınız: <a
        href="http://events.ccc.de/congress/2007/Fahrplan/events/2212.en.html"
        >Unusual Web Bugs</a>, slide 19/20).</p>

      <p>Bozuk başlıklar gönderdiği halde bunlara dokunulmamasını gerektiren
        bir istemciniz varsa, <module>mod_setenvif</module> ve
        <module>mod_header</module> modüllerinin sunduğu yapıyı örnekteki gibi
        kullanarak bu sorunun üstesinden gelebilirsiniz:</p>

<example>
# <br />
# Aşağıdaki satırlarla bir istemcinin gönderdiği bozuk<br />
# Accept_Encoding başlıklarının istenildiği gibi işlenmesi<br />
# sağlanabilir.<br />
#<br />
SetEnvIfNoCase ^Accept.Encoding$ ^(.*)$ fix_accept_encoding=$1<br />
RequestHeader set Accept-Encoding %{fix_accept_encoding}e env=fix_accept_encoding
</example>

    </section>

    <section id="misbehaving">
        <title>Protokolü yanlış yorumlayan tarayıcıların davranışlarının
        değiştirilmesi</title>

        <p>Önceki sürümlerde bilinen istemci davranışlarına karşı önlem olarak
          aşağıdaki satırların <code>httpd.conf</code> içinde bulunması
          önerilirdi. Fakat, böyle tarayıcılar artık ortalıkta görünmediğinden
          bu yapılandırmaya da artık gerek kalmamıştır.</p>

<example>
#<br />
# Aşağıdaki yönergeler normal HTTP yanıt davranışını değiştirirler.<br />
# İlk yönerge Netscape 2.x ve kendini öyle gösteren tarayıcılar için<br />
# kalıcı bağlantıyı (keepalive) iptal eder. İkinci yönerge ise HTTP/1.1<br />
# protokolü bozuk olan ve 301/302 durum kodlu yönlendirme yanıtları<br />
# kullanıldığında kalıcı bağlantıları gerektiği gibi desteklemeyen<br />
# Microsoft Internet Explorer 4.0b2 içindir.<br />
#<br />
BrowserMatch "Mozilla/2" nokeepalive<br />
BrowserMatch "MSIE 4\.0b2;" nokeepalive downgrade-1.0 force-response-1.0<br />
<br />
#<br />
# Aşağıdaki yönergeler HTTP/1.0 yanıtlarından başkasına yabancı olan<br />
# tarayıcılara HTTP/1.1 yanıtlarının gönderilmesini iptal eder.<br />
#<br />
BrowserMatch "RealPlayer 4\.0" force-response-1.0<br />
BrowserMatch "Java/1\.0" force-response-1.0<br />
BrowserMatch "JDK/1\.0" force-response-1.0
</example>

    </section>
    <section id="no-img-log">
        <title>Resim isteklerinin erişim günlüğüne kaydedilmemesi</title>

        <p>Bu örnek resim isteklerinin erişim günlüğüne yazılmasını engeller.
          Bu örnek değiştirilerek belli dizinlerin veya belli konaklardan
          gelen isteklerin günlüğe kaydedilmesini engellemek amacıyla da
          kullanılabilir.</p>

        <example>
          SetEnvIf Request_URI \.gif image-request<br />
          SetEnvIf Request_URI \.jpg image-request<br />
          SetEnvIf Request_URI \.png image-request<br />
          CustomLog logs/access_log common env=!image-request
        </example>

    </section>
    <section id="image-theft">
        <title>“Resim Hırsızlığı” için önlem alınması</title>

        <p>Bu örnekte sunucunuzda bulunmayan sayfalarda sunucunuzdaki
          resimlerin kullanılmasının nasıl önleneceği gösterilmiştir. Bu
          yapılandırma önerilmemekle birlikte nadir durumlarda işe yarar. Tüm
          resimlerin <code>/siteler/resimler</code> dizini altında tutulduğu
          varsayılmıştır.</p>

        <example>
          SetEnvIf Referer "^http://www\.example\.com/" local_referal<br />
          # Referrer bilgisi göndermeyen tarayıcılara izin verelim<br />
          SetEnvIf Referer "^$" local_referal<br />
          &lt;Directory /siteler/resimler&gt;<br />
          <indent>
            Order Deny,Allow<br />
            Deny from all<br />
            Allow from env=local_referal
          </indent>
          &lt;/Directory&gt;
        </example>

        <p>Bu teknik hakkında daha ayrıntılı bilgi edinmek için ServerWatch
          üzerindeki  "<a
          href="http://www.serverwatch.com/tutorials/article.php/1132731"
          >Diğer sitelerin sizin resimlerinizle donatılmasını engellemek</a>"
          belgesine bakınız.</p>
    </section>
  </section>
</manualpage>