Sorun: CRLFolarak kodlanmış dosyalardan hizmet vermek istiyorumLF
Linux tabanlı bir simülatör tarafından oluşturulan (büyük) günlük dosyalarını ( ) sunmak üzere yapılandırılmış bir apache2 httpd linux tabanlı web sunucum var *.log.
Bu günlük dosyaları, LFWindows tarzı yerine Unix tarzı biter CRLF. CRLFayrıca httpprotokoldeki metin dosyaları için standart olduğu ortaya çıkıyor .
Onları Windows'ta bir tarayıcı kullanarak görüntülediğimde Notepad.exe'ye yüklenir ve tüm metinler aynı satırda (yanlış) olur; Ben gelen sunucuda günlükleri adlandırmak sürece
*.logkadar *.txt.
Görünen o ki, Microsoft Windows muhtemelen *.txtözel olarak çalışıyor ve geldikleri gibi sonları dönüştürüyor gibi görünüyor .
Bu ipuçları göz önüne alındığında, kurulumu nasıl değiştirebilirim ki müşteri kullanıcılarının platform / tarayıcıdan bağımsız olarak dosyaları doğru görebilsinler.
Daha fazla sorun detayı: neden bariz şeyi yapamıyorum
Günlükleri analiz, bunu bulmak .txtmim-türü olarak servis edilir text/plainve .logsıra text/x-logfakat anahtarlama .logiçin text/plainkullanarak SetTypesorunu çözmek vermedi.
Bir üretim sisteminde kolayca sona erecek dosyaları değiştiremeyeceğim .txt.
Günlükleri kullanarak (örneğin unix2dos) dönüştürmek ve başka bir kopya kaydetmek istemek benim için çok büyük ve büyük . Ayrıca bu, geçersiz kılınması, silinmesi, vb. Yapılması gereken, dönüştürülen dosyaların ek önbelleğini yönetmeye zorlar veya bunları tüketen diğer sistemleri bozabilecek orijinal dosyaları değiştirir.
- O genişletmek gerektiğini Windows'u / Internet Explorer (ve diğer işletim / tarayıcı) söyleyen bir Apache yapılandırma parametresi var mıdır
LFiçinCRLFulaştığı anda? - YA ben bir şekilde yerine Apache söyleyebilir
LFileCRLFbunu hizmet vermektedir olarak anında?
Ne denedim
Birlikte verilen Apache mod_mimemodülüne ve direktiflerine baktım AddTypeve AddCharsetbunlar sorunu çözmedi, hatta iddia etmediler.
Apache belgeleri satır sonuyla ilgili sessiz.
Türdeki MIME belgeleri text, içeriğin CRLF biçiminde olması gerektiğini belirtir .
Ayrıca satır sonunun karakter kümesi kodlama standartları tarafından dikkate alınmadığı da anlaşılmaktadır.
text/plainCRLF sonları ile sunulması ilginç olsa da , Apache'nin bunları dönüştürmede yer alması gereken bir şey değil; Sunmak için verilenlere hizmet etmeyi ve dosyaları üreten her ne olursa olsun RFC'ye uyum sağlamayı tercih ederim. Daha iyi bir editör edinin; Tavsiye yığınına Scite atacağım .