1. Trang chủ
  2. » Luận Văn - Báo Cáo

Khoá luận tốt nghiệp xây dựng website quản lí cán bộ viên chức trường đại học sư phạm hà nội 2

62 795 0

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 62
Dung lượng 184,5 KB

Nội dung

Tuy Visual Basic bền hơn do không cần phải khởi tạo mã nguồn trongForm khi thiết kế nhưng Visual Basic cũng có nhiều khuyết điểm : + Không hỗ trợ thiết kế hướng đối tượng, nhất là khả nă

Trang 1

HÀ NỘI, 2015

TRƯỜNG ĐẠI HỌC sư PHẠM HÀ NỘI 2

• • • • KHOA CÔNG NGHỆ THÔNG TIN

Trang 2

Chuyên ngành: Khoa học máy tính

Ngưòi hướng dẫn khoa học ThS Trần Tuấn Vinh

Trang 3

LỜI CẢM ƠN

Trước tiên, em muốn gửi lời cảm ơn sâu sắc nhất đến thầy giáo, ThS TrầnTuấn Vinh, người đã tận tình hướng dẫn em trong suốt quá trình thực hiện khóaluận tốt nghiệp

Em xin bày tỏ lời cảm ơn sâu sắc đến những thầy cô giáo đã giảng dạy emtrong bốn năm qua, những kiến thức mà em nhận được trên giảng đường đại học

sẽ là hành trang giúp em vững bước trong tương lai

Em cũng muốn gửi lời cảm ơn đến các anh chị và các bạn trong lớp K37 CNTT đã giúp đỡ và cho em những lời khuyên bổ ích về chuyên môn trong quátrình nghiên cứu

-Cuối cùng, em muốn gửi lời cảm ơn sâu sắc đến tất cả bạn bè và đặc biệt

là gia đình, những người luôn kịp thời động viên và giúp đỡ em vượt qua nhữngkhó khăn ừong cuộc sống

Sinh viênNguyễn Ngọc Cường

Trang 4

LỜI CAM ĐOAN

Em xin cam đoan: Khóa luận này là nghiên cứu thực sự của cá nhân, được thực hiện dưới sự hướng dẫn của thầy giáo, ThS Trần Tuấn Vinh

Các số liệu, những kết luận nghiên cứu được trình bày trong khóa luận này trung thực và chưa từng được công bố dưới bất cứ hình thức nào

Em xin chịu trách nhiệm về nghiên cứu của mình

Người cam đoan

Nguyễn Ngọc Cường

MỤC LỤC

MỞ ĐẦU 1

CHƯƠNG 1 Cơ SỞ LÝ THUYẾT 4

1.1 Giới thiệu ngôn ngữ C# 4

1.1.1 Ngôn ngữ C# 4

1.1.2 Kiến trúc Net 6

1.1.3 Nền tảng ngôn ngữ C# 16

1.2 Hệ quản trị cơ sở dữ liệu SQL server 19

1.3 Kỹ thuật lập trình ASP.Net 21

CHƯƠNG 2 PHÂN TÍCH HỆ THỐNG 24

2.1 Khảo sát hiện trạng 24

Trang 5

2.2 Phân tích hệ thống 25

2.2.1 Biểu đồ phân cấp chức năng của hệ thống 25

2.2.2 Một số chức năng chính của hệ thống 26

CHƯƠNG 3 THIẾT KÉ HỆ THỐNG 28

3.1 Thiết kế cơ sở dữ liệu 28

3.1.1 Mô hình quan hệ 28

3.1.2 Chi tiết các bảng cơ sở dữ liệu 29

3.2 Thiết kế giao diện Website 50

KẾT LUẬN VÀ HƯỚNG PHÁT TRIỀN 53

TÀI LIỆU THAM KHẢO 54

DANH MỤC HÌNH ẢNH • Hình 2.1 Biểu đồ phân cấp chức năng hệ thống 25

Hình 2.2 Biểu đồ phân cấp chức năng quản lý thông tin 25

Hình 3.1 Mô hình quan hệ 28

Hình 3.2 Giao diện trang chủ của website 50

Hình 3.3 Giao diện chức năng cập nhập hồ sơ cán bộ 51

Hình 3.4 Giao diện chức năng thêm mới hồ sơ cán bộ 52

DANH MỤC BẢNG • Bảng 3.1 Cán bộ 29

Bảng 3.2 Chức vụ 38

Bảng 3.3 Công việc 38

Bảng 3.4 Dân tộc 38

Trang 6

Bảng 3.5 Khen thưởng 39

Bảng 3.6 Loại cán bộ 39

Bảng 3.7 Kỉ luật 40

Bảng 3.8 Đơn vị 40

Bảng 3.9 Ngạch công chức 41

Bảng 3.10 Tham gia LLVT 41

Bảng 3.11 Thành phần xuất thân 42

Bảng 3.12 Quá trình bồi dưỡng 42

Bảng 3.13 Quan hệ 43

Bảng 3.14 Quá trình công tác 43

Bảng 3.15 Tôn giáo 44

Bảng 3.16 Quá trình đào tạo 44

Bảng 3.17 Tình ừạng hôn nhân 45

Bảng 3.18 Thân nhân 45

Bảng 3.19 Trình độ ngoại ngữ 46

Bảng 3.20 Trình độ lý luận chính trị 46

Bảng 3.21 Trình độ chuyên môn 46

Bảng 3.22 Trình độ học vấn 47

Bảng 3.23 Trình độ quản lý nhà nước 47

Bảng 3.24 Trình độ tin học 47

Bảng 3.25 Loại đơn vị 48

Bảng 3.26 Loại ngạch 48

Bảng 3.27 Đăng nhập 48

Trang 7

Bảng 3.28 Tên cột 49Bảng 3.29 Hình thức kỷ luật 49

MỞ ĐÀU

1 Lý do chọn đề tài

Trong những năm gần đây, Công nghệ thông tin phát triển như vũ bão, cótác dụng thúc đẩy sự phát triển mạnh về kinh tế và trở thành ngành mũi nhọn, vìvậy đảng và nhà nước đang bắt đầu chú trọng đầu tư phát triển ngành công nghệthông tin

Công nghệ thông tin ngày càng khẳng định vai trò của mình ưong cuộcsống con người, từ những ngành khoa học công nghệ cao đến những ứng dụngnhỏ nhất trong cuộc sống Đối vói những người thực sự gắn bó với công nghệthông tin thì ngoài việc áp dụng những thành tựu sẵn có của tin học còn phải biếtxây dựng thiết kế những chương trình ứng dụng phục vụ cho yêu cầu thực tếcông việc của mình và cao hơn nữa là phục vụ cho xã hội

Hiện nay hồ sơ cán bộ được phòng Tổ chức cán bộ quản lý bằng phànmềm được xây dựng ừên môt trường lập trình Visual Studio 2008 Tuy nhiênmuốn sử dụng phần mềm thì máy tính phải cài đặt sẵn chương trình, như vậytính linh động chưa được cao Vói tình hình mạng Internet ngày càng phổ biến

Trang 8

rộng rãi ở Việt Nam, em quyết định xây dựng Website quản lý hồ sơ cán bộ viênchức trường Đại học Sư phạm Hà Nội 2 nhằm giúp cho việc quản lý cán bộ viênchức trở nên dễ dàng, thuận lợi hơn, cán bộ viên chức có thể xem, cập nhậpthông tin bản thân một cách đơn giản thông qua mạng Internet.

2 Mục đích nghiền cứu

“Xây dựng website quản lý cán bộ viên chức trường Đại học Sư phạm HàNội 2” nhằm tự động hóa công tác quản lý hồ sơ cán bộ viên chức Tự độngthống kê, báo cáo, ữa cứu, tổng hợp số liệu theo yêu cầu của người sử dụng, giúpcông việc quản lý trở lên đơn giản và tiết kiệm thời gian cũng như công sức.Bằng việc áp dụng mô hình Client/Server, hệ quản trị cơ sở dữ liệu SQLServer 2008, môi trường lập trình Microsoft Visual Studio 2010 để phát triểnweb, hỗ trợ cán bộ viên chức thông qua mạng Internet

3 Đối tượng và phạm vi nghiên cứu Đối tượng

Tìm hiểu về thông tin cán bộ, phân tích thiết kế hệ thống, xây dựngwebsite Quản lý cán bộ viên chức trường ĐHSP Hà Nội 2

Xây dựng website theo hướng mở, dễ dàng bổ sung, tích họp được cácchức năng mới trong tương lai

Phạm vi

- Lĩnh vực thiết kế website

Trang 9

- Thiết kế Module quản lý các thông tin liên quan tới cán bộ viên chức (cậpnhập sơ yếu lý lịch cán bộ, quản lý khen thưởng, đào tạo, công tác, thânnhân, )

4 Nhiệm vụ nghiên cứu

- Khảo sát quy trình nghiệp vụ của phòng Tổ chức Cán bộ

- Phân tích và thiết kế hệ thống:

о Thiết kế chức năng

о Thiết kế cơ sở dữ liệu, giao diện của website

- Lập trình chức năng của website

- Kiểm thử dựa ưên các dữ liệu được phòng Tổ chức Cán bộ cung cấp

5 Phương pháp nghiên cứu

- Nghiên cứu các công việc và các văn bản liên quan đến công tác quản

lý hồ sơ cán bộ viên chức

- Thu thập các biểu mẫu

- Xây dựng cơ sở dữ liệu của website “ Quản lý hồ sơ cán bộ viên chức”

- Nghiên cứu về website để áp dụng xây dựng website

6 Giả thuyết khoa học

Nếu có website Quản lý hồ sơ cán bộ viên chức thì tất cả các công tácquản lý ở phòng Tổ chức Cán bộ sẽ khoa học và chính xác hơn rất nhiều, giúpcho công tác thống kê, báo cáo, tra cứu hồ sơ cán bộ trở lên nhanh chóng vàthuận tiện, giảm thời gian chi phí cũng như tăng thêm độ hiệu quả cho công việc

Trang 10

CHƯƠNG 1 Cơ SỞ LÝ THUYẾT 1.1 Giới thiệu ngôn ngữ C#

1.1.1 Ngôn ngữ C#

C# là ngôn ngữ khá đơn giản, chỉ khoảng 80 từ khoá và hơn mười mấykiểu dữ liệu được xây dựng sẵn Tuy nhiên ngôn ngữ C# có ý nghĩa cao hơn khi

nó thực thi những khái niệm lập trình hiện đại

C# bao gồm tất cả những hỗ trợ cho cấu trúc, thành phàn component, lậptrình hướng đối tượng Những tính chất đó hiện diện ữong một ngôn ngữ lậptrình hiện đại Và ngôn ngữ C# hội đủ những điều kiện như vậy, hơn nữa nóđược xây dựng trên nền tảng của hai ngôn ngữ mạnh nhất là C++ và Java

Ngôn ngữ C# là ngôn ngữ lập trình hướng đối tượng được phát triển bởiđội ngũ kĩ sư của Microsoft, trong đó người dẫn đàu là Anders Hejlsberg vàScott Wiltamuth Cả hai người này đều là những người nổi tiếng trong đóAnders Hejlsberg được biết đến là tác giả của Turbo Pascal, một ngôn ngữ lậptrình PC phổ biến Và ông đứng đàu nhóm thiết kế Borland Delphi, một trongnhững thành công đàu tiên của việc xây dựng một môi trường phát triển tích họp(IDE) cho lập trình clienưserver

Phần cốt lõi của bất kì ngôn ngữ lập trình hướng đối tượng nào là sự hỗtrợ của nó cho việc định nghĩa và làm việc với những lớp Những lớp thì địnhnghĩa những kiểu dữ liệu mới, cho phép người phát triển mở rộng ngôn ngữ đểtạo mô hình tốt hơn để giải quyết vấn đề Ngôn ngữ C# chứa những từ khoá choviệc khai báo những kiểu lớp đối tượng mới và những phương thức hay thuộc

Trang 11

tính của lớp và cho việc thực thi đóng gói, kế thừa và tính đa hình, ba thuộc tính

cơ bản của bất cứ một ngôn ngữ lập trình hướng đối tượng nào

Trong ngôn ngữ C# mọi thứ liên quan đến khai báo lóp đều được tìm thấyữong phần khai báo của nó Định nghĩa một lớp ữong ngôn ngữ C# không đòi

ngôn ngữ C# hỗ trợ kiểu XML, cho phép chèn các tag XML để phát sinh tựđộng các document trong lớp

C# hỗ trợ giao diện interface, nó được xem như một cam kết với một lớpcho những dịch vụ mà giao diện quy định Trong ngôn ngữ c#, một lớp chỉ cóthể kế thừa từ duy nhất một lớp cha, tức là không cho kế thừa như C++, tuynhiên một lớp có thể thực thi nhiều giao diện

Trong ngôn ngữ c#, những cấu trúc cũng được hỗ trợ nhưng khái niệm về

dữ liệu nhỏ gọn, khi tạo thể hiện thì nó ít yêu cầu hệ điều hành hơn và bộ nhớ sovới một lớp

C# cung cấp những đặc trưng lập trình như property, sự kiện và dẫnhướng khai báo Lập trình hướng component được hỗ trợ bởi CLR thông quasiêu dữ liệu (metadata),

thêm vào những đặc tính mới để làm cho ngôn ngữ này dễ sử dụng hơn Nhiếu

Trang 12

trong số những đặc tính này khá giống với những đặc tính có trong ngôn ngữJava Không dừng lại ở đó, Microsoft đưa ra một số mục đích khi xây dựng ngônngữ này như sau:

C# là ngôn ngữ hiện đại

Điều gì làm cho một ngôn ngữ hiện đại?

Những đặc tính như là xử lý ngoại lệ, thu gom bộ nhớ tự động, những kiểu

dữ liệu mở rộng và bảo mật mã nguồn là những đặc tính được mong đợi ữongmột ngôn ngữ hiện đại C# chứa tất cả những đặc tính ữên

- C# là ngôn ngữ đơn giản

Ngôn ngữ C# loại bỏ một vài sự phức tạp và rối rắm của những ngôn ngữnhư Java và C++, bao gồm việc loại bỏ những macro, những template, đa kếthừa và lớp cơ sở ảo Chúng là những nguyên nhân gây ra sự nhầm lẫn hay dẫnđến những vấn đề cho các người phát triển C++ Nếu chúng ta là người học ngônngữ này đàu tiên thì chắc chắn là ta sẽ không tòi qua những thòi gian để học nó!Nhưng khi đó ta sẽ không biết được hiệu quả của ngôn ngữ C# khi loại bỏ nhữngvấn đề trên

Ngôn ngữ C# đơn giản vì nó dựa trên nền tảng c và C++ Nếu chúng tathân thiện với c và C++ hoặc thậm chí là Java chúng ta sẽ thấy C# khá giống vềdiện mạo, cú pháp, biểu thức toán tử và những chức năng khác được lấy trực tiếp

từ ngôn ngữ c và C++ nhưng nó đã được cải tiến để làm cho ngôn ngữ đơn giản

Trang 13

hơn Nếu chúng ta đã sử dụng Java và tin rằng nó đơn giản, thì chúng ta cũngthấy rằng C# đơn giản.

- C# là ngôn ngữ hướng đối tượng

Những đặc điểm chính của ngôn ngữ hướng đối tượng là sự đóng gói, sự

kế thừa và đa hình C# hỗ trợ tất cả điều đó

- C# là ngôn ngữ mạnh và mềm dẻo

Như đã đề cập ở trước, với ngôn ngữ C# chúng ta chỉ bị giói hạn ở chínhbỏi bản thân hay là trí tưởng tượng của chúng ta Ngôn ngữ này không đặt nhữngràng buộc lên những việc có thể làm C# được sử dụng cho nhiều dự án khácnhau như tạo ra ứng dụng xử lý văn bản, ứng dụng đồ hoạ, bản tính hay thậm chí

là những trình biên dịch cho các ngông ngữ khác

1.1.2 Kiến trúc Net

Tình hình trước khi MS.NET ra đời

Trong lĩnh vực công nghệ thông tin của thế giới ngày nay, với sự pháttriển liên tục và đa dạng nhất là phần mềm, các hệ điều hành, các môi trườngphát triển, các ứng dụng liên tục ra đời Tuy nhiên, đôi khi việc phát triển khôngđồng nhất và nhất là do lợi ích khác nhau của các công ty phàn mềm lớn làm ảnhhưởng đến những người xây dựng phần mềm Cách đây vài năm Java được Sunviết ra, đã có sức mạnh đáng kể, nó hướng tới việc chạy trên nhiều hệ điều hànhkhác nhau, độc lập với bộ xử lý (Intel, Rise, )

Trang 14

Đặc biệt là Java rất thích hợp cho việc viết các ứng dụng trên Internet Tuynhiên, Java lại có hạn chế về mặt tốc độ và trên thực tế vẫn chưa thịnh hành Mặc

dù Sun Corporation và IBM có đẩy mạnh Java, nhưng Microsoft đã dùng ASP đểlàm giảm khả năng ảnh hưởng của Java Để lập trình trên Web, lâu nay ngưòi tavẫn dùng CGI-Perl và gần đây nhất là PHP, một ngôn ngữ giống như Perl nhưngtốc độ chạy nhanh hơn Ta có thể triển khai Perl trên Unix/Linux hay MSWindows Tuy nhiên có nhiều người không thích dùng do bản thân ngôn ngữhay các qui ước khác thường và Perl không được phát triển thống nhất, các công

cụ được xây dựng cho Perl tuy rất mạnh nhưng do nhiều nhóm phát triển vàngười ta không đảm bảo

Trong giới phát triển ứng dụng trên Windows ta có thể viết ứng dụng bằngVisual C++, Delphi hay Visual Basic, đây là một số công cụ phổ biến và mạnh.Trong đó Visual C++ là một ngôn ngữ rất mạnh và cũng rất khó sử dụng VisualBasic thì đơn giản dễ học, dễ dùng nhất nên rất thông dụng Lý do chính làVisual Basic giúp chúng ta có thể viết chương trình trên Windows dễ dàng màkhông cần thiết phải biết nhiều về cách thức MS Windows hoạt động, ta chỉ cầnbiết một số kiến thức căn bản tối thiểu về MS Windows là có thể lập trình được

Do đó theo quan điểm của Visual Basic nên nó liên kết vói Windows là điều tựnhiên và dễ hiểu, nhưng hạn chế là Visual Basic không phải ngôn ngữ hướng đốitượng (Object Oriented)

Delphi là hậu duệ của Turbo Pascal của Borland Nó cũng giống và tươngđối dễ dùng như Visual Basic Delphi là một ngôn ngữ hướng đối tượng Các

Trang 15

điều khiển dùng trên Form của Delphi đều được tự động khỏi tạo mã nguồn Tuynhiên, chức năng khởi động mã nguồn này của Delphi đôi khi gặp rắc rối khi có

sự can thiệp của người dùng vào Sau này khi công ty Borland bị bán và cácchuyên gia xây dựng nên Delphi đã chạy qua bên Microsoft, và Delphi khôngcòn được phát triển tốt nữa, người ta không dám đầu tư triển khai phần mềm vàoDelphi Công ty sau này đã phát triển dòng sản phẩm Jbuilder (dùng Java) khôngcòn quan tâm đến Delphi

Tuy Visual Basic bền hơn do không cần phải khởi tạo mã nguồn trongForm khi thiết kế nhưng Visual Basic cũng có nhiều khuyết điểm :

+ Không hỗ trợ thiết kế hướng đối tượng, nhất là khả năng thừa kế (inheritance)+ Giới hạn về việc chạy nhiều tiểu trình trong một ứng dụng, ví dụ ta không thểdùng Visual Basic để viết một Service kiểu NT

+ Khả năng xử lý lỗi rất yếu, không thích hợp trong môi trường Multi- tier

+ Khó dùng chung với ngôn ngữ khác như C++

+ Không có User Interface thích hợp cho Internet

Do Visual Basic không thích hợp cho viết các ứng Web Server nênMicrosoft tạo ra ASP (Active Server Page) Các trang ASP này vừa có tagHTML vừa chứa các đoạn script (VBScript, JavaScript) nằm lẫn lộn nhau Khi

xử lý một trang ASP, nếu là tag HTML thì sẽ được gởi thẳng qua Browser, còncác script thì sẽ được chuyển thành các dòng HTML rồi gởi đi, ngoại trừ cácfunction hay các sub trong ASP thì yị trí các script khác rất quan trọng Khi một

Trang 16

số chức năng nào được viết tốt người ta dịch thành ActiveX và đưa nó vào WebServer.

Tuy nhiên vì lý do bảo mật nên các ISP (Internet Service Provider) làmmáy chủ cho Web site thường rất dè đặt khi cài ActiveX lạ trên máy của họ.Ngoài ra việc tháo gỡ các phiên bản của ActiveX này là công việc rất khó,thường xuyên làm cho Administrator nhức đầu Những người đã từng quản lýcác version của DLL trên Windows điều than phiền tại sao phải đăng ký các

DLL và nhất là chỉ có thể đăng ký một phiên bản của DLL mà thôi Và từ “DLL

Hell” xuất hiện tức là địa ngục DLL

Sau này để giúp cho việc lập trình ASP nhanh hơn thi công cụ VisualInterDev, một IDE (Integrated Development Environment) ra đời VisualInterDev tạo ra các Design Time Controls cho việc thiết kế các điều khiển ừênweb, Tiếc thay Visual InterDev không bền vững lắm nên sau một thời gian thìcác nhà phát triển đã rời bỏ nó Tóm lại bản thân của ASP hãy còn một số khuyếtđiểm quan trọng, nhất là khi chạy trên Internet Information Server với Windows

NT 4, ASP không đáng tin cậy lắm Tóm lại trong giói lập trình theo Microsoftthì việc lập trình ừên desktop cho đến lập trình hệ phân tán hay trên web làkhông được nhịp nhàng cho lắm Để chuyển được từ lập trình client hay desktopđến lập trình web là một chặng đường dài

Nguồn gốc NET

Đầu năm 1998, sau khi hoàn tất phiên bản Version 4 của InternetInformation Server (IIS), các đội ngũ lập trình ở Microsoft nhận thấy họ còn rất

Trang 17

nhiều sáng kiến để kiện toàn IIS Họ bắt đàu xây dựng một kiến trúc mới trênnền tảng ý tưởng đó và đặt tên là Next Generation Windows Services (NGWS).Sau khi Visual Basic được trình làng vào cuối 1998, dự án kế tiếp mang tênVisual Studio 7 được xác nhập vào NGWS.

Đội ngũ COM+/MTS góp vào một universal runtime cho tất cả ngôn ngữlập trình chung trong Visual Studio, và tham vọng của họ cung cấp cho các ngônngữ lập trình của các công ty khác dùng chung luôn Công việc này được xúctiến một cách hoàn toàn bí mật mãi cho đến hội nghị Professional Developers’Conference ở Orlado vào tháng 7/2000 Đến tháng 11/2000 thì Microsoft đã pháthành bản Beta 1 của NET gồm 3 đĩa CD Tính đến lúc này thì Microsoft đã làmviệc với NET gần 3 năm rồi, do đó bản Beta 1 này tương đối vững chắc .NETmang dáng dấp của những sáng kiến đã được áp dụng trước đây như p-codetrong ƯCSD Pascal cho đến Java Virtual Machine Có điều là Microsoft góp

làm nên một sản phẩm hoàn chỉnh từ bên trong lẫn bên ngoài Hiện tại Microsoft

đã công bố phiên bản release của ■NET Thật sự Microsoft đã đặt cược vào.NET YÌ theo thông tin của công ty, đã tập trung 80% sức mạnh của Microsoft

để nghiên cứu và triển khai NET (bao gồm nhân lực và tài chính ?), tất cả cácsản phẩm của Microft sẽ được chuyển qua Nét

Microsoft NET

Microsoft NET gồm 2 phần chính Framework và Integrated DevelopmentEnvironment (IDE) Framework cung cấp những gì cần thiết và căn bản, chữ

Trang 18

Framework có nghĩa là khung hay khung cảnh trong đó ta dùng những hạ tàng

cơ sở theo một qui ước nhất định để công việc được trôi chảy IDE thì cung cấpmột môi trường giúp chúng ta triển khai dễ dàng, và nhanh chóng các ứng dụngdựa ữên nền tảng NET

Nếu không có IDE chúng ta cũng có thể dùng một trình soạn thảo YÍ nhưNotepad hay bất cứ trình soạn thảo văn bản nào và sử dụng command line đểbiên dịch và thực thi, tuy nhiên việc này mất nhiều thòi gian Tốt nhất là chúng

ta dùng IDE phát triển các ứng dụng, và cũng là cách dễ sử dụng nhất Thànhphàn Framework là quan trọng nhất NET là cốt lõi và tinh hoa của môi trường,

một IDE

Tóm lại Microsoft NET là nền tảng cho việc xây dựng và thực thi cácứng dụng phân tán thế hệ kế tiếp Bao gồm các ứng dụng từ client đến server vàcác dịch vụ khác Một số tính năng của Microsoft NET cho phép những nhàphát triển sử dụng như sau:

Một mô hình lập trình cho phép nhà phát triển xây dựng các ứng dụngdịch vụ web và ứng dụng client với Extensible Markup Language (XML)

Tập hợp dịch vụ XML Web, như Microsoft NET My Services cho phépnhà phát triển đơn giản và tích hợp người dùng kinh nghiệm

Trang 19

Cung cấp các server phục vụ bao gồm: Windows 2000, SQL Server, vàBizTalk Server, tất cả điều tích họp, hoạt động, và quản lý các dịch yụ XMLWeb và các ứng dụng

Các phần mềm client như Windows XP và Windows CE giúp người pháttriển phân phối sâu và thuyết phục người dùng kinh nghiệm thông qua các dòngthiết bị

Nhiều công cụ hỗ ượ như Visual Studio NET, để phát triển các dịch vụWeb XML, ứng dụng trên nền Windows hay nền web một cách dể dàng và hiệuquả

Kiến trúc NET Framework

.NET Framework là một platform mới làm đơn giản việc phát triển ứngdụng trong môi trường phân tán của Internet NET Framework được thiết kế đày

đủ để đáp ứng theo quan điểm sau:

Để cung cấp một môi trường lập trình hướng đối tượng vững chắc, trong

đó mã nguồn đối tượng được lưu trữ và thực thi một cách cục bộ Thực thi cục

bộ nhưng được phân tán trên Internet, hoặc thực thi từ xa

Để cung cấp một môi trường thực thi mã nguồn mà tối thiểu được việcđóng gói phần mềm và sự tranh chấp về phiên bản

Để cung cấp một môi trường thực thi mã nguồn mà đảm bảo việc thực thi

an toàn mã nguồn, bao gồm cả việc mã nguồn được tạo bởi hãng thứ ba hay bất

cứ hãng nào mà tuân thủ theo kiến trúc NET

Trang 20

Để cung cấp một môi trường thực thi mã nguồn mà loại bỏ được những lỗithực hiện các script hay môi trường thông dịch.

Để làm cho những người phát triển có kinh nghiệm vững chắc có thể nắmvững nhiều kiểu ứng dụng khác nhau Như là từ những ứng dụng trên nềnWindows đến những ứng dụng dựa trên web

Để xây dựng tất cả các thông tin dựa triên tiêu chuẩn công nghiệp để đảmbảo rằng mã nguồn ữên NET có thể tích hợp với bất cứ mã nguồn khácNETFramework có hai thành phần chính: Common Language Runtime (CLR) và thưviện lớp NET Framework CLR là nền tảng của NET Framework Chúng ta cóthể hiểu runtime như là một agent quản lý mã nguồn khi nó được thực thi, cungcấp các dịch vụ cốt lõi như: Quản lý bộ nhớ, quản lý tiểu trình, và quản lý từ xa.Ngoài ra nó còn thúc đẩy việc sử dụng kiểu an toàn và các hình thức khác củaviệc chính xác mã nguồn, đảm bảo cho việc thực hiện được bảo mật và mạnh

mẽ Thật yậy, khái niệm quản lý mã nguồn là nguyên lý nền tảng của runtime

Mã nguồn mà đích tới runtime thì được biết như là mã nguồn được quản lý(managed code) Trong khi đó mã nguồn mà không có đích tới runtime thì đượcbiết như mã nguồn không được quản lý (unmanaged code)

Thư viện lớp, một thành phần chính khác của NET Framework là một tậphợp hướng đối tượng của các kiểu dữ liệu được dùng lại, nó cho phép chúng ta

có thể phát triển những ứng dụng từ những ứng dụng truyền thống command-linehay những ứng dụng có giao diện đồ họa (GUI) đến những ứng dụng mới nhấtđược cung cấp bởi ASP.NET, như là Web Form và dịch yụ XML Web

Trang 21

Thư viện lớp.Net Framework

Thư viện lớp NET Framework là một tập hợp những kiểu dữ liệu đượcdùng lại và được kết họp chặt chẽ với Common Language Runtime Thư việnlớp là hướng đối tượng cung cấp những kiểu dữ liệu mà mã nguồn được quản lýcủa chúng ta có thể dẫn xuất Điều này không chỉ làm cho những kiểu dữ liệucủa NET Framework dễ sử dụng mà còn làm giảm thời gian liên quan đến việchọc đặc tính mới của NET Framework Thêm vào đó, các thành phần của cáchãng thứ ba có thể tích hợp với những lóp trong NET Framework

Cũng như mong đợi của người phát triển với thư viện lớp hướng đốitượng, kiểu dữ liệu NET Framework cho phép người phát triển thiết lập nhiềumức độ thông dụng của việc lập trình, bao gồm các nhiệm yụ như: Quản lýchuỗi, thu thập hay chọn lọc dữ liệu, kết nối với cơ cở dữ liệu, và truy cập tậptin Ngoài những nhiệm vụ thông dụng ừên Thư viện lớp còn đưa vào nhữngkiểu dữ liệu để hỗ trợ cho những kịch bản phát triển chuyên biệt khác Ví dụngười phát triển có thể sử dụng NET Framework để phát triển những kiểu ứngdụng và dịch vụ như sau:

Trang 22

Trong đó những lớp Windows Forms cung cấp một tập hợp lớn các kiểu

dữ liệu nhằm làm đơn giản việc phát triển các ứng dụng GUI chạy trênWindows Còn nếu như viết các ứng dụng ASP.NET thì có thể sử dụng các lớpWeb Forms trong thư viện NET Framework

Phát triển ứng dụng Client

Những ứng dụng client cũng gần vói những ứng dụng kiểu truyền thốngđược lập trình dựa trên Windows Đây là những kiểu ứng dụng hiển thị nhữngcửa sổ hay những form trên desktop cho phép người dùng thực hiện một thao táchay nhiệm yụ nào đó Những ứng dụng client bao gồm những ứng dụng như xử

lý văn bản, xử lý bảng tính, những ứng dụng ừong lĩnh vực thương mại như công

cụ nhập liệu, công cụ tạo báo cáo Những ứng dụng client này thường sử dụngnhững cửa sổ, menu, toolbar, button hay các thành phần GUI khác, và chúngthường truy cập các tài nguyên cục bộ như là các tập tin hệ thống, các thiết bịngoại vi như máy in

Một loại ứng dụng client khác với ứng dụng truyền thống như trên làActiveX control (hiện nay nó được thay thế bởi các Windows Form conữol)được nhúng vào các ưang web trên Internet

Trong quá khứ, những nhà phát triển có thể tạo các ứng dụng sử dụngC/C++ thông qua kết nối với MFC hoặc sử dụng môi trường phát triển ứng dụngnhanh (RAD: Rapid Application Development) NET Framework tích hợp diện

Trang 23

mạo của những sản phẩm thành một Môi trường phát triển cố định làm đơn giảnmạnh mẽ sự phát triển của ứng dụng client.

Những lớp NET Framework chứa trong NET Framework được thiết kếcho việc sử dụng phát triển các GUI Điều này cho phép người phát triển nhanhchóng và dễ dàng tạo các cửa sổ, button, menu, toolbar, và các thành phàn kháctrong các ứng dụng được viết phục vụ cho lĩnh vực thương mại Ví dụ như, NETcung cấp những thuộc tính đơn giản để hiệu chỉnh các hiệu ứng visual liên quanđến form Trong vài trường họp hệ điều hành không hỗ trợ việc thay đổi nhữngthuộc tính này một cách trực tiếp, và trong trường hợp này NET tự động tạo lạiform Đây là một ữong nhiều cách mà NET tích hợp việc phát triển giao diệnlàm cho mã nguồn đơn giản và mạnh mẽ hơn

Không giống như ActiveX control, Windows Form control có sự truy cậpgiói hạn đến máy của ngưòi sử dụng Điều này có nghĩa rằng mà nguồn thực thinhị phân có thể truy cập một vài tài nguyên trong máy của người sử dụng (nhưcác thành phàn đồ họa hay một số tập tin được giới hạn) mà không thể truy cậpđến những tài nguyên khác Nguyên nhân là sự bảo mật truy cập của mã nguồn.Lúc này các ứng dụng được cài đặt ừên máy người dùng có thể an toàn để đưalên Internet

Biên dich và MSIL

Trong NET Framework, chương trình không được biên dịch vào các tậptin thực thi mà thay vào đó chúng được biên dịch vào những tập tin trung giangọi là Microsoft Intermediate Language (MSIL) Những tập tin MSIL được tạo

Trang 24

ra từ C# cũng tương tự như các tập tin MSIL được tạo ra từ những ngôn ngữkhác của NET, platform ở đây không cần biết ngôn ngữ của mã nguồn Điềuquan trọng chính yếu của CLR là chung (common), cùng một runtime hỗ trợphát triển trong C# cũng như trong VB.NET.

Mã nguồn C# được biên dịch vào MSIL khi chúng ta build project MãMSIL này được lưu vào ừong một tập tin trên đĩa Khi chúng ta chạy chươngtrình, thì MSIL được biên dịch một lần nữa, sử dụng trình biên dịch Just-In-Time (JIT) Kết quả là mã máy được thực thi bỏi bộ xử lý của máy

Trình biên dịch JIT tiêu chuẩn thì thực hiện theo yêu cầu Khi một phươngthức được gọi, trình biên dịch JIT phân tích MSIL và tạo ra sản phẩm mã máy cóhiệu quả cao, mã này có thể chạy rất nhanh Trình biên dịch JIT đủ thông minh

để nhận ra khi một mã đã được biên dịch, do vậy khi ứng dụng chạy thì việc biêndịch chỉ xảy ra khi cần thiết, tức là chỉ biên dịch mã MSIL chưa biên dịch ra mãmáy Khi đó một ứng dụng NET thực hiện, chúng có xu hướng là chạy nhanh vànhanh hơn nữa, cũng như là những mã nguồn được biên dịch rồi thì được dùnglại

Do tất cả các ngôn ngữ NET Framework cùng tạo ra sản phẩm MSILgiống nhau, nên kết quả là một đối tượng được tạo ra từ ngôn ngữ này có thểđược truy cập hay được dẫn xuất từ một đối tượng của ngôn ngữ khác trong.NET Ví dụ, người phát triển có thể tạo một lóp cơ sở trong VB.NET và sau đódẫn xuất nó trong C# một cách dễ dàng

1.1.3 Nền tảng ngôn ngữ C#

Trang 25

Kiểu dữ liệu

C# là ngôn ngữ lập trình mạnh về kiểu dữ liệu, một ngôn ngữ mạnh vềkiểu dữ liệu là phải khai báo kiểu của mỗi đối tượng khi tạo (kiểu số nguyên, sốthực, kiểu chuỗi, kiểu điều khiển ) và trình biên dịch sẽ giúp cho người lập trìnhkhông bị lỗi khi chỉ cho phép một loại kiểu dữ liệu có thể được gán cho các kiểu

dữ liệu khác Kiểu dữ liệu của một đối tượng là một tín hiệu để trình biên dịchnhận biết kích thước của một đối tượng (kiểu int có kích thước là 4 byte) và khảnăng của nó (như một đối tượng button có thể vẽ, phản ứng khi nhấn, )

Tương tự như C++ hay Java, C# chia thành hai tập họp kiểu dữ liệu chính:Kiểu xây dựng sẵn (built- in) mà ngôn ngữ cung cấp cho người lập trình và kiểuđược người dùng định nghĩa (user-defined) do người lập trình tạo ra

C# phân tập hợp kiểu dữ liệu này thành hai loại: Kiểu dữ liệu giá tri(value) và kiểu dữ liệu tham chiếu (reference) Việc phân chi này do sự khácnhau khi lưu kiểu dữ liệu giá trị và kiểu dữ liệu tham chiếu trong bộ nhớ Đối vớimột kiểu dữ liệu giá tri thì sẽ được lưu giữ kích thước thật trong bộ nhớ đã cấpphát là stack Trong khi đó thì địa chỉ của kiểu dữ liệu tham chiếu thì được lưutrong stack nhưng đối tượng thật sự thì lưu trong bộ nhớ heap

Nếu chúng ta có một đối tượng có kích thước rất lớn thì việc lưu giữchúng trên bộ nhớ heap rất có ích, trong chương 4 sẽ trình bày những lợi ích vàbất lọi khi làm việc với kiểu dữ liệu tham chiếu, còn trong chương này chỉ tậptrung kiểu dữ kiểu cơ bản hay kiểu xây dựng sẵn

Trang 26

Ngoài ra C# cũng hỗ trợ một kiểu con trỏ C++, nhưng hiếm khi được sửdụng, và chỉ khi nào làm việc vói những đoạn mã lệnh không được quản lý(unmanaged code) Mã lệnh không được quản lý là các lệnh được viết bên ngoàinền MS.NET, như là các đối tượng COM.

Kiểu dữ liệu xây dựng sẵn

Ngôn ngữ C# đưa ra các kiểu dữ liệu xây dựng sẵn rất hữu dụng, phù hợpvới một ngôn ngữ lập trình hiện đại, mỗi kiểu dữ liệu được ánh xạ đến một kiểu

dữ liệu được hỗ trợ bởi hệ thống xác nhận ngôn ngữ chung (Common LanguageSpecification: CLS) ữong MS.NET Việc ánh xạ các kiểu dữ liệu nguyên thuỷcủa C# đến các kiểu dữ liệu của NET sẽ đảm bảo các đối tượng được tạo ratrong C# có thể được sử dụng đồng thời với các đối tượng được tạo bởi bất cứngôn ngữ khác được biên dịch bởi NET, như VB.NET

Mỗi kiểu dữ liệu có một sự xác nhận và kích thước không thay đổi, khônggiống như C++, int trong C# luôn có kích thước là 4 byte bởi YÌ nó được ánh xạ

từ kiểu Int32 trong NET

Chọn kiểu dữ liệu

Thông thường để chọn một kiểu dữ liệu nguyên để sử dụng như short, inthay long thường dựa vào độ lớn của giá tri muốn sử dụng Ví dụ, một biếnushort có thể lưu giữ giá trị từ 0 đến 65.535, trong khi biến ulong có thể lưu giữgiá trị từ 0 đến 4.294.967.295, do đó tùy vào miền giá tri của phạm vi sử dụngbiến mà chọn các kiểu dữ liệu thích hợp nhất Kiểu dữ liệu int thường được sử

Trang 27

dụng nhiều nhất trong lập trình vì với kích thước 4 byte của nó cũng đủ để lưucác giá trị nguyên cần thiết.

Kiểu số nguyên có dấu thường được lựa chọn sử dụng nhiều nhất trongkiểu số trừ khi có lý do chính đáng để sử dụng kiểu dữ liệu không dấu

Cách tốt nhất khi sử dụng biến không dấu là giá tri của biến luôn luôndương, biến này thường thể hiện một thuộc tính nào đó có miền giá trị dương Ví

dụ khi cần khai báo một biến lưu giữ tuổi của một người thì ta dùng kiểu byte(số nguyên từ 0-255) vì tuổi của người không thể nào âm được

Kiểu float, double, và decimal đưa ra nhiều mức độ khác nhau về kíchthước cũng như độ chính xác.Với thao tác trên các phân số nhỏ thì kiểu float làthích hợp nhất Tuy nhiên lưu ý rằng trình biên dịch luôn luôn hiểu bất cứ một sốthực nào cũng là một số kiểu double trừ khi chúng ta khai báo rõ ràng Để gánmột số kiểu float thì số phải có ký tự f theo sau

float soFloat = 24f;

Kiểu dữ liệu ký tự thể hiện các ký tự Unicode, bao gồm các ký tự đơngiản, ký tự theo mã Unicode và các ký tự thoát khác được bao trong những dấunháy đơn Ví dụ, A là một ký tự đơn giản trong khi \u0041 là một ký tự Unicode

Ký tự thoát là những ký tự đặc biệt bao gồm hai ký tự liên tiếp trong đó ký tựdầu tiên là dấu chéo ‘V Ví dụ, \t là dấu tab

Trang 28

1.2 Hệ quản trị cơ sở dữ liệu SQL server

Một hệ quản trị cơ sở dữ liệu là một hệ thống các chương trình hỗ trợ cáctác vụ quản lý, khai thác dữ liệu theo mô hình cơ sở dữ liệu quan hệ

SQL Server là một hệ thống quản lý cơ sở dữ liệu quan hệ (RDBMS) haycòn được gọi Relation Database Management System Cơ sở dữ liệu quan hệ là

cơ sở dữ liệu mà dữ liệu bên trong nó được tổ chức thành các bảng Các bảngđược tổ chức bằng cách nhóm dữ liệu theo cùng chủ đề và có chứa các cột và cáchàng thông tin Sau đó các bảng này lại quan hệ với nhau bởi Database Enginekhi có yêu cầu RDBMS là một trong những mô hình cơ sở dữ liệu thông dụngnhất hiện nay

Người dung truy cập dữ liệu ữên Server thông qua ứng dụng Người quảntrị CSDL truy cập server trực tiếp để thực hiện các chức năng cấu hình, quản trị,thực hiện các thao tác bảo trì CSDL

Ngoài ra, SQL Server là một CSDL có khả năng mở rộng, nghĩa là chúng

dùng truy cập dữ liệu đồng thòi

Các phiên bản của SQL Server phổ biến hiện nay trên thị trường là SQLServer 7.0, SQL Server 2000, SQL Server 2005, SQL Server 2008

Trang 29

Các phiên bản của SQL Server 2005

SQL Server 2005 nâng cao hiệu năng, độ tin cậy, khả năng lập trình đơngiản và giao diện dễ sử dụng hơn so với SQL Server 2000 SQL Server 2005 tậptrung vào khả năng xử lý giao dịch trực tuyến (online transaction processing

- OLTP), ứng dụng thương mại điện tử (e- ecommerce) và kho dữ liệu (datawarehousing) Ngoài ra những cải tiến quan trọng trong SQL Server 2005 làthêm các dịch vụ mới như: dịch vụ báo cáo (reporting service), service broker và

sự thay đổi đáng kể trong cỗ máy cơ sở dữ liệu SQL Server 2005 được sử dụngrộng rãi cho nhiều đối tượng khác nhau nên Microsoft cung cấp nhiều phiên bảnkhác nhau cho phù hợp với các yêu càu về chi phí, thời gian thực hiện, của các

tổ chức, cá nhân Năm phiên bản của SQL Server 2005 là:

+ Microsoft SQL Server 2005 Enterprise Edition +

Microsoft SQL Server 2005 Standard Edition +

Microsoft SQL Server 2005 Workgroup Edition +

Microsoft SQL Server 2005 Developer Edition +

Microsoft SQL Server 2005 Express Edition

+ Hầu hết các tổ chức đều chọn ừong ba phiên bản SQL Server 2005Enterprise Edition, SQL Server 2005 Standard Edition, SQL Server 2005Workgroup Edition Các tổ chức chọn một trong ba phiên bản này với lý do làchỉ có các phiên bản Enterprise, Standard và Workgroup được cài đặt và sử dụngtrong môi trường server phục vụ cho hoạt động thực tế

SQL Server 2005 Enterprise Edition (32-bit và 64-bit)

Trang 30

Enterprise Edition được sử dụng trong các doanh nghiệp, tổ chức có cácmức yêu cầu xử lý giao dịch trực tuyến trên diện rộng (online trasactionprocessing - OLTP), khả năng phân tích dữ liệu phức tạp cao, hệ thống kho dữliệu (data warehousing systems) và web site Enterprise Edition phù họp cho các

tổ chức lớn và các yêu cầu phức tạp

SQL Server 2005 Standard Edition (32-bit và 64-bit)

Standard Edition là phiên bản phục vụ cho việc quản trị và phân tích dữliệu phù hợp cho các doanh nghiệp, tổ chức vừa và nhỏ Nó bao gồm các giảipháp cần thiết cho thương mại điện tử (ecommerce), kho dữ liệu (datawarehousing) và dòng doanh nghiệp (line-of-business)

SQL Server 2005 Workgroup Edition (32-bit only)

Workgroup Edition là giải pháp quản trị dữ liệu phù họp cho các doanhnghiệp, tổ chức nhỏ chỉ cần một cơ sở dữ liệu không giói hạn kích thước hoặc sốngười sử dụng Workgroup Edition là lý tưởng cho các mức cơ sở dữ liệu tincậy, mạnh mẽ và dễ quản trị

SQL Server 2005 Developer Edition (32-bit và 64-bit)

Developer Edition có tất cả các tính năng của phiên bản SQL Server 2005Enterprise Edition, nhng nó chỉ là phiên bản sử dụng cho phát triển và kiểm traứng dụng Phiên bản này phù họp cho các cá nhân, tổ chức xây dựng và kiểm traứng dụng

SQL Server 2005 Express Edition (32-bit only)

SQL Server Express dễ sử dụng và quản tri cơ sở dữ liệu đơn giản Đượctích hợp với Microsoft Visual Studio 2005, SQL Server Express ừở nên dễ dàng

Trang 31

để phát triển các ứng dụng dữ liệu giàu khả năng, an toàn trong luư trữ, và nhanhchóng triển khai.

SQL Server Express là phiên bản miễn phí, có thể dùng như một cơ sở dữliệu máy khách hoặc cơ sở dữ liệu máy chủ đơn giản SQL Server Express là lựachọn tốt cho những người dùng chỉ cần một phiên bản SQL Server 2005 nhỏgọn, dùng trên máy chủ có cấu hình thấp, những nhà phát triển ứng dụng khôngchuyên hay những người yêu thích xây dựng các ứng dụng nhỏ

1.3 Kỹ thuật lập trình ASP.Net

Đầu năm 2002, Microsoft giói thiệu một kĩ thuật lập trình Web khá mói mẻ vớitên gọi ban đầu là ASP+, tên chính thức sau này là ASP.Net Với ASP.Net,không những không cần đòi hỏi bạn phải biết các tag HTML, thiết kế Web, mà

nó còn hỗ trợ mạnh lập trình hướng đối tượng trong quá trình xây dựng

WebASP.Net là kỹ thuật lập trình và phát triển ứng dụng web ở phía Server (Server-side) dựa trên nền tảng của Microsoft Net Framework

Hầu hết, những người mới lập trình web đều bắt đầu tìm hiểu những kĩ thuật ởphía client (client-side) như: HTML, Java Script, css Khi Web browser yêu cầumột trang web (ữang web sử dụng kĩ thuật client-side), Web browser tìm trangWeb mà client yêu cầu, sau đó gửi về phía client Client nhận kết quả trả về từServer và hiển thì lên màn hình

ASP.Net sử dụng kỹ thuật lập trình ở phía server thì hoàn toàn khác, mã lệnh ởphía server sẽ được biên dịch và thi hành tại Web - server Sau khi được Serverđọc, biên dịch và thi hành, kết quả tự động được chuyển sang HTML

Ngày đăng: 24/09/2015, 11:54

TỪ KHÓA LIÊN QUAN

TRÍCH ĐOẠN

TÀI LIỆU CÙNG NGƯỜI DÙNG

TÀI LIỆU LIÊN QUAN

w