Với sự phát triển nhanh chóng của Internet và thương mại điện tử như hiện nay. Việc lựa ASP.NET được coi như là giải pháp hữu hiệu nhất. Với ASP.NET thiết kế Web giờ đây trở nên dễ dàng hơn bao giờ hết do được hỗ trợ nhiều thành phần phong phú, có khả năng vượt qua mọi trình duyệt, thiết bị mà ta không cần quan tâm đến việc định dạng các trang tài liệu cho mỗi trình duyệt, mỗi thiết bị, ASP.NET kết thúc những tranh luận về ngôn ngữ lập trình khi hỗ trợ trên 25 ngôn ngữ khác nhau.
Khi kết hợp với ADO+ với ASP.NET ta dễ dàng triển khai được các ứng dụng với mô hình N-tier, tạo ra được nguồn dữ liệu không kết nối từ nhiều nguồn dữ liệu khác nhau
Hơn nữa, ASP.NET mở ra nhiều cơ hội cho các nhà phát triển với các ứng dụng phân tán cung cấp dữ liệu cho khách hàng thông qua Internet cho phép họ tạo ra một dòng phần mềm mới với dữ liệu XML.
Em đã cố gắng khi xây dựng một ứng dụng với ASP.NET sử dụng cơ sở dữ liệu Oracle, kết hợp hai công cụ sức mạnh nhất trên Internet. Nhưng do thời gian tìm hiểu về hai công cụ này quá ít nên chưa phát huy được nhiều lợi ích do chúng đem lại.
Cuối cùng, em xin cảm ơn TS. Cao Kim Ánh là người trực tiếp hướng dẫn em hoàn thành đồ án này, anh Tuấn giám đốc Trung tâm và các anh, chị ở phòng nghiên cứu và phát triển Trung tâm CNTT – Ngân hàng công thương Việt Nam (ITC-ICB) đã khuyến khích và tạo điều kiện thuận lợi cho em hoàn thành đồ án đúng thời hạn.
108 trang |
Chia sẻ: oanh_nt | Lượt xem: 1290 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Đề tài Tìm hiểu Microsoft ASP.NET, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ng có quyền đưa các thông tin về mặt hàng của mình vào trong CSDL bất cứ lúc nào
3.2. Sơ đồ phân rã chức
Mục đích của sơ đồ phân rã chức năng:
+ Chỉ ra ràng buộc cần xây dựng, xác định các chức năng mà HT cần thực hiện.
+ Xác định rõ phạm vi của hệ thống trong phân tích hệ thống. Các chức năng được xác định ở đây sẽ được dùng nhiều trong mô hình sau này. Chỉ ra miền khảo cứu của hệ thống trong toàn bộ hệ thống tổ chức. Điều này có thể làm rõ trách nhiệm, giúp tránh được trùng lặp công việc.
người dùng
Quản trị
Tài khoản User
Thư liên hệ
Mặt hàng
Đăng nhập
Tìm kiếm
Post
xác nhận hợp lệ
Xem và sửa
Gửi thư
Cập nhật danh mục
login
đồng ý
login/Register
đồng ý
Kết quả tìm thấy
YC tìm/duyệt
Tạo thư
Lưu thư
Thêm mặt hàng
Yêu cầu xác nhận
Xem lại mặt hàng
Thông báo xác nhận
Thay đổi
Sửa đổi
Yêu cầu xác nhận
đồng ý
Cập nhật
Cập nhật
Quản lý danh mục
Xác nhận
Tìm thấy
Xác nhận đông ý
Yêu cầu
Tìm kiếm
Nhận thư
3.2.3. Mô hình logic
Mô hình logic cho ta thấy được quan hệ của các đối tượng dữ liệu trong cơ sở dữ liệu. Các quan hệ này có thể trực tiếp hay gián tiếp và không cần quan tâm đến dữ liệu được lưu trữ như thế nào.
CSDL này có 6 thực thể chính:
Categories (các danh mục hàng hoá lớn).
SubCategories (các danh mục hàng hoá phụ).
Products.
Users (người sử dụng).
Mailsent (thông tin về mail của người dùng).
Maildetails (thông tin chi tiết về mail liên quan đến sản phẩm).
Ngoài ra còn một số thực thể (admin, Post) không có quan hệ dùng để chứa một vài thông tin cho ngươì quản lý.
Mối quan hệ giữa các thực thể có thể tổng kết như sau:
Mỗi Category có thể có nhiều SubCategories.
Trong mỗi SubCategory lại có nhiều loại sản phẩm. Một người dùng có thể Post lên đó nhiều sản phẩm và gửi nhiều bức thư về các sản phẩm mà mình quan tâm, một sản phẩm có thể được nhiều người quan tâm và được gửi nhiều thư có liên quan đến thông tin trong sản phẩm đó.
3.2.4Mô hình Vật lý
Cơ sở dữ liệu vật lý trong Oracle bao gồm các tập tin dữ liệu, các tablespace, các rollback segment, các bảng, các cột và các index. Ta sẽ bắt đầu thiết kế với đơn vị nhỏ nhất của bộ nhớ vật lý là các cột.
Việc định nghĩa các thuộc tính cột là một bước quan trọng trong dự định về năng xuất. Từ thông tin này, kích thước tối đa của mỗi record có thể xác định. Điều này kết hợp với sự đánh giá tổng số hàng giúp xác định không gian cần lưu trữ.
Bảng Categories
Name
Datatype
Size
Scale
Nulls?
Default Value
CATEGORYID
NUMBER
10
0
No
CATEGORYNAME
VARCHAR2
50
0
No
Bảng SubCategories
Name
Datatype
Size
Scale
Nulls?
Default Value
SUBCATEGORYID
NUMBER
0
No
CATEGORYID
NUMBER
No
SUBCATEGORYNAME
VARCHAR2
0
0
No
Bảng Products
Name
Datatype
Size
Scale
Nulls?
Default Value
PRODUCTID
NUMBER
10
0
No
SUBCATEGORYID
NUMBER
10
0
No
USERID
NUMBER
10
0
No
PRODUCTMODEL
VARCHAR2
50
0
No
PRODUCTION
VARCHAR2
50
0
No
COUNTRY
VARCHAR2
20
0
Yes
PRICE
FLOAT
10
No
IMAGEURL
VARCHAR2
50
0
Yes
DESCRIPTION
VARCHAR2
100
0
Yes
QUALITY
NUMBER
10
0
Yes
AMOUNT
NUMBER
10
0
No
TOTALVIEW
NUMBER
10
0
No
DATECREATED
DATE
7
0
No
ISFORSALE
VARCHAR2
20
0
No
Bảng Mails
Name
Datatype
Size
Scale
Nulls?
Default Value
MAILITEMID
NUMBER
10
0
No
USERID
NUMBER
10
0
No
Bảng Maildetails
Name
Datatype
Size
Scale
Nulls?
Default Value
MAILITEMID
NUMBER
0
No
PRODUCTID
NUMBER
0
No
SUBJECT
VARCHAR2
0
No
RCPT
VARCHAR2
0
No
MBODY
VARCHAR2
0
No
DATESENT
DATE
7
0
No
Bảng Users:
Name
Datatype
Size
Scale
Nulls?
Default Value
USERID
NUMBER
10
0
No
USERNAME
VARCHAR2
50
0
No
TEL
VARCHAR2
50
0
No
ADDRESS
VARCHAR2
50
0
No
EMAIL
VARCHAR2
50
0
No
PASSWORD
VARCHAR2
10
0
No
3.2.5 Tạo các stored procedure cho ứng dụng
Để giảm đi nhiều tính toán cho Web server và tăng cường an ninh cho ứng dụng, các thao tác với CSDL được thực hiện qua các store procedured. Oracle gói các stored procedure trong các Package khiến công việc trở nên modul hoá, che dấu thông tin, dễ dàng được mở rộng khi thêm nhiều chức năng mà không bị ảnh hưởng đến chương trình cũ. Chúng ta sẽ dùng OleDb để gọi các stored procedure trong đây.
Create or replace package body PackCategory
AS
Procedure Getallcategory(c_cursor out cat_cursor)
as
begin
Open c_cursor for
select * From Categories;
End Getallcategory;
Procedure Getsubcategoriesbycat(icategoryid in number, c_cursor out cat_cursor)
as
begin
Open c_cursor for
Select c.subcategoryid,c.subcategoryName from subcategories c
where c.categoryid=icategoryid ;
End Getsubcategoriesbycat;
End PackCategory;
Create or replace package body PackMail
As
Procedure Getmaildetails(imailid in number, m_cursor OUT mailcursor)
As
Begin
Open m_cursor for
Select * from Maildetails where Mailitemid=imailid;
End Getmaildetails;
Procedure Getmailbyproduct(iProductid In Number, m_cursor Out mailcursor)
As
Begin
Open m_cursor for
Select * from Maildetails where ProductID=iProductid;
End GetmailbyProduct;
Procedure GetmailbyUser(iUserid In number, m_cursor Out mailcursor)
As
Begin
Open m_cursor for
Select m.mailitemid, m.Productid,m.subject,m.RCPT, m.mbody,m.Datesent
From maildetails m, Mailsent s Where
m.mailitemid=s.mailitemid and s.userid=iuserid;
End GetmailbyUser;
Procedure Getmailtype (imailtype In number, m_cursor out mailcursor)
As
Begin
Open m_cursor for
Select * from Emailtemplate;
End Getmailtype;
End Packmails;
Create or replace package body PackProduct
As
Procedure GetProductbycat(icategoryid in number,i_isforsale In varchar2,p_cursor out procursor)
As
begin
if i_isforsale='both' then
open p_cursor for
select p.productid,p.productmodel,p.imageurl,p.totalview,
p.price,p.isforsale,u.userid,u.USERNAME,p.subcategoryid from products p,users u
where p.subcategoryid in (select subcategoryid from subcategories where
categoryid=icategoryid) and p.userid=u.userid ;
else
if i_isforsale='sale' then
open p_cursor for
select p.productid,p.productmodel,p.imageurl,p.totalview,
p.price,p.isforsale,u.userid,u.USERNAME,p.subcategoryid from products p,users u
where p.subcategoryid in (select subcategoryid from subcategories where
categoryid=icategoryid) and p.userid=u.userid and p.isforsale='For sale only';
else
open p_cursor for
select p.productid,p.productmodel,p.imageurl,p.totalview,
p.price,p.isforsale,u.userid,u.USERNAME,p.subcategoryid from products p,users u
where p.subcategoryid in (select subcategoryid from subcategories where
categoryid=icategoryid) and p.userid=u.userid and p.Isforsale ='Wanted';
end if;
end if;
end GetProductbycat;
procedure GetProductbysubcat(isubcategoryid in Number, p_cursor out procursor)
As
begin
open p_cursor for
select p.productid,p.productmodel,p.production,p.imageurl,p.totalview,
p.price,p.isforsale,u.userid from products p,users u
where p.subcategoryid=isubcategoryid and p.userid=u.userid;
end GetProductbysubcat;
Procedure PostNewProduct(iSUBCATEGORYID IN NUMBER,iUSERID IN NUMBER,iPRODUCTMODEL IN VARCHAR2,
iPRODUCTION IN VARCHAR2, iCOUNTRY IN VARCHAR2,iPRICE IN FLOAT, iIMAGEURL IN VARCHAR2,
iDESCRIPTION IN VARCHAR2, iQUALITY IN NUMBER,iAMOUNT IN NUMBER,iTOTALVIEW IN NUMBER,
iDATECREATED IN DATE, iISFORSALE IN VARCHAR2)
IS
Begin
Insert into Post
values(
(post_seq.nextval),iSUBCATEGORYID,iUSERID,iPRODUCTMODEL,iPRODUCTION,iCOUNTRY,iPRICE,
iIMAGEURL,iDESCRIPTION, iQUALITY,iAMOUNT,iTOTALVIEW,iDATECREATED,iISFORSALE);
end PostNewProduct;
Procedure SearchProducts(search IN Varchar2,pageindex In number,pagesize in number,p_cursor Out procursor)
As
pagelow number;
pagehight number;
Cursor resultcursor is Select ProductID from products
Where ProductModel like '%search'
OR Production like '%search'
OR Description like '%search';
cnt Integer;
productlow integer;
producthight integer;
begin
cnt:=0;
pagelow:=pageindex * pagesize;
pagehight:=pagelow + pagesize + 1;
/* Ok, now paging */
For countrec In resultcursor Loop
if cnt = pagelow then
productlow:=countrec.Productid;
End if;
if cnt = pagehight then
producthight:=countrec.Productid;
cnt:=cnt+1;
End if;
End loop;
Open p_cursor for
Select P.ProductId,P.ProductModel,P.ImageUrl,P.Price,P.Totalview,U.UserName
From Products P,Users U
Where P.ProductModel like '%search'
OR P.Production like '%search'
OR P.Description like '%search'
and p.userid=u.userid and P.productid >=Productlow and P.productid <= producthight;
End SearchProducts;
Procedure GetProductDetails(i_ProductID In Number,p_cursor Out procursor)
As
Begin
Open p_cursor for
Select P.SUBCATEGORYID,P.USERID,P.PRODUCTMODEL,P.PRODUCTION,P.COUNTRY,P.PRICE,
P.IMAGEURL,P.DESCRIPTION,P.QUALITY,P.AMOUNT,P.TOTALVIEW,P.DATECREATED,P.ISFORSALE,
U.Userid From Products P,Users U Where
P.Productid=i_Productid and P.Userid=U.Userid;
End GetProductDetails;
Procedure AddPostProduct(Productid In Number)
As
Begin
Insert Into Products
select * From Post;
End AddPostProduct;
Procedure GetHotProduct (PrevWeek In Date, p_cursor OUT procursor)
As
Begin
Open p_cursor for
Select P.SUBCATEGORYID,P.USERID,P.PRODUCTMODEL,P.PRODUCTION,P.COUNTRY,P.PRICE,
P.IMAGEURL,P.DESCRIPTION,P.QUALITY,P.AMOUNT,P.TOTALVIEW,P.DATECREATED,P.ISFORSALE,
U.Userid From Products P,Users U Where
P.Userid=U.Userid and P.Datecreated >=PrevWeek;
End GetHotProduct;
Procedure Updateview (iProductid IN Number)
As
Begin
Update Products set totalview= totalview +1
Where ProductId =iProductid;
end Updateview;
End packproduct;
Create or replace package body PackUser
As
Procedure CheckEmail(iEmailadd in varchar2,U_cursor Out UserCursor)
As
Begin
Open U_cursor for
Select Email from Users where Email=iEmailadd;
End CheckEmail;
Procedure CheckLogin (iadmin In varchar2,iEmailadd In Varchar2,iPassword In varchar2, U_cursor Out UserCursor)
As
Begin
If iadmin ='%normal' then
Open U_cursor for
Select Userid,UserName,password from Users Where Email=iEmailadd
and Password=iPassword;
Else
Open U_cursor for
Select Name,Password from Admins where Name=iEmailadd and
password=ipassword;
End if;
End CheckLogin;
Procedure AddUser(USERNAME IN Varchar2,TEL IN Varchar2, ADDRESS IN Varchar2,
EMAIL IN Varchar2,PASSWORD In Varchar2)
As
Begin
Insert Into Users
Values(
(User_seq.Nextval), USERNAME, TEL,ADDRESS, EMAIL,PASSWORD);
End AddUser;
Procedure GetUserDetails(iuserid In Number, u_cursor out usercursor)
As
Begin
Open u_cursor for
Select UserName,Tel,Address,Email from users
where userid=iuserid;
End GetUserDetails;
end packUser;
3.3 Mô hình đa tầng của ứng dụng
ứng dụng mà ta sẽ cài đặt được triển khai theo mô hình đa tầng (multi-tier). Đây là mô hình mà các ứng dụng ngày nay đang hướng đến để thay thế cho mô hình client/server truyền thống.
.aspx file
ProductDB.vb
CustomerDB.vb
Email.vb
Oracle
User Service
Business Service
Data Service
Trong mô hình này các nghiệp vụ xử lý logic của ứng dụng được cài đặt thành những đối tượng riêng biệt.
Trong tầng dịch vụ người dùng chứa các trang .aspx để định dạng giao diện và triệu gọi đối tượng ở tầng nghiệp vụ. Các đối tượng ở tầng nghiệp vụ thực hiện chức năng chính của chương trình bao gồm mã lệnh tách rời phần định dạng HTML. Việc kết nối và truy xuất dữ liệu thực hiện ở tầng thứ 3. Các chức năng trong tầng xử lý nghiệp vụ có thể dễ dàng chuyển sang môi trường sử dụng khác như desktop, chúng ta có thể sử dụng lại chức năng này mà không cần thay đổi gì thêm.
Trong ứng dụng này gồm có 3 đối tượng chính ProductDb phục vụ việc xử lý các vấn đề có liên quan đến mặt hàng và các category, đối tượng Customers quản lý các chức năng có liên quan đến khách hàng, Email là đối tượng dùng để xử lý Email của khách hàng trong Web site.
Cài đặt:
Thư mục cài đặt
Cyber_market: thư mục gốc chứa các trang chính của ứng dụng.
Images: chứa ảnh giao diện của ứng dụng.
ImagePro : chứa ảnh của các mặt hàng.
3.3.1 Cài đặt đối tượng xử lý trong tầng logic nghiệp vụ.
Đối tượng ProductDb.vb
Imports System
Imports System.Configuration
Imports System.Data
Imports System.Data.OleDb
Namespace Cybermarket
' ProductsDB Class
'
' Business/Data Logic Class that encapsulates all data
' logic necessary to query products within
' the cybermaket Products database.
'
'*******************************************************
Public Class ProductsDB
'*******************************************************
'
' ProductsDB.GetProductCategories() Method
'
' The GetProductCategories method returns a DataReader that exposes all
' product categories (and their CategoryIDs)
' The OleDbDataReaderResult struct also returns the
' OleDb connection, which must be explicitly closed after the
' data from the DataReader is bound into the controls.
'
'*******************************************************
Public Function GetProductCategories() As OleDbDataReader
' Create Instance of Connection and Command Object
Dim cnOra As OleDbConnection = New OleDbConnection( _
"Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=scott;Password=tiger;Data Source=Test02;PLSQLRSet=1;Extended Properties=''")
Dim cmdCategories As New OleDbCommand _
("{call packcategory.getallcategory()}", cnOra)
cnOra.Open()
Dim result As OleDbDataReader
result = cmdCategories.ExecuteReader()
Return result
End Function
'*******************************************************
'
' ProductsDB.GetProductsbycat() Method
'
' The GetProducts method returns a struct containing a forward-only,
' read-only DataReader. This displays all products within a specified
' product category. The OleDbDataReaderResult struct also returns the
' OleDb connection, which must be explicitly closed after the
' data from the DataReader is bound into the controls.
'
' Other relevant sources:
'
'*******************************************************
Public Overloads Function GetProductsbyCat(ByVal categoryID As Integer, ByVal isforsale As String) As DataSet
' Create Instance of Connection and Command Object
Dim myConnection As OleDbConnection = New OleDbConnection("Provider=MSDAORA.1;Password=tiger;User ID=scott;Data Source=test02")
Dim myCommand As OleDbDataAdapter = New OleDbDataAdapter("{call PackProduct.GetProductbyCat(?,?)}", myConnection)
' Mark the Command as a SPROC
' myCommand.CommandType = CommandType.StoredProcedure
' Add Parameters to SPROC
Dim parameterCategoryID As OleDbParameter = New OleDbParameter("ICategoryID", OleDbType.Numeric, 10)
parameterCategoryID.Value = categoryID
myCommand.SelectCommand.Parameters.Add(parameterCategoryID)
Dim parameterisforsale As OleDbParameter = New OleDbParameter("i_isforsale", OleDbType.LongVarChar)
parameterisforsale.Value = isforsale
myCommand.SelectCommand.Parameters.Add(parameterisforsale)
' Execute the command
myConnection.Open()
Dim result As New DataSet()
myCommand.Fill(result, "Products")
Return result
myConnection.Close()
End Function
Public Overloads Function GetProductsbySubCat(ByVal subcategoryid As Integer, ByVal pageindex As Integer, ByVal pagesize As Integer) As OleDbDataReader
' Create Instance of Connection and Command Object
Dim myConnection As OleDbConnection = New OleDbConnection("Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=scott;Password=tiger;Data Source=Test02;PLSQLRSet=1;Extended Properties=''")
Dim myCommand As OleDbCommand = New OleDbCommand("{call PackProduct.GetProductbysubCat(?)}", myConnection)
Dim parameterCategoryID As OleDbParameter = New OleDbParameter("IsubCategoryID", OleDbType.Numeric, 10)
parameterCategoryID.Value = subcategoryid
myCommand.Parameters.Add(parameterCategoryID)
' Execute the command
myConnection.Open()
Dim result As OleDbDataReader
result = myCommand.ExecuteReader
Return result
myConnection.Close()
End Function
Public Function GetsubCategoryProducts(ByVal categoryID As Integer) As OleDbDataReader
' Create Instance of Connection and Command Object
Dim myConnection As OleDbConnection = New OleDbConnection("Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=scott;Password=tiger;Data Source=Test02;PLSQLRSet=1;Extended Properties=''")
Dim myCommand As OleDbCommand = New OleDbCommand("{call packcategory.Getsubcategoriesbycat(?)}", myConnection)
' Mark the Command as a SPROC
' myCommand.CommandType = CommandType.StoredProcedure
' Add Parameters to SPROC
Dim parameterCategoryID As OleDbParameter = New OleDbParameter("ICategoryID", OleDbType.Numeric, 10)
parameterCategoryID.Value = categoryID
myCommand.Parameters.Add(parameterCategoryID)
' Execute the command
myConnection.Open()
Dim result As OleDbDataReader
result = myCommand.ExecuteReader()
' Return the datareader result
Return result
myConnection.Close()
End Function
Public Function GetProductdetails(ByVal ProductID As Integer) As OleDbDataReader
' Create Instance of Connection and Command Object
Dim myConnection As OleDbConnection = New OleDbConnection("Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=scott;Password=tiger;Data Source=Test02;PLSQLRSet=1;Extended Properties=''")
Dim myCommand As OleDbCommand = New OleDbCommand("{call packproduct.Getproductdetails(?)}", myConnection)
' Mark the Command as a SPROC
' myCommand.CommandType = CommandType.StoredProcedure
' Add Parameters to SPROC
Dim parameterProductID As OleDbParameter = New OleDbParameter("i_ProductID", OleDbType.Numeric, 10)
parameterProductID.Value = ProductID
myCommand.Parameters.Add(parameterProductID)
' Execute the command
myConnection.Open()
Dim result As OleDbDataReader
result = myCommand.ExecuteReader()
' Return the datareader result
Return result
myConnection.Close()
End Function
Public Sub Postproduct(ByVal SUBCATEGORYID As Integer, ByVal USERID As Integer, _
ByVal PRODUCTMODEL As String, ByVal PRODUCTION As String, ByVal COUNTRY As String, ByVal PRICE As Double, ByVal QUALITY As Integer, ByVal AMOUNT As Integer, _
ByVal IMAGEURL As String, ByVal ISFORSALE As String, ByVal DESCRIPTION As String, ByVal TOTALVIEW As Integer, ByVal DATECREATED As Date)
' Create Instance of Connection and Command Object
Dim myConnection As OleDbConnection = New OleDbConnection( _
"Provider=MSDAORA;Password=tiger;User ID=scott;Data Source=Test02")
Dim myCommand As OleDbCommand = New OleDbCommand("{call packproduct.PostNewProduct(?,?,?,?,?,?,?,?,?,?,?,?,?)}", myConnection)
' Mark the Command as a SPROC
' myCommand.CommandType = CommandType.StoredProcedure
' Add Parameters to SPROC
Dim parameterSUBCATEGORYID As OleDbParameter = New OleDbParameter("iSUBCATEGORYID", OleDbType.Numeric, ParameterDirection.Input)
parameterSUBCATEGORYID.Value = SUBCATEGORYID
myCommand.Parameters.Add(parameterSUBCATEGORYID)
Dim parameterUSERID As OleDbParameter = New OleDbParameter("iUSERID", OleDbType.Numeric, ParameterDirection.Input)
parameterUSERID.Value = USERID
myCommand.Parameters.Add(parameterUSERID)
Dim parameterProductModel As OleDbParameter = New OleDbParameter("iProductModel", OleDbType.LongVarChar, ParameterDirection.Input)
parameterProductModel.Value = PRODUCTMODEL
myCommand.Parameters.Add(parameterProductModel)
Dim parameterProduction As OleDbParameter = New OleDbParameter("iProduction", OleDbType.LongVarChar, ParameterDirection.Input)
parameterProduction.Value = PRODUCTION
myCommand.Parameters.Add(parameterProduction)
Dim parameterCountry As OleDbParameter = New OleDbParameter("iCountry", OleDbType.LongVarChar, ParameterDirection.Input)
parameterCountry.Value = COUNTRY
myCommand.Parameters.Add(parameterCountry)
Dim parameterPrice As OleDbParameter = New OleDbParameter("iPrice", OleDbType.Double, ParameterDirection.Input)
parameterPrice.Value = PRICE
myCommand.Parameters.Add(parameterPrice)
Dim parameterProductIMAGEURL As OleDbParameter = New OleDbParameter("iIMAGEURL", OleDbType.LongVarChar, ParameterDirection.Input)
parameterProductIMAGEURL.Value = IMAGEURL
myCommand.Parameters.Add(parameterProductIMAGEURL)
Dim parameterProductDescription As OleDbParameter = New OleDbParameter("Description", OleDbType.LongVarChar, ParameterDirection.Input)
parameterProductDescription.Value = DESCRIPTION
myCommand.Parameters.Add(parameterProductDescription)
Dim parameterQuality As OleDbParameter = New OleDbParameter("iQuality", OleDbType.Numeric, ParameterDirection.Input)
parameterQuality.Value = QUALITY
myCommand.Parameters.Add(parameterQuality)
Dim parameterAmount As OleDbParameter = New OleDbParameter("iAmount", OleDbType.Numeric, ParameterDirection.Input)
parameterAmount.Value = AMOUNT
myCommand.Parameters.Add(parameterAmount)
Dim parameterTotalview As OleDbParameter = New OleDbParameter("iTotalview", OleDbType.Numeric, ParameterDirection.Input)
parameterTotalview.Value = TOTALVIEW
Dim parameterDate As OleDbParameter = New OleDbParameter("iDate", OleDbType.Date, ParameterDirection.Input)
parameterDate.Value = DATECREATED
myCommand.Parameters.Add(parameterDate)
myCommand.Parameters.Add(parameterTotalview)
Dim parameterIsforsale As OleDbParameter = New OleDbParameter("iIsforsale", OleDbType.LongVarChar, ParameterDirection.Input)
parameterIsforsale.Value = ISFORSALE
myCommand.Parameters.Add(parameterIsforsale)
' Execute the command
myConnection.Open()
myCommand.ExecuteNonQuery()
myConnection.Close()
End Sub
Public Sub AddNewCategory(ByVal CategoryName As String)
Dim myConnection As OleDbConnection = New OleDbConnection("Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=scott;Password=tiger;Data Source=Test02;PLSQLRSet=1;Extended Properties=''")
Dim myCommand As OleDbCommand = New OleDbCommand("{call packcategory.AddCat(?)}", myConnection)
Dim parameterCategoryName As OleDbParameter = New OleDbParameter("CategoryName", OleDbType.LongVarChar, ParameterDirection.Input)
parameterCategoryName.Value = CategoryName
myCommand.Parameters.Add(parameterCategoryName)
myConnection.Open()
myCommand.ExecuteNonQuery()
myConnection.Close()
End Sub
Public Sub Updateview(ByVal Productid As Integer)
Dim myConnection As OleDbConnection = New OleDbConnection("Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=scott;Password=tiger;Data Source=Test02;PLSQLRSet=1;Extended Properties=''")
Dim myCommand As OleDbCommand = New OleDbCommand("{call PackProduct.UpdateView(?)}", myConnection)
Dim parameterView As OleDbParameter = New OleDbParameter("CategoryName", OleDbType.LongVarChar, ParameterDirection.Input)
parameterView.Value = Productid
myCommand.Parameters.Add(parameterView)
myConnection.Open()
myCommand.ExecuteNonQuery()
myConnection.Close()
End Sub
End Class
End Namespace
Các phương thức có trong đối tượng này là lấy các thông tin về category, subcategory, lấy thông tin về mặt hàng theo category và subcategory, thông tin chi tiết về mặt hàng, thêm vào thuộc tính của mặt hàng số lượt người xem.
Đối tương Customers
Imports System
Imports System.Web
Imports System.Data
Imports System.Data.OleDb
Namespace Cybermarket
Public Class Customers
Public Sub AddUser(ByVal Username As String, ByVal Tel As String, ByVal address As String, ByVal emailadd As String, ByVal password As String)
Dim myConnection As OleDbConnection = New OleDbConnection("Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=scott;Password=tiger;Data Source=test02;PLSQLRSet=1;Extended Properties=''")
Dim myCommand As OleDbCommand = New OleDbCommand("{call PackUser.AddUser(?,?,?,?,?)}", myConnection)
Dim parameterUserName As OleDbParameter = New OleDbParameter("UserName", OleDbType.LongVarChar, ParameterDirection.Input)
parameterUserName.Value = Username
myCommand.Parameters.Add(parameterUserName)
Dim parameterUserTel As OleDbParameter = New OleDbParameter("Tel", OleDbType.LongVarChar, ParameterDirection.Input)
parameterUserTel.Value = Tel
myCommand.Parameters.Add(parameterUserTel)
Dim parameterUseraddress As OleDbParameter = New OleDbParameter("Address", OleDbType.LongVarChar, ParameterDirection.Input)
parameterUseraddress.Value = address
myCommand.Parameters.Add(parameterUseraddress)
Dim parameterEmailaddress As OleDbParameter = New OleDbParameter("Email", OleDbType.LongVarChar, ParameterDirection.Input)
parameterEmailaddress.Value = emailadd
myCommand.Parameters.Add(parameterEmailaddress)
Dim parameterpassword As OleDbParameter = New OleDbParameter("Password", OleDbType.LongVarChar, ParameterDirection.Input)
parameterpassword.Value = password
myCommand.Parameters.Add(parameterpassword)
myConnection.Open()
myCommand.ExecuteNonQuery()
myConnection.Close()
End Sub
Public Function CheckLogin(ByVal emailadd As String, ByVal password As String) As OleDbDataReader
Dim myConnection As OleDbConnection = New OleDbConnection("Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=scott;Password=tiger;Data Source=test02;PLSQLRSet=1;Extended Properties=''")
Dim myCommand As OleDbCommand = New OleDbCommand("{call PackUser.CheckLogin(?,?)}", myConnection)
Dim parameterEmailaddress As OleDbParameter = New OleDbParameter("iEmailadd", OleDbType.LongVarChar, ParameterDirection.Input)
parameterEmailaddress.Value = emailadd
myCommand.Parameters.Add(parameterEmailaddress)
Dim parameterpassword As OleDbParameter = New OleDbParameter("iPassword", OleDbType.LongVarChar, ParameterDirection.Input)
parameterpassword.Value = password
myCommand.Parameters.Add(parameterpassword)
myConnection.Open()
Dim result As OleDbDataReader
result = myCommand.ExecuteReader()
Return result
myConnection.Close()
End Function
Public Function checkEmail(ByVal emailadd As String) As Boolean
Dim myConnection As OleDbConnection = New OleDbConnection("Provider=MSDAORA.1;Password=tiger;User ID=scott;Data Source=test02")
Dim myCommand As OleDbCommand = New OleDbCommand("{call PACKUSER.CHECKEMAIL(?)}", myConnection)
Dim parameterEmailaddress As OleDbParameter = New OleDbParameter("IEmailadd", OleDbType.VarChar, 50, ParameterDirection.Input)
parameterEmailaddress.Value = emailadd
myCommand.Parameters.Add(parameterEmailaddress)
myConnection.Open()
Dim result As OleDbDataReader
result = myCommand.ExecuteReader()
If result.Read Then
Return True
Else
Return False
End If
myConnection.Close()
End Function
Public Function GetUserdetails(ByVal UserID As Integer) As OleDbDataReader
' Create Instance of Connection and Command Object
Dim myConnection As OleDbConnection = New OleDbConnection("Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=scott;Password=tiger;Data Source=Test02;PLSQLRSet=1;Extended Properties=''")
Dim myCommand As OleDbCommand = New OleDbCommand("{call packuser.GetUserDetails(?)}", myConnection)
' Mark the Command as a SPROC
' myCommand.CommandType = CommandType.StoredProcedure
' Add Parameters to SPROC
Dim parameterUser As OleDbParameter = New OleDbParameter("iuserid", OleDbType.Numeric, 10)
parameterUser.Value = UserID
myCommand.Parameters.Add(parameterUser)
' Execute the command
myConnection.Open()
Dim result As OleDbDataReader
result = myCommand.ExecuteReader()
' Return the datareader result
Return result
myConnection.Close()
End Function
End Class
End Namespace
Đối tượng này cung cấp các phương thức để kiểm tra quá trình đăng nhập của người dùng, kiểm ta tính hợp lệ của địa chỉ Email khi đăng ký mới, thêm một khách hàng vào cơ sở dữ liệu và lấy thông tin chi tiết về khách hàng đó.
Đối tượng Email
Imports System.Web.Mail
Imports System
Imports System.Data
Imports System.Data.OleDb
Namespace Cybermarket
Public Class Email
Public Function Getmailtemplate(ByVal mailtype As Integer) As OleDbDataReader
' Create Instance of Connection and Command Object
Dim myConnection As OleDbConnection = New OleDbConnection("Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=scott;Password=tiger;Data Source=Test02;PLSQLRSet=1;Extended Properties=''")
Dim myCommand As OleDbCommand = New OleDbCommand("{call packmails.Getmailtype(?)}", myConnection)
' Mark the Command as a SPROC
' myCommand.CommandType = CommandType.StoredProcedure
' Add Parameters to SPROC
Dim parametermailtype As OleDbParameter = New OleDbParameter("imailtype", OleDbType.Numeric, 10)
parametermailtype.Value = mailtype
myCommand.Parameters.Add(parametermailtype)
' Execute the command
myConnection.Open()
Dim result As OleDbDataReader
result = myCommand.ExecuteReader()
' Return the datareader result
Return result
myConnection.Close()
End Function
Public Function sent(ByVal from As String, ByVal sender As String, ByVal mailto As String, ByVal RCPT As String, ByVal subject As String, ByVal Body As String) As Boolean
Dim msg As New MailMessage()
msg.From = from
msg.Subject = subject 'Formatmail(result("subject"), mailto, productmodel)
msg.Body = Body 'Formatmail(result("body"), mailto, productmodel)
msg.To = RCPT
SmtpMail.SmtpServer = "localhost"
Try
SmtpMail.Send(msg)
Catch
Return False
End Try
Return True
End Function
Public Function Formatmail(ByVal msgtoformat As String, ByVal Username As String, ByVal Productmodel As String) As String
msgtoformat = msgtoformat.Replace("", Username)
msgtoformat = msgtoformat.Replace("", Productmodel)
Return msgtoformat.ToString
End Function
Public Sub Addmail(ByVal productid As String, ByVal sender As String, ByVal RCPT As String, ByVal subject As String, ByVal body As String)
Dim myConnection As OleDbConnection = New OleDbConnection("Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=scott;Password=tiger;Data Source=test02;PLSQLRSet=1;Extended Properties=''")
Dim myCommand As OleDbCommand = New OleDbCommand("{call Packmails.Addmail(?,?,?,?,?)}", myConnection)
Dim parameterproduct As OleDbParameter = New OleDbParameter("iproduct", OleDbType.Numeric, ParameterDirection.Input)
parameterproduct.Value = productid
myCommand.Parameters.Add(parameterproduct)
Dim parametersender As OleDbParameter = New OleDbParameter("isender", OleDbType.LongVarChar, ParameterDirection.Input)
parametersender.Value = sender
myCommand.Parameters.Add(parametersender)
Dim parameterRCPT As OleDbParameter = New OleDbParameter("iRCPT", OleDbType.LongVarChar, ParameterDirection.Input)
parameterRCPT.Value = sender
myCommand.Parameters.Add(parameterRCPT)
Dim parametersubject As OleDbParameter = New OleDbParameter("isubject", OleDbType.LongVarChar, ParameterDirection.Input)
parametersubject.Value = subject
myCommand.Parameters.Add(parametersubject)
Dim parameterbody As OleDbParameter = New OleDbParameter("ibody", OleDbType.LongVarChar, ParameterDirection.Input)
parameterbody.Value = body
myCommand.Parameters.Add(parameterbody)
myConnection.Open()
myCommand.ExecuteNonQuery()
myConnection.Close()
End Sub
Public Function Getmailbyproduct(ByVal productid As Integer) As OleDbDataReader
' Create Instance of Connection and Command Object
Dim myConnection As OleDbConnection = New OleDbConnection("Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=scott;Password=tiger;Data Source=Test02;PLSQLRSet=1;Extended Properties=''")
Dim myCommand As OleDbCommand = New OleDbCommand("{call packmail.getmailbyproduct(?)}", myConnection)
' Mark the Command as a SPROC
' myCommand.CommandType = CommandType.StoredProcedure
' Add Parameters to SPROC
Dim parameterProduct As OleDbParameter = New OleDbParameter("iuserid", OleDbType.Numeric, 10)
parameterProduct.Value = productid
myCommand.Parameters.Add(parameterProduct)
' Execute the command
myConnection.Open()
Dim result As OleDbDataReader
result = myCommand.ExecuteReader()
' Return the datareader result
Return result
myConnection.Close()
End Function
Public Function Getmailbycustomer(ByVal Userid As Integer) As OleDbDataReader
' Create Instance of Connection and Command Object
Dim myConnection As OleDbConnection = New OleDbConnection("Provider=OraOLEDB.Oracle.1;Persist Security Info=False;User ID=scott;Password=tiger;Data Source=Test02;PLSQLRSet=1;Extended Properties=''")
Dim myCommand As OleDbCommand = New OleDbCommand("{call Packmail.Getmailbyuser(?)}", myConnection)
' Mark the Command as a SPROC
' myCommand.CommandType = CommandType.StoredProcedure
' Add Parameters to SPROC
Dim parameterUser As OleDbParameter = New OleDbParameter("iuserid", OleDbType.Numeric, 10)
parameterUser.Value = Userid
myCommand.Parameters.Add(parameterUser)
' Execute the command
myConnection.Open()
Dim result As OleDbDataReader
result = myCommand.ExecuteReader()
' Return the datareader result
Return result
myConnection.Close()
End Function
End Class
End Namespace
Cung cấp các phương thức dùng để thêm mới một email khi có một khách hàng sử dụng chức năng gửi thư trong Web site, lấy các email theo sản phẩm hay theo id của khách hàng đó. Trong đối tượng này còn có phương thức để định dạng lại bức thư theo từng chủ để có trong bảng Emailtemplate của CSDL và phương thức để gửi đi một bức thư.
Các đối tượng khác
Đối tượng cmenu
Trong ứng dụng có sử dụng một menu để tạo giao diện khi lựa chọn các category việc xây dựng menu này để có thể đọc dữ liệu từ nguồn dữ liệu XML tương đối phức tạp và dài dòng nên không được trình bày ở đây. cmenu là đối tượng đã được biên dịch và đặt trong thư mục /BIN của ứng dụng.
Đối tượng menuDb
Imports System
Imports System.Text
Imports System.Configuration
Imports System.Data
Imports System.Data.OleDb
Imports Cyber_market.Cybermarket
Namespace Cybermarket
Public Class MenuDb
Public Function CreatMenu() As StringBuilder
Dim ProductCategory As ProductsDB = New Cybermarket.ProductsDB()
Dim Categories As OleDbDataReader
Categories = ProductCategory.GetProductCategories()
Dim strXml As StringBuilder = New StringBuilder()
strXml.Append(" ")
strXml.Append("")
strXml.Append("")
'Dim i As string=0
Dim PRoductCatelo As Cybermarket.ProductsDB = New Cybermarket.ProductsDB()
Dim ProductList As OleDbDataReader
'Dim categoryId As Integer
While Categories.Read()
strXml.Append("")
strXml.Append("")
ProductList = PRoductCatelo.GetsubCategoryProducts(Categories("CategoryID"))
While ProductList.Read()
strXml.Append("")
End While
strXml.Append("")
strXml.Append("")
End While
strXml.Append("")
strXml.Append("")
Return strXml
End Function
End Class
End Namespace
Phương thức createmenu trong đối tượng này chỉ để tạo một chuỗi dữ liệu XML để định dạng menu cho đối tượng cmenu.
Đối tượng uploadpro là đối tương thêm vào để thực hiện việc upload file ảnh lên server.
3.3.2 Cài đặt trang ASP.NET
Một số trang chính trong ứng dụng
Trang default
Gồm có phần tiêu đề của trang là một web user control “_header.ascx” được dưa vào trang bằng chỉ thị , phần menu hiển thị danh mục mặt hàng cũng là một User control. Phần định dạng này xuyên suốt trong toàn bộ Web site
Default
<td style="HEIGHT: 324px" vAlign=top width=120 colSpan=1 height=324
>
<td vAlign=top align=middle width=335 height=336 rowSpan=2
style="HEIGHT: 336px">
<DIV style="DISPLAY: inline; WIDTH: 325px; HEIGHT: 55px"
ms_positioning="FlowLayout">This is hottest
Products in Week
<td vAlign=top align=middle width=120 colSpan=1 height=12
style="HEIGHT: 12px">
Type something
<img
height=19 src="file:///C:/CTK_CU~1.GIF" width=10 border=0
><img style="HEIGHT: 19px" height=19
width=470 border=0
>
Mã ẩn trong trang default thực hiện việc request cookies để kiểm tra xem người dùng đó có save lại thông tin của họ trên trình khách không.
Trang login
Imports System
Imports System.Data
Imports System.Data.OleDb
Imports System.Web.Security
Public Class Login
Inherits System.Web.UI.Page
Protected WithEvents CheckBox1 As System.Web.UI.WebControls.CheckBox
Protected WithEvents TextBox1 As System.Web.UI.WebControls.TextBox
Protected WithEvents TextBox2 As System.Web.UI.WebControls.TextBox
Protected WithEvents Button1 As System.Web.UI.WebControls.Button
Protected WithEvents Label2 As System.Web.UI.WebControls.Label
Protected WithEvents TextBox3 As System.Web.UI.WebControls.TextBox
#Region " Web Form Designer Generated Code "
'This call is required by the Web Form Designer.
Private Sub InitializeComponent()
End Sub
Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init
'CODEGEN: This method call is required by the Web Form Designer
'Do not modify it using the code editor.
InitializeComponent()
End Sub
#End Region
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
'Put user code to initialize the page here
End Sub
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
Dim Customer As Cybermarket.Customers = New Cybermarket.Customers()
Dim drcustomer As OleDbDataReader
drcustomer = Customer.CheckLogin(TextBox1.Text, TextBox2.Text)
If Not drcustomer.Read Then
Label2.Text = "Invalid Password"
Else
Label2.Text = "Login successful!"
' Store the user's fullname in a cookie for personalization purposes
Response.Cookies("Cybermarket_customerid").Value = drcustomer("UserId").ToString()
Response.Cookies("Cybermarket_fullname").Value = drcustomer("UserName").ToString()
' Make the cookie persistent only if the user selects "persistent" login checkbox
If CheckBox1.Checked = True Then
Response.Cookies("Cybermarket_customerid").Expires = DateTime.Now.AddMonths(1)
Response.Cookies("Cybermarket_fullname").Expires = DateTime.Now.AddMonths(1)
End If
End If
End Sub
End Class
Kiểm tra và ghi lại thông tin của người dùng trong mỗi lần đăng nhập
Nội dung trang Productlist.aspx
Trang này được goi từ trang default.aspx qua các link trong menu. Trang này được gọi với một hoặc hai giá trị gán vào điạ chỉ URL, các giá trị này là category và subcategory. Ta sẽ lấy các thông tin này để hiển thị mặt hàng theo chủng loại.
Imports System
Imports System.Data
Imports System.Data.OleDb
Public Class ProductsList
Inherits System.Web.UI.Page
Protected WithEvents LinkButton1 As System.Web.UI.WebControls.LinkButton
Protected WithEvents LinkButton2 As System.Web.UI.WebControls.LinkButton
Protected WithEvents LinkButton3 As System.Web.UI.WebControls.LinkButton
Protected WithEvents LinkButton4 As System.Web.UI.WebControls.LinkButton
Protected WithEvents LinkButton5 As System.Web.UI.WebControls.LinkButton
Protected WithEvents TextBox1 As System.Web.UI.WebControls.TextBox
Protected WithEvents Button1 As System.Web.UI.WebControls.Button
Protected WithEvents Label2 As System.Web.UI.WebControls.Label
Protected WithEvents MyList As System.Web.UI.WebControls.DataList
Protected WithEvents Label1 As System.Web.UI.WebControls.Label
Dim PageDS As PagedDataSource
Dim seltab As String
Dim i As Integer
#Region " Web Form Designer Generated Code "
'This call is required by the Web Form Designer.
Private Sub InitializeComponent()
End Sub
Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init
'CODEGEN: This method call is required by the Web Form Designer
'Do not modify it using the code editor.
InitializeComponent()
End Sub
#End Region
Private Sub pagestart(ByVal pageindex As Integer)
' i = CInt(Label1.Text)
Dim ds As DataSet
PageDS = New PagedDataSource()
Dim dv As DataView
If Request.Params("subCategoryId") Is Nothing Then
seltab = Label2.Text
Dim categoryId As Integer = CInt(Request.Params("CategoryID"))
Dim productCatalogue As Cybermarket.ProductsDB = New Cybermarket.ProductsDB()
If seltab = "For sale only" Then
ds = productCatalogue.GetProductsbyCat(categoryId, "sale")
Else
If seltab = "Wanted" Then
ds = productCatalogue.GetProductsbyCat(categoryId, "wanted")
Else
'Get Products by Categories
ds = productCatalogue.GetProductsbyCat(categoryId, "both")
End If
End If
dv = ds.Tables("Products").DefaultView
PageDS.DataSource = dv
PageDS.AllowPaging = True
PageDS.PageSize = 2
PageDS.CurrentPageIndex = pageindex
MyList.DataSource = PageDS
MyList.DataBind()
Else
Dim subcategoryId As Integer = CInt(Request.Params("SubCategoryID"))
'Get Products by subCategories
Dim productsubCatalogue As Cybermarket.ProductsDB = New Cybermarket.ProductsDB()
'ds = productsubCatalogue.GetProductsbySubCat(subcategoryId, i, 2)
'MyList.DataSource = ds
'MyList.DataBind()
End If
End Sub
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
'Put user code to initialize the page here
If Not Page.IsPostBack Then
pagestart(0)
End If
End Sub
Private Sub LinkButton1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles LinkButton1.Click
Label2.Text = "For sale only"
Label1.Text = 0
pagestart(0)
End Sub
Private Sub LinkButton3_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles LinkButton3.Click
Label2.Text = "Both"
pagestart(0)
End Sub
Private Sub LinkButton2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles LinkButton2.Click
Label2.Text = "Wanted"
pagestart(0)
End Sub
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
Response.Redirect("search.aspx?query=" & TextBox1.Text)
End Sub
Private Sub LinkButton4_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles LinkButton4.Click
Label1.Text = CInt(Label1.Text) + 1
pagestart(CInt(Label1.Text))
End Sub
Private Sub LinkButton5_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles LinkButton5.Click
Label1.Text = CInt(Label1.Text) - 1
pagestart(CInt(Label1.Text))
End Sub
Private Sub MyList_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs)
End Sub
Private Sub DataGrid1_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs)
End Sub
End Class
Trang ProductList
Trang này được yêu cầu khi người dùng chọn ảnh của mặt hàng trong ProductList thông tin về mặt hàng được lấy từ URL khi gọi trang với id của mặt hàng
Imports System
Imports System.Data
Imports System.Data.OleDb
Public Class Productdetails
Inherits System.Web.UI.Page
Protected WithEvents Image1 As System.Web.UI.WebControls.Image
Protected WithEvents Label1 As System.Web.UI.WebControls.Label
Protected WithEvents Label2 As System.Web.UI.WebControls.Label
Protected WithEvents Label3 As System.Web.UI.WebControls.Label
Protected WithEvents Label4 As System.Web.UI.WebControls.Label
Protected WithEvents Label5 As System.Web.UI.WebControls.Label
Protected WithEvents Label6 As System.Web.UI.WebControls.Label
Protected WithEvents Label7 As System.Web.UI.WebControls.Label
Protected WithEvents Label8 As System.Web.UI.WebControls.Label
Protected WithEvents HyperLink1 As System.Web.UI.WebControls.HyperLink
Protected WithEvents Label10 As System.Web.UI.WebControls.Label
Protected WithEvents Label9 As System.Web.UI.WebControls.Label
#Region " Web Form Designer Generated Code "
'This call is required by the Web Form Designer.
Private Sub InitializeComponent()
End Sub
Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init
'CODEGEN: This method call is required by the Web Form Designer
'Do not modify it using the code editor.
InitializeComponent()
End Sub
#End Region
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
'Put user code to initialize the page here
Dim ProductId As Integer = CInt(Request.Params("ProductID"))
Dim productdetail As Cybermarket.ProductsDB = New Cybermarket.ProductsDB()
Dim dr As OleDbDataReader
dr = productdetail.GetProductdetails(ProductId)
dr.Read()
Label1.Text += dr("ProductModel").ToString()
Label2.Text += dr("Production").ToString()
Label3.Text += dr("Country").ToString()
Label4.Text += dr("Price").ToString()
Label5.Text += dr("quality").ToString
Label6.Text += dr("amount").ToString()
Label7.Text += dr("totalview").ToString()
Label8.Text += dr("datecreated").ToString()
Label9.Text += dr("description").ToString()
Dim userdetails As Cybermarket.Customers = New Cybermarket.Customers()
Dim druser As OleDbDataReader
druser = userdetails.GetUserdetails(CInt(dr("userid").ToString))
druser.Read()
HyperLink1.Text = druser("Email").ToString
Label10.Text = druser("UserName").ToString & vbCrLf & _
druser("Tel").ToString & vbCrLf & _
druser("Address").ToString
Image1.ImageUrl = "Images\ProductImages\" & dr("ImageUrl").ToString
dr.Close()
productdetail.Updateview(ProductId)
End Sub
End Class
Trang sendmail
Imports System.Data
Imports System.Data.OleDb
Public Class sendmail
Inherits System.Web.UI.Page
Protected WithEvents TextBox2 As System.Web.UI.WebControls.TextBox
Protected WithEvents TextBox3 As System.Web.UI.WebControls.TextBox
Protected WithEvents TextBox4 As System.Web.UI.WebControls.TextBox
Protected WithEvents TextBox5 As System.Web.UI.WebControls.TextBox
Protected WithEvents Button2 As System.Web.UI.WebControls.Button
Protected WithEvents Label1 As System.Web.UI.WebControls.Label
Protected WithEvents Label2 As System.Web.UI.WebControls.Label
Protected WithEvents search As System.Web.UI.HtmlControls.HtmlForm
#Region " Web Form Designer Generated Code "
'This call is required by the Web Form Designer.
Private Sub InitializeComponent()
End Sub
Private Sub Page_Init(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Init
'CODEGEN: This method call is required by the Web Form Designer
'Do not modify it using the code editor.
InitializeComponent()
End Sub
#End Region
Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
'Put user code to initialize the page here
If Not Page.IsPostBack Then
If Request.Params("productid") "" Then
Dim ProductId As Integer = CInt(Request.Params("ProductID"))
Dim UserId As Integer = CInt(Request.Params("UserID"))
'Ok! now get some information about product and user
Dim Getinfouser As New Cybermarket.Customers()
Dim dr As OleDbDataReader
dr = Getinfouser.GetUserdetails(UserId)
dr.Read()
TextBox3.Text = dr("Email").ToString
Dim drp As OleDbDataReader
Dim Getinfopro As New Cybermarket.ProductsDB()
drp = Getinfopro.GetProductdetails(ProductId)
drp.Read()
Label2.Text += " You can contact to " & dr("UserName") & vbCrLf & _
"at" & dr("Tel") & vbCrLf & dr("address")
Dim drm As OleDbDataReader
Dim Gettmp As New Cybermarket.Email()
drm = Gettmp.Getmailtemplate(1)
drm.Read()
TextBox4.Text = Gettmp.Formatmail(drm("Subject").ToString, dr("UserName").ToString, drp("ProductModel").ToString)
TextBox5.Text = Gettmp.Formatmail(drm("Body").ToString, dr("UserName").ToString, drp("ProductModel").ToString)
dr.Close()
drp.Close()
drm.Close()
End If
End If
End Sub
Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button2.Click
Dim sendmail As New Cybermarket.Email()
Dim result As Boolean
result = sendmail.sent(TextBox2.Text, "Hatung", TextBox3.Text, TextBox3.Text, TextBox4.Text, TextBox5.Text)
If result Then
Label1.Text = "Successful"
Else
Label1.Text = "Fail"
End If
End Sub
End Class
Trên đây chúng ta đã xem qua một cách ngắn gọn nội dung của và cùng một phần của mã nguồn ở phía người dùng, còn đơn thể để quản trị mạng chưa được thiết kế do thời gian hạn hẹp. Phần đơn thể quản trị này sẽ có nội dung như sau:
Liệt kê toàn bộ mặt hàng có trong bảng POST cho người quản trị,sửa đổi hay xóa khi thông tin không hợp lệ, hay chèn thêm vào bảng PRODUCTS để thông tin được đưa đến mọi người.
Liệt kê các category để sửa đổi hay mở rộng chủng loại mặt hàng.
Danh mục tài liệu tham khảo
[1] Introduction to Microsoft ASP.NET. (Course Number: 2063C).
[2] ASP 3.0 ASP.NET – Nhà xuất bản giáo dục.
[3] Microsoft .NET Framework SDK Documentation.
[4] Giáo trình lý thuyết và thực hành Oracle 8i.
[5] PL/SQL Fundamental.
Kết luận
Với sự phát triển nhanh chóng của Internet và thương mại điện tử như hiện nay. Việc lựa ASP.NET được coi như là giải pháp hữu hiệu nhất. Với ASP.NET thiết kế Web giờ đây trở nên dễ dàng hơn bao giờ hết do được hỗ trợ nhiều thành phần phong phú, có khả năng vượt qua mọi trình duyệt, thiết bị mà ta không cần quan tâm đến việc định dạng các trang tài liệu cho mỗi trình duyệt, mỗi thiết bị, ASP.NET kết thúc những tranh luận về ngôn ngữ lập trình khi hỗ trợ trên 25 ngôn ngữ khác nhau.
Khi kết hợp với ADO+ với ASP.NET ta dễ dàng triển khai được các ứng dụng với mô hình N-tier, tạo ra được nguồn dữ liệu không kết nối từ nhiều nguồn dữ liệu khác nhau
Hơn nữa, ASP.NET mở ra nhiều cơ hội cho các nhà phát triển với các ứng dụng phân tán cung cấp dữ liệu cho khách hàng thông qua Internet cho phép họ tạo ra một dòng phần mềm mới với dữ liệu XML.
Em đã cố gắng khi xây dựng một ứng dụng với ASP.NET sử dụng cơ sở dữ liệu Oracle, kết hợp hai công cụ sức mạnh nhất trên Internet. Nhưng do thời gian tìm hiểu về hai công cụ này quá ít nên chưa phát huy được nhiều lợi ích do chúng đem lại.
Cuối cùng, em xin cảm ơn TS. Cao Kim ánh là người trực tiếp hướng dẫn em hoàn thành đồ án này, anh Tuấn giám đốc Trung tâm và các anh, chị ở phòng nghiên cứu và phát triển Trung tâm CNTT – Ngân hàng công thương Việt Nam (ITC-ICB) đã khuyến khích và tạo điều kiện thuận lợi cho em hoàn thành đồ án đúng thời hạn.
Các file đính kèm theo tài liệu này:
- P0029.doc