Node.js - API RESTful
Apa itu arsitektur REST?
REST adalah singkatan dari REpresentational State Transfer. REST adalah arsitektur berbasis standar web dan menggunakan Protokol HTTP. Ini berputar di sekitar sumber daya di mana setiap komponen adalah sumber daya dan sumber daya diakses oleh antarmuka umum menggunakan metode standar HTTP. REST pertama kali diperkenalkan oleh Roy Fielding pada tahun 2000.
Server REST hanya menyediakan akses ke sumber daya dan klien REST mengakses dan memodifikasi sumber daya menggunakan protokol HTTP. Di sini setiap sumber daya diidentifikasi oleh URI / ID global. REST menggunakan berbagai representasi untuk mewakili sumber daya seperti teks, JSON, XML tetapi JSON adalah yang paling populer.
Metode HTTP
Empat metode HTTP berikut biasanya digunakan dalam arsitektur berbasis REST.
GET - Ini digunakan untuk memberikan akses hanya baca ke sumber daya.
PUT - Ini digunakan untuk membuat sumber daya baru.
DELETE - Ini digunakan untuk menghapus sumber daya.
POST - Ini digunakan untuk memperbarui sumber daya yang ada atau membuat sumber daya baru.
Layanan Web RESTful
Layanan web adalah kumpulan protokol dan standar terbuka yang digunakan untuk bertukar data antara aplikasi atau sistem. Aplikasi perangkat lunak yang ditulis dalam berbagai bahasa pemrograman dan berjalan di berbagai platform dapat menggunakan layanan web untuk bertukar data melalui jaringan komputer seperti Internet dengan cara yang mirip dengan komunikasi antar proses pada satu komputer. Interoperabilitas ini (mis., Komunikasi antara Java dan Python, atau aplikasi Windows dan Linux) disebabkan oleh penggunaan standar terbuka.
Layanan web berdasarkan Arsitektur REST dikenal sebagai layanan web RESTful. Layanan web ini menggunakan metode HTTP untuk mengimplementasikan konsep arsitektur REST. Layanan web RESTful biasanya mendefinisikan URI, Uniform Resource Identifier sebuah layanan, yang menyediakan representasi sumber daya seperti JSON dan kumpulan Metode HTTP.
Membuat RESTful untuk Perpustakaan
Pertimbangkan kita memiliki database pengguna berbasis JSON yang memiliki pengguna berikut dalam sebuah file users.json:
{
"user1" : {
"name" : "mahesh",
"password" : "password1",
"profession" : "teacher",
"id": 1
},
"user2" : {
"name" : "suresh",
"password" : "password2",
"profession" : "librarian",
"id": 2
},
"user3" : {
"name" : "ramesh",
"password" : "password3",
"profession" : "clerk",
"id": 3
}
}
Berdasarkan informasi ini kami akan menyediakan API RESTful berikut.
Sr.No. | URI | Metode HTTP | Badan POST | Hasil |
---|---|---|---|---|
1 | listUsers | DAPATKAN | kosong | Tampilkan daftar semua pengguna. |
2 | Tambahkan pengguna | POS | String JSON | Tambahkan detail pengguna baru. |
3 | Hapus pengguna | MENGHAPUS | String JSON | Hapus pengguna yang sudah ada. |
4 | :Indo | DAPATKAN | kosong | Tampilkan detail pengguna. |
Saya menyimpan sebagian besar bagian dari semua contoh dalam bentuk pengkodean keras dengan asumsi Anda sudah tahu cara meneruskan nilai dari ujung depan menggunakan Ajax atau data formulir sederhana dan cara memprosesnya menggunakan ekspres Request obyek.
Daftar Pengguna
Mari terapkan RESTful API pertama kita listUsers menggunakan kode berikut di file server.js -
server.js
var express = require('express');
var app = express();
var fs = require("fs");
app.get('/listUsers', function (req, res) {
fs.readFile( __dirname + "/" + "users.json", 'utf8', function (err, data) {
console.log( data );
res.end( data );
});
})
var server = app.listen(8081, function () {
var host = server.address().address
var port = server.address().port
console.log("Example app listening at http://%s:%s", host, port)
})
Sekarang coba akses API yang ditentukan menggunakan URL: http://127.0.0.1:8081/listUsers dan Metode HTTP: DAPATKAN di mesin lokal menggunakan klien REST apa pun. Ini harus menghasilkan hasil sebagai berikut -
Anda dapat mengubah alamat IP yang diberikan ketika Anda akan meletakkan solusi di lingkungan produksi.
{
"user1" : {
"name" : "mahesh",
"password" : "password1",
"profession" : "teacher",
"id": 1
},
"user2" : {
"name" : "suresh",
"password" : "password2",
"profession" : "librarian",
"id": 2
},
"user3" : {
"name" : "ramesh",
"password" : "password3",
"profession" : "clerk",
"id": 3
}
}
Tambahkan pengguna
Mengikuti API akan menunjukkan cara menambahkan pengguna baru dalam daftar. Berikut adalah detail pengguna baru -
user = {
"user4" : {
"name" : "mohit",
"password" : "password4",
"profession" : "teacher",
"id": 4
}
}
Anda dapat menerima input yang sama dalam bentuk JSON menggunakan panggilan Ajax tetapi untuk sudut pandang pengajaran, kami membuatnya menjadi kode keras di sini. Berikut ini adalahaddUser API untuk pengguna baru di database -
server.js
var express = require('express');
var app = express();
var fs = require("fs");
var user = {
"user4" : {
"name" : "mohit",
"password" : "password4",
"profession" : "teacher",
"id": 4
}
}
app.post('/addUser', function (req, res) {
// First read existing users.
fs.readFile( __dirname + "/" + "users.json", 'utf8', function (err, data) {
data = JSON.parse( data );
data["user4"] = user["user4"];
console.log( data );
res.end( JSON.stringify(data));
});
})
var server = app.listen(8081, function () {
var host = server.address().address
var port = server.address().port
console.log("Example app listening at http://%s:%s", host, port)
})
Sekarang coba akses API yang ditentukan menggunakan URL: http://127.0.0.1:8081/addUser dan Metode HTTP: POST di mesin lokal menggunakan klien REST apa pun. Ini harus menghasilkan hasil sebagai berikut -
{
"user1":{"name":"mahesh","password":"password1","profession":"teacher","id":1},
"user2":{"name":"suresh","password":"password2","profession":"librarian","id":2},
"user3":{"name":"ramesh","password":"password3","profession":"clerk","id":3},
"user4":{"name":"mohit","password":"password4","profession":"teacher","id":4}
}
Tunjukkan Detail
Sekarang kita akan menerapkan API yang akan dipanggil menggunakan ID pengguna dan itu akan menampilkan detail pengguna yang sesuai.
server.js
var express = require('express');
var app = express();
var fs = require("fs");
app.get('/:id', function (req, res) {
// First read existing users.
fs.readFile( __dirname + "/" + "users.json", 'utf8', function (err, data) {
var users = JSON.parse( data );
var user = users["user" + req.params.id]
console.log( user );
res.end( JSON.stringify(user));
});
})
var server = app.listen(8081, function () {
var host = server.address().address
var port = server.address().port
console.log("Example app listening at http://%s:%s", host, port)
})
Sekarang coba akses API yang ditentukan menggunakan URL: http://127.0.0.1:8081/2 dan Metode HTTP: DAPATKAN di mesin lokal menggunakan klien REST apa pun. Ini harus menghasilkan hasil sebagai berikut -
{"name":"suresh","password":"password2","profession":"librarian","id":2}
Hapus pengguna
API ini sangat mirip dengan API addUser di mana kami menerima input data melalui req.body dan kemudian berdasarkan ID pengguna kami menghapus pengguna tersebut dari database. Untuk menjaga agar program kami tetap sederhana, kami menganggap kami akan menghapus pengguna dengan ID 2.
server.js
var express = require('express');
var app = express();
var fs = require("fs");
var id = 2;
app.delete('/deleteUser', function (req, res) {
// First read existing users.
fs.readFile( __dirname + "/" + "users.json", 'utf8', function (err, data) {
data = JSON.parse( data );
delete data["user" + 2];
console.log( data );
res.end( JSON.stringify(data));
});
})
var server = app.listen(8081, function () {
var host = server.address().address
var port = server.address().port
console.log("Example app listening at http://%s:%s", host, port)
})
Sekarang coba akses API yang ditentukan menggunakan URL: http://127.0.0.1:8081/deleteUser dan Metode HTTP: HAPUS di mesin lokal menggunakan klien REST apa pun. Ini harus menghasilkan hasil sebagai berikut -
{"user1":{"name":"mahesh","password":"password1","profession":"teacher","id":1},
"user3":{"name":"ramesh","password":"password3","profession":"clerk","id":3}}