2. 2 Tại sao nên sử dụng JSON?
Xây dựng và triển khai Web Service cho ứng dụng di động 8
• Có thể đọc hiểu và dễ dàng tiếp cận (human-readability).
• Dữ liệu truyền tải ngắn gọn so với những định dạng dữ liệu khác
như: XML, HTML, → Tiết kiệm dung lượng hơn XML, HTML,.
• Dễ dàng chuyển đổi (parse) dữ liệu từ dạng chuỗi (nhận từ server)
sang dữ liệu có thể sử dụng được (thành Object, Number, Array).
• Dễ truy cập nội dung.
• Với những ứng dụng AJAX lấy và xử lý dữ liệu từ 1 web service nào
đó khác domain. Nếu nội dung trả về có dạng JSON thì javascript
từ trang web của chúng ta có thể trực tiếp truy cập (dùng lệnh
eval).
• Có cách phân tích xử lý đơn giản, chỉ qua 1 bước (chuyển chuỗi
nhận được từ máy chủ sang dữ liệu có thể sử dụng được)
36 trang |
Chia sẻ: thanhle95 | Lượt xem: 647 | Lượt tải: 2
Bạn đang xem trước 20 trang tài liệu Bài giảng Xây dựng và triển khai Web Service cho ứng dụng di động - Bài 4: Tương tác giữa Web Service với ứng dụng trên thiết bị di động, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
Trường ĐH Khoa Học Tự Nhiên Tp. Hồ Chí Minh
TRUNG TÂM TIN HỌC
2015
Bài 4: Tương tác giữa Web Service
với ứng dụng trên thiết bị di động
Ngành Mạng & Thiết bị di động
www.t3h.vn
1. Giới thiệu các dạng dữ liệu tương tác giữa Web
Service với ứng dụng trên TBDĐ
2. Tổng quan về JSON
3. Tạo JSON bằng .Net Web Service
4. Tương tác giữa Web Service với ứng dụng trên TBDĐ
Nội dung
Xây dựng và triển khai Web Service cho ứng dụng di động 2
1. Giới thiệu các dạng dữ liệu tương tác giữa
Web Service với ứng dụng trên TBDĐ
Xây dựng và triển khai Web Service cho ứng dụng di động 3
XML - eXtensible Markup Language
• Là ngôn ngữ đánh dấu với mục đích chung do W3C đề nghị.
• Là một dạng chuẩn cho phép lưu các thông tin hướng cấu trúc,
được tổ chức dưới dạng thẻ (tag) tương ứng.
• Các thẻ (tag) của XML thường không được định nghĩa trước mà
chúng được tạo ra theo quy ước của người, (hoặc Chương trình)
tạo ra XML theo những quy ước của chính người tạo.
• Giúp đơn giản hóa việc chia sẻ dữ liệu giữa các hệ thống khác
nhau, đặc biệt là các hệ thống được kết nối với Internet.
• Sử dụng các khai báo kiểu dữ liệu DTD (Document Type Definition)
hay lược đồ Schema để mô tả dữ liệu.
1. Giới thiệu các dạng dữ liệu tương tác giữa
Web Service với ứng dụng trên TBDĐ
Xây dựng và triển khai Web Service cho ứng dụng di động 4
XML - eXtensible Markup Language
Ví dụ:
1. Giới thiệu các dạng dữ liệu tương tác giữa
Web Service với ứng dụng trên TBDĐ
Xây dựng và triển khai Web Service cho ứng dụng di động 5
JSON - JavaScript Object Notation
Định nghĩa dữ liệu theo ngôn ngữ JavaScript, tiêu chuẩn ECMA-
262 năm 1999.
Là một định dạng văn bản đơn giản với các trường dữ liệu được
lồng vào nhau.
1. Giới thiệu các dạng dữ liệu tương tác giữa Web
Service với ứng dụng trên TBDĐ
2. Tổng quan về JSON
• JSON là gì?
• Tạo sao nên sử dụng JSON?
• Cú pháp JSON
• Cấu trúc xây dựng JSON
• Các kiểu dữ liệu JSON
3. Tạo JSON bằng .Net Web Service
4. Tương tác giữa Web Service với ứng dụng trên TBDĐ
Nội dung
Xây dựng và triển khai Web Service cho ứng dụng di động 6
2. 1 JSON là gì?
Xây dựng và triển khai Web Service cho ứng dụng di động 7
JSON - JavaScript Object Notation
• Định nghĩa dữ liệu theo ngôn ngữ JavaScript, tiêu chuẩn
ECMA-262 năm 1999.
• Là một định dạng văn bản đơn giản với các trường dữ
liệu được lồng vào nhau.
• Dùng để trao đổi dữ liệu giữa các thành phần của một
hệ thống tương thích với hầu hết các ngôn ngữ C, C++,
C#, Java, JavaScript, Perl, Python...
2. 2 Tại sao nên sử dụng JSON?
Xây dựng và triển khai Web Service cho ứng dụng di động 8
• Có thể đọc hiểu và dễ dàng tiếp cận (human-readability).
• Dữ liệu truyền tải ngắn gọn so với những định dạng dữ liệu khác
như: XML, HTML, → Tiết kiệm dung lượng hơn XML, HTML,...
• Dễ dàng chuyển đổi (parse) dữ liệu từ dạng chuỗi (nhận từ server)
sang dữ liệu có thể sử dụng được (thành Object, Number, Array).
• Dễ truy cập nội dung.
• Với những ứng dụng AJAX lấy và xử lý dữ liệu từ 1 web service nào
đó khác domain. Nếu nội dung trả về có dạng JSON thì javascript
từ trang web của chúng ta có thể trực tiếp truy cập (dùng lệnh
eval).
• Có cách phân tích xử lý đơn giản, chỉ qua 1 bước (chuyển chuỗi
nhận được từ máy chủ sang dữ liệu có thể sử dụng được)
2. 3 Cú pháp JSON?
Xây dựng và triển khai Web Service cho ứng dụng di động 9
Cú pháp JSON là một tập hợp con của cú pháp đối tượng JavaScript:
• Dữ liệu là các cặp tên/giá trị (name/values)
• Dữ liệu được phân cách bằng dấu phẩy
• Đối tượng nằm trong cặp ngoặc nhọn „{}‟
• Dấu ngoặc vuông giữ mảng „[]‟
Để kiểm tra cú pháp chuỗi JSON, chúng ta có thể truy cập vào trang
để kiểm tra.
2. 3 Cú pháp JSON?
Xây dựng và triển khai Web Service cho ứng dụng di động 10
Cặp tên và giá trị (name & values) của JSON
•Dữ liệu JSON được viết trong cặp Tên/Giá trị.
•Một cặp Tên/Giá trị chứa tên 1 trường (trong dấu nháy đôi “”),
theo sau là dấu phẩy, cuối cùng là giá trị.
Ví dụ:
"ten" : "An"
2. 3 Cú pháp JSON?
Xây dựng và triển khai Web Service cho ứng dụng di động 11
Tập tin JSON (JSON Files)
• Kiểu tập tin (file) của JSON là ".json"
• Kiểu MIME của JSON là "application/json"
2. 3 Cấu trúc xây dựng JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 12
Được xây dựng trên 2 cấu trúc chính:
• Tập hợp của các cặp tên và giá trị name-value
Các kiểu thể hiện:
1 đối tượng (object), sự ghi (record), cấu trúc (struct), từ điển
(dictionary), bảng băm (hash table), danh sách khoá (keyed
list), hay mảng liên hợp.
• Tập hợp các giá trị đã được sắp xếp
Các kiểu thể hiện:
1 mảng, véc tơ, tập hợp hay là 1 dãy tuần tự (sequence).
2. 4 Các kiểu dữ liệu JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 13
JSON có 5 kiểu dữ liệu chính:
• Kiểu số (Number)
• Kiểu chuỗi (String)
• Kiểu mảng (Array)
• Kiểu đối tượng (Object)
• Giá trị (Value)
2. 4 Các kiểu dữ liệu JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 14
Kiểu đối tượng (Object)
• 1 đối tượng là 1 hổn độn của các cặp tên và giá trị.
• 1 đối tượng bắt đầu bởi dấu ngoặc đơn trái { và kết thúc với
dấu ngoặc đơn phải }.
• Từng tên được theo sao bởi dấu 2 chấm (:) và các cặp
tên/giá trị được tách ra bởi dấu phẩy (,).
• 1 đối tượng có thể chứa nhiều cặp tên/giá trị (Name/Values)
2. 4 Các kiểu dữ liệu JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 15
Kiểu đối tượng (Object)
Ví dụ:
{ “ten":“An" , “ho":“Nguyen" }
2. 4 Các kiểu dữ liệu JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 16
Kiểu mảng (Array)
• 1 mảng là 1 tập hợp các giá trị đã được sắp xếp.
• 1 mảng bắt đầu bởi dấu mở ngoặc vuông [ và kết thúc với
dấu ngoặc vuông phải ].
• Các giá trị được cách nhau bởi dấu phẩy (,).
• 1 mảng có thể chứa nhiều đối tượng.
2. 4 Các kiểu dữ liệu JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 17
Kiểu mảng (Array)
• Ví dụ
{
"NhanVien":
[
{"tenNV":"An" , "hoNV":"Nguyễn" },
{"tenNV":"Bình" , "hoNV":"Trần" },
{"tenNV":"Châu" , "hoNV":"Lê" }
]
}
2. 4 Các kiểu dữ liệu JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 18
Kiểu giá trị (Value)
•Giá trị JSON có thể là:
1 số (nguyên (integer) hay số thực (floating point))
1 chuỗi (nằm trong dấu nháy đôi "")
1 số luận lý (true hoặc false)
1 mảng (nằm trong dấu ngoặc vuông [])
1 đối tượng (nằm trong dấu ngoặc nhọn {})
Kiểu null
•Những cấu trúc này có thể đã được lồng vào nhau.
2. 4 Các kiểu dữ liệu JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 19
Kiểu giá trị (Value)
2. 4 Các kiểu dữ liệu JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 20
Kiểu chuỗi (String)
•1 chuỗi (string) là 1 tập hợp của các số hay mẫu tự Unicode, được
bao bọc trong các dấu trích dẫn kép (").
•Dùng dấu chéo (/) để thoát khỏi 1 chuỗi.
•1 ký tự đã được hiển thị như là 1 chuỗi ký tự đơn độc.
2. 4 Các kiểu dữ liệu JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 21
Kiểu chuỗi (string)
2. 4 Các kiểu dữ liệu JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 22
Kiểu số (Number)
Giống với kiểu số trong C và Java, trừ định dạng bát phân và hex là
không thể dùng.
2. 4 Các kiểu dữ liệu JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 23
Ví dụ sử dụng các kiểu dữ liệu JSON
{
SVNganhCNTT:
[
{hoTen: “Nguyễn Văn An”, tuoi: 21, nam: true, queQuan: “Đồng Tháp”},
{hoTen: “Trần Văn Bình”, tuoi: 22, nam: true,queQuan:“Hồ Chí Minh”},
{hoTen: “Lê Thị Châu”, tuoi: 23, nam: false, queQuan: “Vĩnh Long” }
],
SVNganhCNSH:
[
{hoten: “Trần Văn Bông”, tuoi: 24, nam: true, queQuan: “Long An”},
{hoten: “Nguyễn Thị Hoa”, tuoi: 22, nam: false, queQuan: “Cần Thơ”},
]
}
2. 4 Các kiểu dữ liệu JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 24
Phân tích ví dụ
- Tuoi (tuổi) kiểu dữ liệu là Number
- hoTen (họ tên) kiểu dữ liệu là String
- nam (giới tính) kiểu dữ liệu là Boolean
- SVNganhCNTT (sinh viên ngành CNTT), SVNganhCNSH (Sinh viên
ngành CNSH) kiểu dữ liệu làArray
- {hoTen: “Nguyễn Văn An”, tuoi: 21, nam: true, queQuan: “Đồng
Tháp”} là một kiểu Object
- hoTen : “Nguyễn Văn An” là một cặp giá trị của một Object, hoTen là
tên thuộc tính, “Nguyễn Văn An” là giá trị của thuộc tính đó
- SVNganhCNTT: [...] và SVNganhCNSH: [...] cũng được xem là những
cặp giá trị
1. Giới thiệu các dạng dữ liệu tương tác giữa Web
Service với ứng dụng trên TBDĐ
2. Tổng quan về JSON
3. Chuyển đổi giữa kiểu dữ liệu JSON và đối tượng .NET
(Serializing - Deserializing JSON)
● Cấu hình Web API Service chỉ trả về JSON
● Chuyển đổi từ đối tượng .NET sang chuỗi JSON ( Tạo chuỗi JSON)
● Chuyển đổi từ chuỗi JSON sang đối tượng .NET
4. Tương tác giữa Web Service với ứng dụng trên TBDĐ
Nội dung
Xây dựng và triển khai Web Service cho ứng dụng di động 25
3. 1 Cấu hình Web API Service chỉ trả về JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 26
Mở file WebApiConfig.cs trong thư mục App_Start → thêm dòng
sau vào trong phương thức Register:
config.Formatters.Remove(config.Formatters.XmlFormatter);
Để cấu trúc thuộc tính của đối tượng JSON trả về đúng quy cách
CamelCase thì ta thêm config sau vào Register:
var json = config.Formatters.JsonFormatter;
json.SerializerSettings.PreserveReferencesHandling =
Newtonsoft.Json.PreserveReferencesHandling.Objects;
json.SerializerSettings.ContractResolver = new
CamelCasePropertyNamesContractResolver();
3. Chuyển đổi giữa kiểu dữ liệu JSON và đối tượng
.NET (Serializing - Deserializing JSON)
Xây dựng và triển khai Web Service cho ứng dụng di động 27
Để chuyển đổi (convert) một chuỗi (string) định dạng JSON sang
đối tượng (object) của .Net và ngược lại, ta sử dụng lớp
JavaScriptSerializer trong thư viện System.Web.Extensions.
3. 2 Chuyển đổi từ đối tượng .NET sang chuỗi JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 28
Sử dụng phương thức Serializer thuộc lớp JavaScriptSerializer.
Khai báo sử dụng:
using System.Web.Script.Serialization;
Ví dụ 1:
Lớp HocVien đã được định nghĩa với các thuộc tính: maHV, tenHV và các
thuộc tính get, set cho từng thuộc tính, phương thức khởi tạo với 2 tham
số maHV và tenHV. Những lệnh sau dùng để chuyển đổi đối tượng
HocVien sang chuỗi JSON:
HocVien = new HocVien("SV001", "Nguyễn Văn A");
string chuoiJSON= serializer.Serialize(s);
Response.Write("Object: " + chuoiJSON);
Kết quả:
Object: {“maHV”:SV001, “tenHV”: “Nguyễn Văn A”}
3. 2 Chuyển đổi từ đối tượng .NET sang chuỗi JSON
Xây dựng và triển khai Web Service cho ứng dụng di động 29
Ví dụ 2:
HocSinh hs1= new HocSinh();
hs1 = getHocSinhByID(123);
JavaScriptSerializer jss = new JavaScriptSerializer();
string chuoiJSON = jss.Serialize(hs1);
Console.WriteLine(chuoiJSON);
Kết quả:
{
“tenHV": “Trần Văn B",
“maHV": "123456",
“ngaySinh": "01/01/1991",
“diaChi":{"sonha":"123","quan":“10"},
"diemThi":[{"mon":“toan","diem":"10"},
{"mon":"ly","diem":"9"},
{"mon":"hoa","diem":"8"}]
}
3. 3 Chuyển đổi từ chuỗi JSON sang đối tượng .NET
Xây dựng và triển khai Web Service cho ứng dụng di động 30
Sử dụng phương thức Deserializer thuộc lớp JavaScriptSerializer.
Ví dụ 1:
Với chuỗi JSON sau:
{“maHV”:100, “tenHV”: “Nguyễn Văn A”}
Lệnh dùng để chuyển đổi chuỗi JSON trên thành đối tượng
HocVien:
HocVien hv1 = serializer.Deserialize(str);
Response.Write("tenHV: " + hv1.HocVien);
Xây dựng và triển khai Web Service cho ứng dụng di động 31
Ví dụ 2:
Với chuỗi JSON sau
{
“tenHS": “Trần Văn B",
"maHS": "123456",
"ngaySinh": "01/01/1991"
}
Cách 1: Chuyển qua một đối tượng cụ thể
Định nghĩa 1 lớp đối tượng tương ứng
public class HocSinh
{
public string tenHS{ get; set; }
public string maHS{ get; set; }
public string ngaySinh{ get; set; }
}
3. 3 Chuyển đổi từ chuỗi JSON sang đối tượng .NET
Xây dựng và triển khai Web Service cho ứng dụng di động 32
Cách 1: Chuyển qua một đối tượng cụ thể
Định nghĩa 1 lớp đối tượng tương ứng:
public class sinhvien
{
public string tenHS{ get; set; }
public string maHS{ get; set; }
public string ngaySinh{ get; set; }
}
Chuyển đổi JSON qua đối tượng:
JavaScriptSerializer jss = new JavaScriptSerializer();
sinhvien hs = jss.Deserialize(JsonText);
3. 3 Chuyển đổi từ chuỗi JSON sang đối tượng .NET
Xây dựng và triển khai Web Service cho ứng dụng di động 33
Cách 2: Chuyển qua dạng dữ liệu động (dynamic)
JavaScriptSerializer jss = new JavaScriptSerializer();
var obj = jss.Deserialize(JsonText);
Console.WriteLine(obj[“tenHS"]);
3. 3 Chuyển đổi từ chuỗi JSON sang đối tượng .NET
1. Giới thiệu các dạng dữ liệu tương tác giữa Web
Service với ứng dụng trên TBDĐ
2. Tổng quan về JSON
3. Tạo JSON bằng .Net Web Service
4. Tương tác giữa Web Service với ứng dụng trên TBDĐ
Nội dung
Xây dựng và triển khai Web Service cho ứng dụng di động 34
4. Tương tác giữa Web Service với ứng dụng
trên TBDĐ
Xây dựng và triển khai Web Service cho ứng dụng di động 35
• Lấy dữ liệu dạng JSON từ .Net Web Service
• Truyền dữ liệu dạng JSON từ ứng dụng di động lên .Net Web
Service
• Mã hóa khi truyền biến JSON lên .Net Web Service
Xây dựng và triển khai Web Service cho ứng dụng di động 36