Rumah  >  Artikel  >  hujung hadapan web  >  Node kajian NodeJS Sambung modul middleware (1)_node.js

Node kajian NodeJS Sambung modul middleware (1)_node.js

WBOY
WBOYasal
2016-05-16 16:17:451237semak imbas

Saya harap anda boleh terus membaca artikel bersiri ini. Ini juga merupakan dorongan dan sokongan terbesar untuk saya. Okey, mari terus ke topik hari ini,

Apakah itu "Connect" dan bagaimana untuk memahami middleware. Datang ke artikel hari ini dengan soalan.

Bagaimana untuk memahami "perisian tengah"?

Pemahaman saya ialah, perisian tengah adalah sesuatu yang serupa dengan penapis, kaedah antara klien dan aplikasi untuk memproses permintaan dan respons.

Jika anda membandingkan proses pemprosesan http dengan rawatan kumbahan, perisian tengah adalah seperti lapisan penapis. Setiap perisian tengah menulis semula permintaan atau (dan) data tindak balas semasa pemprosesan http,

Status melaksanakan fungsi tertentu.

Apakah itu “Sambung”?

Kita boleh menganggap Connec sebagai koleksi perisian tengah. Untuk setiap permintaan, Connect akan menggunakan lapisan middleware untuk menapis permintaan, setiap satunya boleh mendapatkan permintaan HTTP.

Apabila T.J Holowaychuk bercakap tentang Connect, dia berkata terdapat dua jenis middleware. Salah satunya ialah penapis:

Penapis mengendalikan permintaan, tetapi ia tidak bertindak balas kepada permintaan (fikir log pelayan).

Jenis kedua ialah pembekal, yang akan bertindak balas kepada permintaan Anda boleh menggunakan berbilang middleware mengikut keperluan anda.

2 Pengenalan kepada perisian tengah terbina dalam Connect

Berikut menyenaraikan beberapa middleware utama dan menerangkannya dengan contoh:

(1), cookieParser------perisian tengah menghuraikan kuki, menghuraikan pengepala Kuki untuk mendapatkan kuki melalui req.cookies. Kuki juga boleh disulitkan melalui req.secret.

Salin kod Kod adalah seperti berikut:

var connect = require('./lib/connect') ;
var app = connect()
.use(connect.cookieParser('rentetan rahsia'))
.use(fungsi (req,res,next){
req.cookies.website="hai, saya bigbear ;
res.end(JSON.stringify(req.cookies)) ;
}).dengar(8888) ;

(2), sesi

Penerangan: Perisian tengah pengurusan sesi

Kebergantungan: cookieParser

Parameter: pilihan

pilihan:

Kunci: Nama kuki, nilai lalai ialah connect.sid

kedai: contoh storan sesi

Rahsia: penyulitan kuki sesi

Kuki: konfigurasi kuki sesi, nilai lalai ialah {path: ‘/’, httpOnly: true, maxAge: null}

Proksi: Proksi songsang untuk kuki selamat, dilaksanakan melalui x-forwarded-proto

Pilihan kuki:

Cookie.maxAge: Nilai lalai adalah batal, yang bermaksud kuki dipadamkan apabila penyemak imbas ditutup.

Salin kod Kod adalah seperti berikut:

var connect = require('./lib/connect');
var app = connect()
.use(connect.logger('dev'))
.use(connect.cookieParser())
.use(connect.session({rahsia: '123', kuki: { maxUmur: 60000 }}))
.use(fungsi (req, res, next) {
Jika(req.session.pv){
           res.setHeader('Content-Type', 'text/html');
            res.write('views: ' req.session.pv);
           res.end();
            req.session.pv ;
}lain{
            req.session.pv = 1;
           res.end('Refresh');
}
})
.dengar(8888);

Apabila pelanggan terus memuat semula halaman, "PV" akan terus meningkat dan "Sesi" bahagian pelayan mengekalkan nombor tersebut.

(3), bodyParser------minta perisian tengah parsing kandungan, menyokong pelbagai jenis aplikasi/json, application/x-www-form-urlencoded, multipart/form-data.

Salin kod Kod adalah seperti berikut:

var connect = require('connect');
var app = connect()
.use(connect.bodyParser())
.use(function(req, res) {
            res.end('req.body=>' JSON.stringify(req.body));
})
.dengar(8888);

Ketiga, berikut ialah satu lagi contoh perbandingan untuk melihat faedah menggunakan perisian tengah.

Salin kod Kod adalah seperti berikut:

/*
* Pemprosesan fail statik menggunakan connect
*/
var connect = require('connect');
connect(connect.static(__dirname '/public')).listen(//Listen
8888,
Fungsi() {
console.log('Sambung dimulakan pada port 8888');
}
);
/*
* Dilaksanakan menggunakan api asli nod
*/
var http = memerlukan('http');
http.createServer(
Fungsi(req, res) {
        var url = memerlukan('url');
        var fs = memerlukan('fs');
          var pathname = __dirname '/public' url.parse(req.url).pathname;
//Baca fail tempatan
              fs.readFile(
               nama laluan,
fungsi(err, data) {
//Pengendalian pengecualian
                      jika (err) {
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          .                  }
                    lain {
                                                                                                                                                                                                                                                                                                                                                                 }
            }
);
}
).dengar(//Dengar
8888,
Fungsi() {
console.log('Http Server bermula pada port 8888');
}
);



Walaupun API asli nod telah menghabiskan begitu banyak baris kod, ia masih meninggalkan banyak aspek pelayan fail statik mudah tidak ditangani,
Contohnya: 404 dan pengecualian lain tidak dikendalikan, tiada pengesahan keselamatan laluan fail asas (malah, kami boleh mengakses keseluruhan sistem fail os), pengendalian pengecualian global, dsb.;

Pada masa yang sama, connect telah menyelesaikan semua masalah ini.

Empat, ringkasan

(1), fahami pemprosesan penstriman middleware.

Salin kod

Kod adalah seperti berikut: var app = connect(); app.use(connect.staticCache());
app.use(connect.static(__dirname '/public'));
app.use(connect.cookieParser());
app.use(connect.session());
app.use(connect.query());
app.use(connect.bodyParser());
app.use(connect.csrf());
app.use(fungsi (req, res, next) {
// Middleware
});
app.listen(8888);




(2), perbezaan antara pelaksanaan asli dan pelaksanaan perisian tengah.

(3), melalui contoh perisian tengah di atas, fahami tujuan dan senario penggunaan serta rujuk dokumen yang berkaitan untuk menguasai penggunaan asas perisian tengah lain.

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn