GIỚI THIỆU MÔN HỌC
Thương mại điện tử (E-Commerce) là quá trình mua bán hàng hoá hay dịch vụ thông qua mạng điện tử. Phương tiện phổ biến dùng trong E- Commerce là Internet
GIỚI THIỆU MÔN HỌC
Công nghệ thông tin đã và đang thay đổi mạnh mẽ, nhanh chóng phương thức tiến hành hoạt động kinh doanh, thay đổi cơ bản các chiến lược và tổ chức công ty
184 trang |
Chia sẻ: thanhnguyen | Lượt xem: 2046 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Giáo trình thương mại điện tử, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
dụng :
• Microsoft Frontpage
• Macromedia Dreamweaver
Kiểm định hệ thống
• Ứng dụng web đòi hỏi phải kiểm định ở
cả phía client và phía server.
• Kiểm định dữ liệu nhập
• Loại bỏ những liên kết không xác định
Cài đặt và đánh giá hệ thống
Bàn giao ứng dụng web cho công ty trên
cơ sở:
• Công ty có thể tự đảm nhận việc quản trị
trang web
• Công ty tự cập nhật trang web, xử lý
những yêu cầu khách hàng
• Theo dõi lưu lượng truy cập trang web
Xuất bản ứng dụng web
• Với ứng dụng web thì đó là việc đưa lên
mạng (LAN, INTERNET) toàn bộ site đã
thiết kế
• Site phải được đặt trên một Web Server
• Ứng dụng có thể cần nhiều Server như
mail server, ftp server,…
Web Server
• Với các hệ điều hành Win2K web server
là phần mềm IIS (Internet Information
Service) được cài bên trong (nếu thiếu,
có thể cài thêm bằng “Add/Remove
Software”)
• Mặc định, IIS quản lý vùng đĩa cứng
“C:\Inetpub\wwwroot\”
Thiết kế ứng dụng TMĐT
• TMĐT là một ứng dụng web
• TMĐT - với nghĩa hẹp, một cửa hàng trực
tuyến bao gồm tối thiểu các thành phần sau:
1. Danh mục sản phẩm (Product Catalogs)
2. Giỏ hàng (shopping cart)
3. Quy trình thanh toán (payment process)
Thiết kế ứng dụng TMĐT
• Cơ sở dữ liệu phải được thiết kế để đáp ứng
các yêu cầu thông tin khách hàng như:
+ Sản phẩm
+ Thời gian gửi hàng
+ Chi phí và cách thức gửi hàng
+ Trạng thái đơn hàng
+ Thời gian nhận hàng
+ Trạng thái kho hàng:đã có hay đang sản
xuất,...(real-time inventory)
Qui trình TMĐT
• Nội dung
Khái niệm chung
Các bước của TMĐT
Quản lý Website TMĐT
Thiết kế CSDL TMĐT
Khái niệm chung
• TMĐT ban đầu là hình thức đặt hàng qua thư
• TMĐT là phương tiện thực hiện kinh doanh trên
internet.
• TMĐT bao gồm mua sắm trực tuyến, thường
được gọi là C-to-B (Customer-to-Business), ví
dụ Dell ( Amazon
(
• TMĐT gồm cả việc thương mại giữa các doanh
nghiệp gọi là B-to-B (Business-to-Business), ví
dụ ebay (
Các bước của quy trình TMĐT
Tiếp thị
Vận chuyển
Thực hiện
Biên nhận
Đơn hàng
Kháchhàng/
Người xem
Xem sản phẩm
Tính tiền
Thăm website
Nạp giỏ hàng
Phí vận chuyển Thanh toán
Các hộp phẳng trình bày hoạt động của khách hàng;
Các hộp ba chiều trình bày các quy trình kinh doanh không do khách hàng thực hiện
Tiếp thị
• Mục đích là nhắm đến những người mua tiềm
năng và thu hút họ vào site TMĐT.
• Sử dụng internet để tiếp thị đến khách hàng
theo nhiều cách khác nhau: quảng cáo,
email,hội chợ,...
• Thành lập cộng đồng (user group), diễn đàn,
chat, thăm dò,... nhằm tạo môi trường thu hút
người xem trở lại
• TMĐT tập trung tiếp thị những khách hàng đã
tìm thấy website
Khách hàng/Người xem
• Khách hàng là người gõ nhập URL hoặc liên kết
để xem website TMĐT.
• Cần phân biệt hai hình thức mua hàng: mua
hàng giữa các doanh nghiệp và mua hàng giữa
khách hàng và doanh nghiệp.
• Mua hàng giữa các doanh nghiệp: người mua là
một doanh nghiệp khác cần có nhiều tùy chọn để
mua. Ngoài ra có thể có thêm yêu cầu đối với các
mặt hàng có giá trị lớn và quan trọng.
• Mua hàng truyền thống giữa khách hàng và
doanh nghiệp: người mua thường là một cá nhân
sẽ thanh toán bằng thẻ tín dụng và nhờ gửi hàng
đến tận nhà.
Thăm website
• Ngay sau khi một cá nhân vào website, một
site kinh doanh sẽ được tải xuống.
• Đầu tiên là bước làm quen để tạo kinh
nghiệm thương mại điện tử cho khách
hàng.
• Ngay lúc đó đã có thể bắt đầu theo dõi và
tạo profile cho khách hàng này.
• Dựa vào thông tin đó có thể nhắm đến các
mặt hàng mà khách hàng này quan tâm
nhiều nhất. Đây là bước bắt đầu của TMĐT
Xem sản phẩm
• Người xem bắt đầu duyệt những mặt hàng
trên website
• Các mặt hàng được bố trí theo các gian
hàng, chủng loại đa dạng, dể tìm kiếm
• Khi một khách hàng tiềm năng thực hiện
điều này, khách hàng có thể bị thu hút vào
các mặt hàng đang bày bán, sự khuyến
mãi, các mặt hàng liên quan hay đã nâng
cấp.
Nạp giỏ hàng
• Người mua đặt hàng vào “giỏ mua sắm”
của mình.
• Giỏ mua sắm chỉ đơn giản là một danh
sách các mặt hàng mà người mua đã chọn,
số lượng, giá cả,thuộc tính(màu sắc, kích
cỡ,...) và bất kỳ thông tin khác liên quan
đến đơn đặt hàng tiềm năng.
• Các giỏ mua sắm thường cung cấp các tùy
chọn để dọn sạch giỏ, xóa các mặt hàng,và
cập nhật số lượng.
Tính tiền (checkout)
• Ngay sau khi người mua có tất cả các mặt
hàng cần mú, họ sẽ bắt đầu quy trình tính
tiền
• Đối với mô hình mua hàng giữa khách
hàng với doanh nghiệp, khách hàng
thường sẽ nhập vào thông tin về địa chỉ
chuyển hàng và tính hóa đơn.
• Người mua cũng có thể thêm vào thông tin
về lời chúc mừng, gói quà và các thông tin
khác đối với các dịch vụ phụ thuộc.
Tính phí vận chuyển
• Phí vận chuyển có thể đơn giản như là việc
tính phí toàn bộ hay phức tạp như là việc
tính phí cho mỗi mặt hàng đã muavà tương
quan với đoạn đường mà hàng phải được
vận chuyển đến
• Có thể khó khăn hơn khi xử lý việc đặt
hàng quốc tế. Khi đó có thể liên kết với một
“nhà vận chuyển”(provider), theo dõi hàng
hóa trong quá trình vận chuyển.
Thanh toán (payment)
• Sau khi tính toán tổng giá trị các mặt hàng (có kèm thuế
và phí vận chuyển) người mua sẽ trình bày phương thức
thanh toán
• Các tùy chọn sẽ khác nhau đối với các giao dịch giữa
doanh nghiệp với doanh nghiệp và giữa khách hàng với
doanh nghiệp.
• Giữa khách hàng với doanh nghiệp thường thanh toán
bằng thẻ tín dụng hoặc trả sau khi giao nhận
• Giữa doanh nghiệp với doanh nghiệp cần có sẵn đầy đủ
các tùy chọn, bao gồm cả đơn đặt hàng, báo giá, bảo
lãnh,...
• Đối với các thẻ tín dụng, có các tùy chọn để xử lý các thẻ
tín dụng ở ngoại tuiyến hay trực tuyến. Việc xử lý trực
tuyến trên internet qua các dịch vụ do các công ty uy tín
đảm nhận.
Biên nhận (receipt)
• Sau khi thực hiện xong việc đặt hàng, có thể cần
gửi trở lại cho người mua một biên nhận
• Đối với mô hinh thương mại điện tử giữa doanh
nghiệp với doanh nghiệp, biên nhận có thể là một
danh sách đính kèm với đơn đặt hàng
• Đối với khách hàng, biên nhận có thể là một bảng
inlại của đơn đặt hàng trên màn hình, hoặc một
danh sách được gửi cho người mua hàng bằng
email
• Trong cả hai trường hợp, quy trình này đều có thể
tự động hóa dễ dàng
Xử lý đơn đặt hàng
• Nếu không tự động xử lý thẻ tín dụng, thì đầu tiên
phải xử lý giao dịch tài chính
• Các quy tắc kinh doanh chuẩn điều khiển bước
này như thể việc đặt hàng được thực hiện qua
điện thoại hay qua thư
• Có thể cung cấp tùy chọn cho khách hàng biết về
tình trạng đặt hàng
• Có thể cung cấp tình trạng hàng tồn kho, tình
trạng cung cấp mặt hàng.
Thực hiện đơn đặt hàng
• Ngay sau khi có đơn hàng hợp lệ, nó cần được
thực hiện. Đây có thể là công đoạn kinh doanh
nhiều thách thức nhất
• Nếu mua sắm trực tuyến, có thể có khó khăn
trong kiểm kê hàng
• Nếu mua sắm thông qua hệ thống dịch vụ thì có
thể có các vấn đề hợp nhất về hệ thống dịch vụ
thực hiện đơn đặt hàng
Vận chuyển hàng
• Bước cuối cùng trong quy trình thương mại điện
tử là vận chuyển hàng cho khách hàng
• Có thể cung cấp tình trạng đặt hàng cho khách
hàng. Trong trường hợp này, nó có thể bao gồm
số vận chuyển UPS hay FedEx để khách hàng
theo dõi sự vận chuyển hàng của họ
Quản lý website TMĐT
• Các công cụ quản lý có thể đơn giản như các
công cụ báo cáo và theo dõi đơn đặt hàng hoặc
phức tạp như các công cụ quản lý cơ sở dữ liệu
Thiết kế CSDL TMĐT
• Cơ sở dữ liệu lưu trữ thông tin hàng hóa, thể loại,
đơn đặt hàng, khách hàng, và các dữ liệu khác
• Thiết kế cơ sở dữ liệu có thể dựa trên mô hình
thực thể-quan hệ.
• Các bảng, các thuộc tính, các quan hệ cần bảo
đảm điều kiện chuẩn dữ liệu, nhằm bảo vệ tính
toàn vẹn và tính không dư thừa dữ liệu.
Thiết kế chức năng TMĐT
• Nội dung
Khái niệm chung
Chức năng đối với khách hàng
Chức năng đối với nhà quản trị hệ thống
Chức năng đối với nhân viên bán hàng
Khái niệm chung
• Sau khi phân tích các bước của quy trình thương
mại điện tử, có thể tiến hành thiết kế chức năng
hệ thống
• Các chức năng của hệ thống có thể phân loại
như sau
-Những chức năng hiển thị: NSD có thể nhận biết,
theo dõi sự hoạt động của hệ thống
-Những chức năng ẩn: NSD không thể nhận biết,
theo dõi được. Thường đó là những chức năng
kỹ thuật như lưu trữ, xử lý dữ liệu,...
-Một số chức năng tùy chọn: làm tăng thêm mức
độ thân thiện, tiện dụng cho hệ thống
Khái niệm chung
• Trong hệ thống bán hàng trực tuyến, các
chức năng chính có thể phân loại như sau:
-Chức năng đối với khách hàng
-Chức năng đối với nhà quản trị hệ thống
-Chức năng đối với nhân viên bán hàng
Chức năng đối với khách hàng
• Chức năng tạo tài khoản khách hàng
• Chức năng đăng nhập hệ thống
• Chức năng thoát khỏi hệ thống
• Chức năng tìm kiếm mặt hàng
• Chức năng chọn hàng
• Chức năng đặt hàng
• Chức năng theo dõi đơn hàng của mình
• Chức năng đóng góp ý kiến với công ty
Chức năng tạo tài khoản khách hàng
• Màn hình hệ thống nhắc khách hàng nhập thông
tin cá nhân: họ tên, địa chỉ, email,...
• Khách hàng nhập thông tin theo yêu cầu và ấn
nút “submit”
• Hệ thống lưu trữ những thông tin đó vào CSDL
• Hệ thống thông báo thành công và hiển thị tài
khoản khách hàng
• Kết thúc đăng ký tài khoản và khách hàng có thể
mua hàng
Chức năng đăng nhập hệ thống
• Màn hình hệ thống yêu cầu khách hàng nhập:
họ tên, mật khẩu
• Khách hàng nhập thông tin theo yêu cầu và ấn
nút “submit”
• Hệ thống xácnhận thông tin NSD nhập vào có
hợp lệ không?
• Hệ thống thông báo NSD về tình trạng đăng
nhập
• Kết thúc đăng nhập và NSD có thể đặt hàng
Chức năng thoát khỏi hệ thống
• NSD ấn nút “logout”
• Hệ thống đưa NSD trở về trạng thái chưa
đăng nhập và kết thúc mọi phiên giao dịch
với NSD hiện thời
• NSD có thể đặt hàng với tư cách khách
hàng mới
Chức năng tìm kiếm mặt hàng
• Hệ thống hiển thị màn hình tìm kiếm và
yêu cầu khách hàng nhập vào từ khóa tìm
kiếm và/hoặc chọn phương thức tìm kiếm
• Khách hàng nhập từ khóa hoặc thao tác
chuột và ấn nút “submit”
• Hệ thống tìm kiếm trong CSDL ứng với
thông tin khách hàng nhập vào
• Hệ thống hiển thị kết quả tìm kiếm
Chức năng chọn hàng
• Khách hàng chọn mặt hàng mà mình cần
mua cho vào giỏ hàng. Quá trình này có
thể lặp lại nhiều lần. Trong quá trình này
khách hàng có thể làm các công việc sau:
- Thêm/xóa một mặt hàng mà mình muốn
mua trong giỏ hàng
- Thay đổi số lượng của một mặt hàng trong
giỏ hàng
• Hệ thống hiển thị thông tin giỏ hàng
Chức năng đặt hàng
• Khách hàng sau khi xem xong chi tiết giỏ hàng
của mình thì gửi đơn đặt hàng tới hệ thống xác
định việc đặt hàng
• Hệ thống kiểm tra xem khách hàng đã đăng
nhập chưa
• Hệ thống yêu cầu khách hàng chọn phương
thức vận chuyển
• Khách hàng chọn phương thức vận chuyển
• Hệ thống yêu cầu khách hàng chọn hình thức
thanh toán
• Khách hàng chọn hình thức thanh toán, nhập
thông tin cần thiết và ấn nút “submit”
Chức năng theo dõi đơn đặt hàng
• Khách hàng yêu cầu xem đơn hàng của
mình tại mọi thời điểm
• Hệ thống đưa ra thông tin trong đơn đặt
hàng của khách hàng và trạng thái của
đơn đặt hàng
• Khách hàng nhận thông tin của mình
Chức năng đóng góp ý kiến
• Khách hàng muốn đóng góp ý kiến và ấn nút
“góp ý”
• Hệ thống đưa ra màn hình đóng góp ý kiến và
yêu cầu khách hàng gửi ý kiến
• Khách hàng nhập nội dung ý kiến và ấn nút
“send”
• Hệ thống lưu ý kiến khách hàng
• Hệ thống gửi thông báo cám ơn khách hàng
Chức năng đối với nhà quản trị
• Chức năng đăng nhập hệ thống
• Chức năng thoát khỏi hệ thống
• Chức năng thêm người sử dụng hệ thống
• Chức năng loại người sử dụng
• Chức năng thống kê doanh thu
• Chức năng trả lời ý kiến khách hàng
Chức năng thêm NSD hệ thống
• Hệ thống kiểm tra quyền quản trị
• Màn hình hệ thống nhắc nhà quản trị nhập
thông tin NSD mới: họ tên, mật khẩu,...
• Nhà quản trị nhập thông tin theo yêu cầu
và ấn nút “submit”
• Hệ thống kiểm tra và lưu trữ những thông
tin đó vào CSDL
• Hệ thống thông báo cho nhà quản trị về
kết quả xử lý
Chức năng loại NSD hệ thống
• Hệ thống kiểm tra quyền quản trị
• Màn hình hệ thống liệt kê mọi NSD
• Nhà quản trị chọn NSD mà mình muốn
xóa và ấn nút “xóa”
• Hệ thống loại bỏ NSD khỏi CSDL
• Hệ thống thông báo cho nhà quản trị về
kết quả xử lý
Chức năng thống kê doanh thu
• Hệ thống kiểm tra quyền quản trị
• Nhà quản trị yêu cầu thống kê
• Hệ thống thống kê các hóa đơn đặt hàng
đã thanh toán và số lượng sản phẩm còn
lại trong kho
• Hiển thị kết quả thống kê cho nhà quản trị
Chức năng trả lời ý kiến khách hàng
• Hệ thống kiểm tra quyền quản trị
• Hệ thống liệt kê các ý kiến khách hàng
chưa được trả lời
• Nhà quản trị chọn ý kiến muốn trả lời và
nhập nội dung câu trả lời
• Hệ thống cập nhật nội dung câu trả lờivào
CSDL
• Thông báo đã trả lời ý kiến khách hàng
cho nhà quản trị
Chức năng đối với nhân viên bán hàng
• Chức năng đăng nhập hệ thống
• Chức năng thoát khỏi hệ thống
• Chức năng cập nhật loại hàng
• Chức năng cập nhật hàng
• Chức năng xử lý đơn hàng
Chức năng cập nhật loại hàng
• Hệ thống kiểm tra quyền quản trị
• Hệ thống cung cấp danh sách loại hàng
• Nhân viên bán hàng lựa chọn các chức năng:
- Thêm loại hàng mới
- Sửa loại hàng
- Xóa loại hàng
• Hệ thống cập nhật thông tin vào CSDL
• Thông báo cập nhật thành công
Chức năng cập nhật hàng
• Hệ thống kiểm tra quyền quản trị
• Hệ thống cung cấp danh sách loại hàng
• Nhân viên bán hàng lựa chọn một loại hàng.
• Hệ thống cung cấp danh sách sản phẩm thuộc
loại hàng đã cho
• Nhân viên bán hàng lựa chọn các chức năng:
- Thêm sản phẩm mới
- Sửa sản phẩm
- Xóa sản phẩm
• Hệ thống cập nhật thông tin vào CSDL
• Thông báo cập nhật thành công
Chức năng xử lý đơn hàng
• Hệ thống kiểm tra quyền quản trị
• Hệ thống cung cấp màn hình hiển thị chức năng
quản lý xử lý đơn đặt hàng
• Nhân viên bán hàng lựa chọn các chức năng:
- Hiển thị đơn đặt hàng
- Đánh dấu tình trạng giao hàng ứng với đơn đặt
hàng
- Xóa đơn đặt hàng
• Nhân viên bán hàng thao tác và ấn “submit”
• Hệ thống cập nhật thông tin vào CSDL
• Hiển thị kết quả thực hiện
Thiết kế Cơ sở dữ liệu
• Nội dung
Khái niệm chung
Mô hình thực thể - quan hệ
Sơ đồ thực thể quan hệ
Khái niệm chung
• Cơ sở dữ liệu là tập hợp những dữ liệu có liên
quan với nhau, cùng phục vụ các nhu cầu của
nhiều người sử dụng.
• Cơ sở dữ liệu là tập hợp của nhiều loại bảng
khác nhau và có liên quan với nhau
• Hệ quản trị CSDL (DBMS) là một hệ thống phần
mềm phục vụ thao tác CSDL.
• Hệ CSDL quan hệ là một loại hệ CSDL với
những cấu trúc ưu việt cho phép mức độc lập dữ
liệu cao hơn các hệ quản trị CSDL phân cấp và
mạng
Khái niệm chung
• Dữ liệu được mô hình hóa theo nhiều
phương pháp
• Phương pháp thực thể - quan hệ (entity -
relationship) là mô hình được mô tả đầu
tiên năm 1976
• Hình chử nhật đặc tả các thực thể
• Hình thoi để mô tả các quan hệ
• Các thực thể và quan hệ nối với nhau
bằng các đường nối
Mô hình thực thể - quan hệ
• Phương pháp tiếp cận: mô tả những yêu
cầu dữ liệu trong thế giới thực bằng một
cách thức đơn giản nhưng đủ ý nghĩa để
cả người thiết kế lẫn người dùng đều hiểu
được.
• Phương pháp mô tả: thông qua các lược
đồ để mô tả các thực thể, các thuộc tính
và các quan hệ có thể có trong hệ thống
Mô hình thực thể - quan hệ
• Mô hình mua hàng thường gặp có lược đồ
như sau:
Khách hàng Sản phẩmĐặt
hàng
Sơ đồ thực thể - quan hệ
Mô hình thực thể - quan hệ
• Các bảng
– Products
– Categories
– Customers
– Orders
– Orderitems
Bảng sản phẩm
• Mã sản phẩm
• Tên sản phẩm
• Mô tả
• Giá
• Ảnh
• Mã loại
• Ghi chú
• Nổi bật
Bảng loại sản phẩm
• Mã loại
• Mô tả loại
• Tên loại
• Ảnh loại
Bảng khách hàng
• Mã khách hàng
• Họ / Tên
• email
• Địa chỉ 1/Địa chỉ 2
• Thành phố / Mã vùng
• Tỉnh / Quốc gia
• Mật khẩu
• đt / fax
• Ghi chú
• TG truy nhập mới nhất
• Trạng thái
Bảng đơn hàng
• Mã đơn hàng
• Mã khách hàng
• Ngày
• Họ / Tên
• Địa chỉ 1/Địa chỉ 2
• Thành phố / Mã
vùng
• Tỉnh / Quốc gia
• Kiểu thẻ
• Số thẻ
• Ngày hết hạn thẻ
Bảng chi tiết đơn hàng
• Mã chi tiết
• Mã đơn hàng
• Mã sản phẩm
• Số lượng
• Giá đơn vị
Bảng nhân viên
• Tên nhân viên
• Tên đầy đủ
• Mật khẩu
• Quyền
Công cụ TMĐT
• Nội dung
Khái niệm chung
Giá khuyến mại
Sơ đồ thực thể quan hệ
Khái niệm chung
• Cơ sở dữ liệu là tập hợp những dữ liệu có liên
quan với nhau, cùng phục vụ các nhu cầu của
nhiều người sử dụng.
• Cơ sở dữ liệu là tập hợp của nhiều loại bảng
khác nhau và có liên quan với nhau
• Hệ quản trị CSDL (DBMS) là một hệ thống phần
mềm phục vụ thao tác CSDL.
• Hệ CSDL quan hệ là một loại hệ CSDL với
những cấu trúc ưu việt cho phép mức độc lập dữ
liệu cao hơn các hệ quản trị CSDL phân cấp và
mạng
Giá khuyến mại
• Cơ sở dữ liệu là tập hợp những dữ liệu có liên
quan với nhau, cùng phục vụ các nhu cầu của
nhiều người sử dụng.
• Cơ sở dữ liệu là tập hợp của nhiều loại bảng
khác nhau và có liên quan với nhau
• Hệ quản trị CSDL (DBMS) là một hệ thống phần
mềm phục vụ thao tác CSDL.
• Hệ CSDL quan hệ là một loại hệ CSDL với
những cấu trúc ưu việt cho phép mức độc lập dữ
liệu cao hơn các hệ quản trị CSDL phân cấp và
mạng
Công cụ TMĐT
• Nội dung
Khái niệm chung
Giá khuyến mại
Sơ đồ thực thể quan hệ
Hướng dẫn thực hành
• Cài đặt webserver
• Tạo local site và remote site
• Xuất bản website
• Hiển thị dữ liệu truyền từ form
• Hiển thị dữ liệu truyền từ CSDL
Cài đặt webserver
• Với các hệ điều hành Win2K web server là
phần mềm IIS (Internet Information
Service) được cài bên trong (nếu thiếu, có
thể cài thêm bằng “Add/Remove
Software”)
• Mặc định, IIS quản lý vùng đĩa cứng
“C:\Inetpub\wwwroot\”
Kiểm tra webserver
Kiểm tra IIS
- Tạo file “hello.asp” như sau
- Đặt file trên lên web server
C:/inetpub/wwwroot/hello.asp
- Gọi (call) bằng Internet Explorer
Tạo local site và remote site
• Site cục bộ (local site) là một thư mục
lưu trữ tất cả các tập tin của web site.
• Site từ xa (remote web) có cấu trúc
giống như local site trên web server
Tạo local site và remote site
• Tạo Site cục bộ (local site) là tạo một
thư mục cá nhân lưu trữ tất cả các trang
web, ảnh, tài liệu của web site. Sau khi
soạn thảo có thể lưu trên thiết bị rời
như ramdisk(USB)
• Site từ xa (remote web) trên web server
được dùng chung và thường có thể bị
thay đổi, nên thường xuyên cần cập
nhật từ Site cục bộ
Xuất bản website
• Xuất bản website là thao tác chuyển tất
cả các tập tin từ local site lên remote
site (upload).
• Thao tác ngược lại chuyển tập tin từ
remote site xuống local site gọi là
download
Hiển thị dữ liệu truyền từ form
• Trang 1: tạo form có tên “form.htm” với
action “formprocess.asp”.
• Trang 2: xử lý form có tên
“formprocess.asp”, tạo bảng chứa tất
cả các thông tin nhập từ trang 1
Hiển thị dữ liệu truyền từ CSDL
• Tạo CSDL: mở MS ACCESS, tạo một
bảng, nhập dữ liệu giả định
• Tạo kết nối với CSDL
• Tạo câu lệnh SQL liên kết CSDL
• Hiển thị CSDL trên trang web
• Tất cả thực hiện tại local site, sau đó
upload lên remote site
Hướng dẫn thực hành
• Biến session và application
• Cách khởi tạo và sử dụng giỏ hàng
Biến session và application
• Dùng trong nhiều trang
• Session dùng cho cả phiên làm việc của
khách hàng
• Application dùng cho toàn ứng dụng
• Cách dùng biến:
Tạo session
Dùng session
Biến session và application
• Ví dụ: Tạo session
Session("admin") = adminID
Dim acart(19,1)
Session("cart") = acart
Dùng session
acart=session("cart")
acart(1,0)=productid
Khởi tạo giỏ hàng
If IsArray(Session("cart")) = false Then
Dim acart(19,1)
acart(1,0)=productid
acart(1,1)=qty
Session("cart") = acart
end if
Sử dụng giỏ hàng
If IsArray(Session("cart")) = true Then
acart=session("cart")
productid=acart(i,0)
qty=acart(i,1)
end if
Thêm phần tử vào giỏ hàng
Khi có mặt hàng với mã “productid”, ví dụ 2 và
số lượng “qty”, ví dụ 1 hãy liên kết đến
“addprod.asp?productid= 2&qty=1”
Khi đó chương trình sẽ thêm mặt hàng mới vào
giỏ hàng.
-Nếu trước đó chưa dùng giỏ hàng
(điều kiện IsArray(Session("cart")) = false)
thì tạo giỏ hàng mới và thêm vào một phần tử
-Nếu trước đó đã dùng giỏ hàng
(điều kiện IsArray(Session("cart")) = true)
thì chọn một vị trí trống để thêm vào một phần tử
Thêm phần tử vào giỏ hàng
Vị trí trống được tìm ra khi duyệt bảng acart,
từ phần tử đầu tiên đến phần tử cuối cùng
for i=lbound(acart) to ubound(acart)
if acart(i,0)="" and acart(i,1)="" then
acart(i,0)=productid
acart(i,1)=qty
end if
next
Thêm vào giỏ hàng
Biến logic “incart” dùng để kiểm tra xem giỏ hàng
đã đầy hay chưa.
-Ban đầu trạng thái chưa thêm phần tử nào vào
giỏ hàng:
“incart=false”
-Mỗi khi đã thêm một phần tử, trạng thái thay đổi
“incart=true”
-Nếu duyệt hết cả bảng mà không thể thêm được
phần tử mới thì có nghĩa giỏ đã đầy. Khi đó biến
incart vẫn nguyên giá trị false
Sử dụng giỏ hàng
If IsArray(Session("cart")) = true Then
acart=session("cart")
incart=false
for i=lbound(acart) to ubound(acart)
if acart(i,0)="" and acart(i,1)="" and not(incart)
then acart(i,0)=productid
acart(i,1)=request.form("qty")
incart=true
end if next
session("cart")=acart
end if
Sử dụng giỏ hàng
chiếc đã được thêm vào giỏ hàng của bạn.
...
Sản phẩm này KHÔNG được thêm vào
giỏ của bạn.
Giỏ hàng của bạn đã đầy
Hiển thị nội dung giỏ hàng
<% acart=session("cart")
subtotal=0
for i=lbound(acart) to ubound(acart)
if acart(i,0)"" and acart(i,1)"" then
set rscart=db.execute("select * from products where
productid=" & acart(i,0))
= rscart("name")%>||
|
<%= cursymbol & formatnumber(rscart("price") * acart(i,1))
%>
<%subtotal=subtotal+(rscart("price") * acart(i,1))
end if next %>
Tổng cộng:
Bài tập Thực hành Thương mại điện tử
Bài tập thực hành số 3
+ Tổng số buổi thực hành là 1 buổi, mỗi buổi 2 tiết
+ Hình thức báo cáo sau các buổi thực hành: Sinh viên làm bài trên máy và nộp cho giáo
viên hướng dẫn ở buổi thứ 2, trong thư mục mang tên sinh viên
+ Nghiêm cấm mọi sao chép bài làm của nhau, nếu bị phát hiện sẽ được KHÔNG được thi
Bài số 1.
Ôn tập:
- Cài đặt webserver và kiểm tra IIS.
- Truyền dữ liệu từ form
- Truyền dữ liệu từ CSDL
- Tạo tập tin danh mục sản phẩm
Tạo CSDL có tên “db.mdb” với bảng “Categories” và các trường như sau:
catcode Catdes catname catimage
1 Nokia Mobile Nokia
2 Samsung Mobile Samsung
3 Motorola Mobile Motorola
4 Sony Mobile Sony
Tạo liên kết với CSDL như sau:
Tạo tập tin "db.inc" như sau
<%
dim db
dim strConn
strConn="Driver={Microsoft Access Driver (*.mdb)}; DBQ="&Server.MapPath("db.mdb")
Set db = Server.CreateObject("ADODB.Connection")
db.open strConn
%>
Hiển thị CSDL trên trang web:
<%
dim rs
set rs=db.execute("select * from categories")
%>
<%next
rs.MoveNext%>
<%loop
rs.close
db.close
Bài tập Thực hành Thương mại điện tử
%>
Bài số 2.
Hiển thị Danh mục trên trang web với dạng ảnh:
<%
dim rs
set rs=db.execute("select * from categories")
%>
PRODUCT CATEGORY
<%
rs.MoveNext%>
<%loop
rs.close
db.close
%>
Bài số 3
Trong CSDL “db.mdb” tạo bảng “Products” và các trường như sau:
Productid name description price image catcode notes featured
1 Nokia 7250i 1 yes
2 Nokia 6820 1 no
3 Samsung X600 2 no
4 Motorola V690 3 yes
5 SonyEricson P800 4 yes
Tạo liên kết với CSDL
Hiển thị bảng “Products’ trên trang web (tự làm)
Bài số 4
Mở rộng bài số 2: với mỗi danh mục, tạo một liên kết đến danh sách sản phẩm thuộc danh
mục đó. Mỗi sản phẩm liên kết đến trang “product.asp”
Tập tin có tên là “category.asp”
<%
dim catcode
catcode=request.querystring("catcode")
%>
<%
if len(catcode)=0 then
Bài tập Thực hành Thương mại điện tử
dim rs
set rs=db.execute("select * from categories")
%>
PRODUCT CATEGORY
' style="text-
decoration:none;">
<%
rs.MoveNext%>
<%loop
rs.close
db.close
%>
<%else
set rscat=db.execute("select * from categories where catcode=" & catcode)
set rscatlist=db.execute("select name,productid from products where catcode=" & catcode & "
order by name")
%>
<% if not rscatlist.eof then
rscatlist.movefirst
while not rscatlist.eof
%>
<a href='product.asp?productid=<%=
rscatlist("productid")%>'>
<%
rscatlist.movenext
wend
end if
end if
%>
Bài tập Thực hành Thương mại điện tử
Bài tập thực hành số 4
+ Tổng số buổi thực hành là 1 buổi, mỗi buổi 2 tiết
+ Hình thức báo cáo sau các buổi thực hành: Sinh viên làm bài trên máy và nộp cho giáo
viên hướng dẫn ở buổi thứ 2, trong thư mục mang tên sinh viên
+ Nghiêm cấm mọi sao chép bài làm của nhau, nếu bị phát hiện sẽ được KHÔNG được thi
Bài số 1.
Ôn tập:
- Cài đặt webserver và kiểm tra IIS.
- Truyền dữ liệu từ form
- Truyền dữ liệu từ CSDL
- Tạo tập tin danh mục sản phẩm
- Tạo tập tin sản phẩm
Bài số 2.
Tạo tập tin cấu hình “config.inc” để đưa ra các biến thiết lập trang web,có dạng như sau:
<%
cursymbol="$"
storename="EShop"
fontface="arial"
bgcolor="#FFFFFF"
text="#000000"
vlink="#999999"
%>
Với mỗi sản phẩm, tạo một liên kết đến trang chi tiết sản phẩm “product.asp”. Mỗi khi người
mua muốn đưa sản phẩm vào giỏ hàng (“add item to Cart”) họ sẽ chuyển đến “addprod.asp”
Tập tin có tên là “product.asp”
Hiển thị sản phẩm trên trang web với các chi tiết:
<%
dim productid
productid=request.querystring("productid")
%>
<%
set rsprod=db.execute("SELECT * FROM products INNER JOIN categories ON
products.catcode = categories.catcode WHERE productid = " & productid)
'get names and codes of all products in that category
set rscatlist=db.execute("select name,productid from products where catcode=" &
rsprod("catcode") & " order by name")
%>
<%
if not rscatlist.eof then
rscatlist.movefirst
while not rscatlist.eof
%>
Bài tập Thực hành Thương mại điện tử
'>
<% rscatlist.movenext
wend
end if
%>
Price:
"><img src="anh/purchase.gif"
border=0>
Bài số 3
Tạo phần header và footer cho trang web
Quay trở lại bài 1, tạo trang “functions.inc” mô tả các chức năng cơ bản của trang web.
Tạo các subroutine (chương trình con) thực hiện chức năng header (tiêu đề trang) và footer
(chân trang)
Trang có tên “functions.inc” có dạng sau:
<%
sub header
%>
<table width="100%" cellpadding="2" cellspacing="0" border="0" bgcolor="<%= bgcolor
%>">
<img src="anh/logo.gif" alt="<%=
storename %> Home" border="0" vspace=5 hspace=5>
Bài tập Thực hành Thương mại điện tử
<%
end sub
sub footer
%>
<img
src="anh/powered.gif" alt="Powered by A-CART" border=0>
<%
end sub
%>
Chèn các câu lệnh gọi header và footer vào các trang web đã viết. Ví dụ:
Tạo trang “Category.asp” mới với các dòng như sau
<%
dim catcode
catcode=request.querystring("catcode")
%>
" topmargin="0" leftmargin="0" marginwidth="0"
marginheight="0" text="">
<%
header
if len(catcode)=0 then
dim rs
set rs=db.execute("select * from categories")
%>
PRODUCT CATEGORY
' style="text-
decoration:none;">
<%
rs.MoveNext%>
<%loop
rs.close
db.close
Bài tập Thực hành Thương mại điện tử
%>
<%else
set rscat=db.execute("select * from categories where catcode=" & catcode)
set rscatlist=db.execute("select name,productid from products where catcode=" & catcode & "
order by name")
%>
<% if not rscatlist.eof then
rscatlist.movefirst
while not rscatlist.eof
%>
<a href='product.asp?productid=<%=
rscatlist("productid")%>'>
<%
rscatlist.movenext
wend
end if
end if
footer
%>
Bài số 4
Tự tạo phần header và footer cho trang web của bạn
Bài tập Thực hành Thương mại điện tử
Bài tập thực hành số 5
+ Tổng số buổi thực hành là 1 buổi, mỗi buổi 2 tiết
+ Hình thức báo cáo sau các buổi thực hành: Sinh viên làm bài trên máy và nộp cho giáo
viên hướng dẫn ở buổi thứ 2, trong thư mục mang tên sinh viên
+ Nghiêm cấm mọi sao chép bài làm của nhau, nếu bị phát hiện sẽ được KHÔNG được thi
Bài số 1.
Ôn tập:
- Cài đặt webserver và kiểm tra IIS.
- Truyền dữ liệu từ form
- Truyền dữ liệu từ CSDL
- Tạo tập tin danh mục sản phẩm
- Tạo tập tin sản phẩm
Bài số 2.
Mỗi khi người mua muốn đưa sản phẩm vào giỏ hàng (“add item to Cart”) họ sẽ chuyển đến
“addprod.asp”
Tập tin “addprod.asp”
Thêm sản phẩm vào giỏ hàng:
<%
productid=request.querystring("productid")
stage=request.form("stage")
if stage="" or stage=null then
else
'thêm vào giỏ hàng
'khởi tạo giỏ hàng
If IsArray(Session("cart")) = false Then
Dim acart(19,1)
acart(1,0)=productid
acart(1,1)=request.form("qty")
Session("cart") = acart
else
acart=session("cart")
incart=false
for i=lbound(acart) to ubound(acart)
if acart(i,0)="" and acart(i,1)="" and not(incart) then
acart(i,0)=productid
acart(i,1)=request.form("qty")
incart=true
end if
next
session("cart")=acart
end if
end if
'lấy chi tiết sản phẩm
set rsprod=db.execute("SELECT * FROM products INNER JOIN categories ON
products.catcode = categories.catcode WHERE productid = " & productid)
Bài tập Thực hành Thương mại điện tử
'lấy tên và mã của tất cả sản phẩm trong loại catcode
set rscatlist=db.execute("select name,productid from products where catcode=" &
rsprod("catcode") & " order by name")
%>
" topmargin="0" leftmargin="0" marginwidth="0"
marginheight="0" text="" >
<%
'Hiển thị danh sách các sản phẩm trong loại
if not rscatlist.eof then
rscatlist.movefirst
while not rscatlist.eof
%>
<a href="product.asp?productid=<%=
rscatlist("productid")%>">
<%
rscatlist.movenext
wend
end if
%>
<%
if stage="" or stage=null then
%>
">
Price:
">
Bài tập Thực hành Thương mại điện tử
Bạn muốn mua bao nhiêu chiếc ?
" method="post">
Số lượng:
1
2
3
4
5
6
7
8
<%
else
%>
">
Price:
">
chiếc đã được thêm vào giỏ hàng của bạn. Nếu muốn mua thêm sản phẩm này <a
href="addprod.asp?productid=">hãy bấm vào đây.
Để tiếp tục mua sắm, hãy chọn danh mục phía trái hoặc phía trên.
Để đặt hàng hãy bấm vào đây.
Sản phẩm này KHÔNG được thêm vào giỏ của bạn.
Giỏ hàng của bạn đã đầy
Bài tập Thực hành Thương mại điện tử
">
Để xem hàng hóa trong giỏ hàng của bạn hãy bấm vào
đây.
Để đặt hàng hãy bấm vào đây.
<%
db.close
set db=nothing
%>
Bài số 3
Hãy tạo thêm cho giỏ hàng có tổng tiền
(tổng tiền = giá x số lượng).
Bài số 4
Hãy tạo thêm phím bấm “xóa giỏ hàng” cho giỏ hàng.
Nếu bấm phím “xóa giỏ hàng” thì giỏ hàng sẽ trở thành rổng
Hãy tạo thêm phím bấm “cập nhật giỏ hàng” cho trường hợp khách hàng thay đổi số lượng
hàng.
Bài tập Thực hành Thương mại điện tử
Bài tập thực hành số 6
+ Tổng số buổi thực hành là 1 buổi, mỗi buổi 2 tiết
+ Hình thức báo cáo sau các buổi thực hành: Sinh viên làm bài trên máy và nộp cho giáo
viên hướng dẫn ở buổi thứ 2, trong thư mục mang tên sinh viên
+ Nghiêm cấm mọi sao chép bài làm của nhau, nếu bị phát hiện sẽ được KHÔNG được thi
Bài số 1.
Ôn tập:
- Cài đặt webserver và kiểm tra IIS.
- Truyền dữ liệu từ form
- Truyền dữ liệu từ CSDL
- Tạo tập tin danh mục sản phẩm “category.asp”
- Tạo tập tin sản phẩm “product.asp”
- Thêm giỏ hàng “addprod.asp”
Bài số 2.
Mở rộng tiêu đề trang bằng cách thêm menu thanh ngang như sau:
Trong trường hợp giỏ hàng không rổng, trên thanh menu sẽ xuất hiện thông báo số lượng sản
phẩm “...items in shopping cart” và liên kết “My Cart” để xem nội dung giỏ hàng:
Khi bấm phím “My Cart” liên kết sẽ được chuyển đến trang “review.asp” hiển thị nội dung
giỏ hàng.
Cập nhật tập tin “functions.inc” :
<%
sub categorymenu
showcart=false
'lấy nội dung giỏ hàng nếu có
numitems=0
If IsArray(Session("cart")) = false Then
Dim acart(19,1)
Session("cart") = acart
showcart=false
else
acart=Session("cart")
for i=lbound(acart) to ubound(acart)
if acart(i,0)"" and acart(i,1)"" then
numitems=numitems+acart(i,1)
showcart=true
end if
next
end if
%>
<table width="100%" cellpadding="5" cellspacing="0" border="0" bgcolor="<%= bgcolor
%>">
Bài tập Thực hành Thương mại điện tử
" align="center" valign="MIDDLE" nowrap>
" face="Verdana, Arial" size="1">
sản phẩm trong giỏ hàng
" align="right" valign="MIDDLE" nowrap height="20">
" face="Verdana, Arial" size="1">
;text-
decoration:none;">Home |
;text-
decoration:none;">Support
| ;text-
decoration:none;">My Cart
<% end if
'Kiểm tra xem khách hàng đã đăng nhập chưa
if session("custid")"" then %>
| ;text-
decoration:none;">Sign Out
| ;text-
decoration:none;">Sign In
<table width="100%" cellpadding="0" cellspacing="0" border="0" bgcolor="<%= bgcolor
%>">
" height="20" align="center" valign="MIDDLE" nowrap
colspan="4">
" face="Verdana, Arial" size="1">
<% 'Hiển thị danh sách thể loại
dim rscat
set rscat=db.execute("select * from categories")
if not rscat.eof then
while not rscat.eof
%>
" style="color:<%=
textdark %>;text-decoration:none;">
<%
rscat.movenext
if not rscat.eof then
%>
|
<%
end if
wend
end if
Bài tập Thực hành Thương mại điện tử
%>
Cập nhật tập tin “category.asp” :
<%
dim catcode
catcode=request.querystring("catcode")
%>
" topmargin="0" leftmargin="0" marginwidth="0"
marginheight="0" text="">
<%
header
categorymenu
if len(catcode)=0 then
dim rs
set rs=db.execute("select * from categories")
%>
PRODUCT CATEGORY
' style="text-
decoration:none;">
<%
rs.MoveNext%>
<%loop
rs.close
db.close
%>
<%else
set rscat=db.execute("select * from categories where catcode=" & catcode)
set rscatlist=db.execute("select name,productid from products where catcode=" & catcode & "
order by name")
%>
<% if not rscatlist.eof then
Bài tập Thực hành Thương mại điện tử
rscatlist.movefirst
while not rscatlist.eof
%>
<a href='product.asp?productid=<%=
rscatlist("productid")%>'>
<%
rscatlist.movenext
wend
end if
end if
footer
%>
Bài số 3
Tương tự như trên cập nhật tập tin “product.asp” như sau:
<%
dim productid
productid=request.querystring("productid")
%>
<%
header
categorymenu
set rsprod=db.execute("SELECT * FROM products INNER JOIN categories ON
products.catcode = categories.catcode WHERE productid = " & productid)
'get names and codes of all products in that category
set rscatlist=db.execute("select name,productid from products where catcode=" &
rsprod("catcode") & " order by name")
%>
<%= rsprod("catname")
%>
<%
if not rscatlist.eof then
rscatlist.movefirst
while not rscatlist.eof
%>
Bài tập Thực hành Thương mại điện tử
<a href='product.asp?productid=<%=
rscatlist("productid")%>'>
<% rscatlist.movenext
wend
end if
%>
Price:
"><img
src="anh/purchase.gif" border=0>
Bài số 4
Tương tự như trên cập nhật tập tin “addprod.asp” như sau:
<%
productid=request.querystring("productid")
stage=request.form("stage")
if stage="" or stage=null then
else
'thêm vào giỏ hàng
'khởi tạo giỏ hàng
If IsArray(Session("cart")) = false Then
Dim acart(19,1)
acart(1,0)=productid
Bài tập Thực hành Thương mại điện tử
acart(1,1)=request.form("qty")
Session("cart") = acart
else
acart=session("cart")
incart=false
for i=lbound(acart) to ubound(acart)
if acart(i,0)="" and acart(i,1)="" and not(incart) then
acart(i,0)=productid
acart(i,1)=request.form("qty")
incart=true
end if
next
session("cart")=acart
end if
end if
'lấy chi tiết sản phẩm
set rsprod=db.execute("SELECT * FROM products INNER JOIN categories ON
products.catcode = categories.catcode WHERE productid = " & productid)
'lấy tên và mã của tất cả sản phẩm trong loại catcode
set rscatlist=db.execute("select name,productid from products where catcode=" &
rsprod("catcode") & " order by name")
%>
" topmargin="0" leftmargin="0" marginwidth="0"
marginheight="0" text="" >
<% header
categorymenu
%>
<%
'Hiển thị danh sách các sản phẩm trong loại
if not rscatlist.eof then
rscatlist.movefirst
while not rscatlist.eof
%>
<a href="product.asp?productid=<%=
rscatlist("productid")%>">
<%
rscatlist.movenext
wend
end if
%>
Bài tập Thực hành Thương mại điện tử
<%
if stage="" or stage=null then
%>
">
Price:
">
Bạn muốn mua bao nhiêu chiếc ?
" method="post">
Số lượng:
1
2
3
4
5
6
7
8
<%
else
%>
">
Price:
Bài tập Thực hành Thương mại điện tử
">
chiếc đã được thêm vào giỏ hàng của bạn. Nếu muốn mua thêm sản phẩm này <a
href="addprod.asp?productid=">hãy bấm vào đây.
Để tiếp tục mua sắm, hãy chọn danh mục phía trái hoặc phía trên.
Để đặt hàng hãy bấm vào đây.
Sản phẩm này KHÔNG được thêm vào giỏ của bạn.
Giỏ hàng của bạn đã đầy
">
Để xem hàng hóa trong giỏ hàng của bạn hãy bấm vào
đây.
Để đặt hàng hãy bấm vào đây.
<%
db.close
set db=nothing
%>
Bài số 5
Tạo tập tin “review.asp” để xem nội dung giỏ hàng như sau:
<%
'Kiểm tra giỏ hàng rổng ?
If IsArray(Session("cart")) = false Then
Dim acart(19,1)
Session("cart") = acart
else
acart=session("cart")
end if
cempty=true
for i=lbound(acart) to ubound(acart)
if acart(i,0)"" and acart(i,1)"" then
cempty=false
end if
Bài tập Thực hành Thương mại điện tử
next
%>
" topmargin="0" leftmargin="0" marginwidth="0"
marginheight="0" text="" >
<% header
categorymenu
%>
<%
'Thêm vào giỏ hàng
'Tạo giỏ hàng
If cempty Then
%>
empty cart
">
· Chú ý! giỏ hàng của bạn rổng!
<%
else
%>
Giỏ hàng của bạn
">
· Xem mặt hàng bằng cách bấm vào tên mặt hàng phía dưới.
· Xóa mặt hàng bằng cách bấm vào phím "delete item" ở phía trái.
· Tiếp tục mua hàng bằng cách chọn gian hàng phía trên.
Xóa
Mặt hàng
Số lượng
Đơn giá
Giá thành
<%
'Hiển thị nội dung giỏ hàng
acart=session("cart")
Bài tập Thực hành Thương mại điện tử
subtotal=0
for i=lbound(acart) to ubound(acart)
if acart(i,0)"" and acart(i,1)"" then
set rscart=db.execute("select name,productid,price from products where
productid=" & acart(i,0))
%>
<a href="alter.asp?item=<%=i
%>&action=delete">
"><%=
rscart("name") %>
<%= cursymbol &
formatnumber(rscart("price"))%>
<%= cursymbol &
formatnumber(rscart("price") * acart(i,1)) %>
<%
subtotal=subtotal+(rscart("price") * acart(i,1))
end if
next
%>
Tổng cộng: <%= cursymbol &
formatnumber(subtotal) %>
<%
db.close
set db=nothing
%>
Bài tập Thực hành Thương mại điện tử
Bài tập thực hành số 7
+ Tổng số buổi thực hành là 1 buổi, mỗi buổi 2 tiết
+ Hình thức báo cáo sau các buổi thực hành: Sinh viên làm bài trên máy và nộp cho giáo
viên hướng dẫn ở buổi thứ 2, trong thư mục mang tên sinh viên
+ Nghiêm cấm mọi sao chép bài làm của nhau, nếu bị phát hiện sẽ được KHÔNG được thi
Bài số 1.
Ôn tập:
- Cài đặt webserver và kiểm tra IIS.
- Truyền dữ liệu từ form
- Truyền dữ liệu từ CSDL
- Tạo tập tin danh mục sản phẩm “category.asp”
- Tạo tập tin sản phẩm “product.asp”
- Thêm giỏ hàng “addprod.asp”
- Hiển thị giỏ hàng “review.asp”
Bài số 2.
Xóa nội dung giỏ hàng và một mặt hàng trong giỏ hàng bằng cách dùng trang “alter.asp”
Có 3 trường hợp sử dụng trang “alter.asp”, như sau:
Khi xem giỏ hàng (trang “review.asp”; xem xong trở về “review.asp”), có thể
- Xóa một mặt hàng (ví dụ mặt hàng 2) “alter.asp?item=2&action=delete”
- Xóa hết giỏ hàng “alter.asp?action=clear”
Khi trả tiền (trang “payment.asp”; xem xong trở về “payment.asp”), có thể
- Xóa một mặt hàng (ví dụ mặt hàng 2)
“alter.asp?item=2&action=delete&redir=payment”
Do đó trang “alter.asp” có nội dung như sau:
<%
db.close
set db=nothing
if request.querystring("redir")="payment" then
redir="payment.asp"
else
redir="review.asp"
end if
item=request.querystring("item")
action=request.querystring("action")
if item19 then
response.redirect(redir)
end if
if action="delete" then
If IsArray(Session("cart")) = false Then
Dim acart(19,1)
Session("cart") = acart
else
acart=session("cart")
acart(item,0)=""
acart(item,1)=""
session("cart")=acart
Bài tập Thực hành Thương mại điện tử
end if
end if
if action="clear" then
Session("cart")=null
end if
response.redirect(redir)
%>
Bài số 3
Tạo tập tin “signin.asp” để đăng nhập mua hàng như sau:
<%
stage=request.querystring("stage")
' Kiểm tra xem khách hàng đã đăng nhập trước đó hay chưa (dùng biến session)
' nếu có thì bỏ qua bước đăng nhập
if session("custid")"" then
response.redirect("deliver.asp")
end if
%>
" topmargin="0" leftmargin="0" marginwidth="0"
marginheight="0" text="" alink="" link="<%= COLlight
%>" vlink="">
<%
header
categorymenu
%>
">
Đăng nhập mua hàng
">
· Để mua hàng, bạn phải đăng nhập.
· Bạn hãy ấn một trong các tùy chọn sau.
">
">
Bài tập Thực hành Thương mại điện tử
">
Bạn đã đăng ký từ trước.
Nếu bạn đã đăng ký tại từ trước, bạn hãy viết email và
mật khẩu của mình để đăng nhập mua hàng.
">
E-Mail:
">
">
Mật khẩu:
">
">
">
Bạn là khách hàng mới.
Nếu bạn chưa từng đăng ký trước đây, bạn hãy vào đây.
<%
db.close
set db=nothing
%>
Bài tập Thực hành Thương mại điện tử
Bài số 4
Tạo tập tin “verify.asp” để xử lý trang “signing.asp” như sau:
- Trường hợp đã đăng ký: action=signing
- Trường hợp chưa đăng ký: action=register
<%
email=valid_sql(request.form("email"))
pass=valid_sql(request.form("pass"))
action=request.form("action")
' Kiểm tra xem khách hàng đã đăng nhập trước đó hay chưa (dùng biến session)
' nếu có thì bỏ qua bước đăng nhập
if session("custid")"" and session("custid")null then
response.redirect("deliver.asp")
end if
if action="signin" then
set rsverify=db.execute("select * from customers where email='" & email & "'")
if rsverify.eof then
db.close
set db=nothing
response.redirect("signin.asp?msg=" & Server.URLEncode("Chúng tôi
không có email mà bạn đã nhập.Xin bạn xem lại thông tin đã nhập khi bạn đăng ký lần
đầu."))
end if
if lcase(trim(rsverify("pass")))lcase(trim(request.form("pass"))) then
db.close
set db=nothing
response.redirect("signin.asp?msg=" & Server.URLEncode("Bạn nhập
sai mật khẩu.Xin bạn nhập lại thêm lần nữa, hoặc đăng ký như là khách hàng mới."))
end if
set rsdate=db.execute("update customers set lastvisit=#" & date() & " " &
time() & "# where custid=" & rsverify("custid"))
session("custid")=rsverify("custid")
db.close
set db=nothing
response.redirect("deliver.asp")
else
response.redirect("register.asp")
end if
%>
Bài số 5
Tạo tập tin “register.asp” để đăng ký khách hàng mới như sau:
<%
stage=request.querystring("stage")
Bài tập Thực hành Thương mại điện tử
' Đây là chi tiết khách hàng...
cfname=request.form("cfname")
clname=request.form("clname")
caddress1=request.form("caddress1")
caddress2=request.form("caddress2")
ccity=request.form("ccity")
cstate=request.form("cstate")
czip=request.form("czip")
ccountry=request.form("ccountry")
cphone=request.form("cphone")
cfax=request.form("cfax")
cemail=request.form("cemail")
cpass1=request.form("cpass1")
cpass2=request.form("cpass2")
' Kiểm tra xem khách hàng đã đăng nhập trước đó hay chưa (dùng biến session)
' nếu có thì bỏ qua bước đăng nhập
if session("custid")"" then
response.redirect("deliver.asp")
end if
' Kiểm tra giỏ hàng
if stage="register" then
msg=""
if trim(cfname)="" then
msg=msg & "Bạn phải nhập đủ họ và tên."
end if
if trim(clname)="" then
msg=msg & "Bạn phải nhập đủ họ và tên."
end if
if trim(caddress1)="" then
msg=msg & "Bạn phải nhập địa chỉ."
end if
if trim(ccity)="" then
msg=msg & "Bạn phải nhập thành phố."
end if
if trim(cstate)="" then
msg=msg & "Bạn phải nhập tỉnh/khu vực."
end if
'if trim(czip)="" then
' msg=msg & "Bạn phải nhập mã vùng."
'end if
if trim(ccountry)="" then
msg=msg & "Bạn phải nhập tên nước."
end if
'if trim(cphone)="" then
' msg=msg & "Bạn phải nhập số điện thoại."
'end if
if trim(cpass1)="" or trim(cpass2)="" then
msg=msg & "Bạn phải nhập mật khẩu hai lần."
elseif trim(lcase(cpass1))trim(lcase(cpass2)) then
msg=msg & "Hai mật khẩu phải trùng nhau."
end if
Bài tập Thực hành Thương mại điện tử
if trim(cemail)="" then
msg=msg & "Bạn phải nhập địa chỉ email."
else
'Kiểm tra xem đã có trong CSDL không
set rsmail=db.execute("select * from customers where email='" &
valid_sql(cemail) & "'")
if not(rsmail.eof) then
msg= msg & "Địa chỉ email đã có người đăng ký"
end if
set rsmail=nothing
end if
if msg"" then
response.redirect("register.asp?msg=" & Server.URLEncode(msg))
end if
'Để thêm mới một khách hàng, thêm record rồi sau đó update
Set rscust = Server.CreateObject("ADODB.RecordSet")
' Mở bảng
rscust.Open "customers", strConn, adOpenKeySet, adLockPessimistic,
adCmdTable
' Thêm record mới
rscust.AddNew
rscust("fname") = cfname
rscust("lname") = clname
rscust("address1") = caddress1
rscust("address2") = caddress2
rscust("city") = ccity
rscust("state") = cstate
rscust("zip") = czip
rscust("country") = ccountry
rscust("phone") = cphone
if cfax"" then
rscust("fax") = cfax
end if
rscust("email") = cemail
rscust("pass") = cpass1
' Cập nhật record
rscust.update
' Ghi nhớ ID khách hàng
Session("custid") = rscust("custid")
' Đóng RecordSet
rscust.Close
Set rscust = Nothing
response.redirect("deliver.asp")
end if
%>
Bài tập Thực hành Thương mại điện tử
" topmargin="0" leftmargin="0" marginwidth="0"
marginheight="0" text="" alink="" link="<%= COLlight
%>" vlink="">
<%
header
categorymenu
%>
">
Đăng ký khách hàng
· Xin bạn nhập dữ liệu vào biểu mẫu sau:
">
">
<font face="helvetica"
size="1" color="">
Họ:
">
">
Tên:
">
">
email:
">
Bài tập Thực hành Thương mại điện tử
">
Địa chỉ 1:
">
">
Địa chỉ 2:
">
">
Thành phố:
">
">
Tỉnh/khu vực:
">
">
Mã vùng:
">
">
Quốc gia:
">
">
Điện thoại:
Bài tập Thực hành Thương mại điện tử
">
">
fax:
">
">
Mật khẩu:
">
">
Nhập lại mật khẩu:
">
<%
db.close
set db=nothing
%>
Bài số 6
Tạo tập tin “deliver.asp” để tạo nơi nhận hàng như sau:
<%
Bài tập Thực hành Thương mại điện tử
'Check if user is signed in
if session("custid")="" or session("custid")=null then
response.redirect("signin.asp")
end if
' Kiểm tra giỏ hàng
If IsArray(Session("cart")) = false Then
Dim acart(19,1)
Session("cart") = acart
response.redirect("error.asp?msg=" & Server.URLEncode("Giỏ hàng của bạn rổng."))
end if
acart=Session("cart")
' Chi tiết nơi nhận đã có trước
if not(session("fname")="" or session("lname")="" or session("address1")="" or
session("address2")="" or session("city")="" or session("state")="" or session("zip")="" or
session("country")="") then
response.redirect("payment.asp")
end if
' Chi tiết nơi nhận chưa đầy đủ
if session("fname")"" or session("lname")"" or session("address1")"" or
session("address2")"" or session("city")"" or session("state")"" or session("zip")""
or session("country")"" then
delivertome=""
delivertother="checked"
else
delivertome="checked"
delivertother=""
end if
%>
" topmargin="0" leftmargin="0" marginwidth="0"
marginheight="0" text="" alink="" link="<%= COLlight
%>" vlink="">
<%
header
categorymenu
%>
">
Thông tin nhận hàng
Bài tập Thực hành Thương mại điện tử
· Xin cho biết đơn hàng sẽ chuyển đến đâu.
">
">
>
Tôi muốn đơn hàng này chuyển đến địa chỉ của tôi.
>
Xin chuyển đơn hàng này đến người có địa chỉ dưới đây.
">
Họ:
">
" maxlength=40>
">
Tên:
">
" maxlength=40>
">
Địa chỉ 1:
">
" maxlength=80>
">
Địa chỉ 2:
">
" maxlength=80>
">
Thành phố:
">
" maxlength=28>
Bài tập Thực hành Thương mại điện tử
">
Tỉnh/khu vực:
">
" maxlength=28>
">
Mã vùng:
">
" maxlength=20>
">
Quốc gia:
">
" maxlength=20>
<%
db.close
set db=nothing
%>
Các file đính kèm theo tài liệu này:
- thuong_mai_dien_tu_9615.pdf