PHẦN I: GIỚI THIỆU CHUNG
Chương I: Tổng quan về đào tạo và học tập trực tuyến
I. Giới thiệu
II. Tìm hiểu về học tập trực tuyến
III. Tham khảo một số Website trực tuyến
IV. Tìm hiểu về giáo trình điện tử
Chương II: Tìm hiểu về việc xây dựng hệ thống CMS
I. Các vấn đề về xây dựng và triển khai CMS
II. Tiêu chuẩn đánh giá CMS
III. Ý nghĩa thực tiễn của hệ thống CMS
IV. Một số Website tham khảo
PHẦN II: PHÂN TÍCH THIẾT KẾ HỆ THỐNG
Chương I: Phân tích chức năng hệ thống
I. Đăng nhập-Đăng ký
II. Thư viện sách –giáo trình
III. Diễn đàn thảo lụân
Chương II: Sơ đồ phân rã chức năng
Chương III: Yêu cầu của hệ thống
I. Yêu cầu chức năng
II. Yêu cầu phi chức năng
Chương IV: Biểu đồ luồng dữ liệu
I. Biểu đồ luồng dữ liệu mức đỉnh
II. Biểu đồ luồng dữ liệu dưới mức đỉnh
Chương V: Các mô hình
I. Mô hình dữ liệu quan hệ
II. Mô hình tổ chức dữ liệu
III. Mô hình vật lý dữ liệu
Chương VI: Một số module xử lý chính của chương trình
Chương VII: Một số giao diện chính của chương trình
PHẦN III: CÁC CÔNG CỤ, MÔI TRƯỜNG HỖ TRỢ
XÂY DỰNG VÀ PHÁT TRIỂN HỆ THỐNG
Chương I: Sơ lược về Apache, PHP và MySQL
I. Apache Webserver
II. Giới thiệu PHP
III. MySQL là gì
IV. Truy nhập MySQL từ PHP
V. Lý do lựa chọn ngôn ngữ
Chương II: Sơ lược về Dreamweaver, HTML và FLASHMX
I. Sơ lược về Dreamweaver
II. Giới thiệu về HTML
III. Sơ lược về FLASHMX
PHẦN IV: TỔNG KẾT-HƯỚNG PHÁT TRIỂN
CỦA ĐỒ ÁN
Chương I: Những kết quả đạt được và những vấn đề còn tồn tại.
I. Những kết quả đạt được
II. Những vấn đề còn tồn tại
Chương II: Hướng phát triển của đồ án
Lời Kết
Tài Liệu Tham Khảo
Nhận Xét Của Giáo Viên Hướng Dần
Nhận Xét Của Giáo Viên Phản Biện
76 trang |
Chia sẻ: huong.duong | Lượt xem: 1321 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Các công cụ, môi trường hỗ trợ xây dựng và phát triển hệ thống, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
liệu về sách, tài liệu, bài viết, tin tức và những thông tin khác vv... phải được lưu trữ định kỳ để đề phòng khi có hỏng hóc xảy ra có thể khôi phục lại thông tin, dữ liệu.
- Dữ liệu về sách, tài liệu, giáo trình được lưu trong bảng cơ sở dữ liệu, nội dung các file sách được upload và lưu trong các thư mục phân loại sách liên quan.
Chương trình phải có khả năng ngăn chặn những người dùng truy cập trái phép để đảm bảo tính toàn vẹn của dữ liệu.
Chương trình cũng có khả năng dễ sữa chửa ,bổ sung
CHƯƠNG IV: BIỂU ĐỒ LUỒNG DỮ LIỆU
I. Biểu đồ luồng dữ liệu mức đỉnh:
*Ghi chú:
Yêu cầu nhập username, password
Thông báo chấp nhận/Từ chối
Yêu cầu nhập thông tin đăng ký
Thông tin cần xem
Thông tin cần cập nhật
Thông báo cập nhật
Yêu cầu tìm kiếm
Kết quả tìm kiếm
Thông tin cần gởi
Dữ liệu thông tin người dùng
Dữ liệu thông tin sách/diễn đàn/tin tức
Dữ liệu thông tin cập nhật
a
Đăng nhập
(7)
(4)
Đăng ký
(3)
(2)
Dữ liệu người dùng
Cập nhật
II
(6)
c
(5)
Tìm kiếm
III
ADMIN
a
USER
(1)
(2)
(1)
(2)
Xem thông tin
I
(4)
(8)
(7)
(8)
Dữ liệu sách / diễn đàn / tin tức
b
b
(6)
(5)
II. Biểu đồ dữ liệu dưới mức đỉnh
Phân rã chức năng I:
ADMIN / USER
Đọc Sách
I.1
Xem Tin Tức
I.2
Xem Bài Viết
I.3
Sách
Tin tức
Bài viết trên diễn đàn
(6)
(1)
(2)
(3)
(4)
(5)
(a)
(c)
(b)
Ghi chú:
Yêu cầu đọc sách
Thông tin sách
Yêu cầu xem tin tức
Nội dung tin tức
Yêu cầu xem bài viết có trên diễn đàn
Nộidung bài viết
Dữ liệu thông tin sách
Dữ liệu tin tức
Dữ liệu về bài viết
Phân rã chức năng II
Ghi chú:
Thông tin cần cập nhật
Thông báo đã cập nhật
Thông tin cần thêm/xoá/sửa
Dữ liệu mới
Dữ liệu cũ
(1)
(1)
(1)
(3)
(3)
(2)
(2)
(2)
(2)
(2)
b
ADMIN
Cập nhật Sách
II.1
Cập nhật
phân loại Sách
II.2
Cập nhật
Tin tức
II.3
Cập nhật
Bài viết
II.4
Cập nhật
Chủ đề diễn đàn
II.5
Sách
Loại sách
a
b
a
Tin tức
Bài viết
Chủ đề
a
a
a
b
b
b
USER
(1)
(2)
(1)
(2)
Phân rã chức năng II.1
Ghi chú:
Thông tin sách cần thêm
Thông báo sách đã thêm
Sách cần xoá
Thông báo sách xoá
Thông báo sách đã sửa
Sách cần sửa
Dữ liệu sách thêm
Dữ liệu cũ
Dữ liệu sách sửa
ADMIN
Thêm Sách
II.1.1
Xoá Sách
II.1.2
Sửa Sách
II.1.3
Sách
(1)
(2)
(6)
(5)
(4)
(3)
(c)
(b)
(b)
(b)
(a)
Phân rã chức năng II.3
Ghi chú:
Tin tức cần thêm
Thông báo tin đã gởi
Tin cần xoá
Thông báo tin cần xoá
Tin cần hiển thị
Thông báo tin hiễn thị
Tin cần sửa
Thông báo tin đã sửa
Dữ liệu tin mới
Dữ liệu tin cũ
Dữ liệu tin cần xoá
Dữ liệu tin hiển thị
Dữ liệu tin mới sửa
Dữ liệu tin cần sửa
Hiển thị tin
II.3.3
ADMIN
Thêm Tin
II.3.1
Xoá tin
II.3.2
Tin tức
USER
(1)
(2)
(4)
(3)
(1)
(2)
a
b
c
Sửa tin
II.3.4
(5)
(6)
(8)
(7)
d
e
f
Phân rã chức năng II.4
ADMIN
Thêm BV
II.4.1
Xoá BV
II.4.2
Bài viết
USER
(1)
(2)
(4)
(3)
(1)
(2)
a
b
c
Ghi chú:
Thông tin bài viết cần thêm
Thông báo bài viết đã gởi
Bài viết cần xoá
Thông báo bài viết cần xoá
Dữ liệu bài viết mới
Dữ liệu bài viết cũ
Dữ liệu bài viết cần xoá
Phân rã chức năng III
ADMIN
USER
TK SÁCH
III.1
TK TIN
III.2
TK BÀIVIẾT
III.3
Sách
Tin
Bài viết
(1)
(2)
(1)
(2)
(1)
(2)
(1)
(2)
(1)
(2)
(1)
(2)
a
b
c
Ghi chú:
Yêu cầu tìm kiếm
Kết quả tìm kiếm
Dữ liệu sách
Dữ liệu tin
Dữ liệu bài viết
CHƯƠNG V: CÁC MÔ HÌNH
I. Mô hình dữ liệu quan hệ
II. Mô hình tổ chức dữ liệu:
USER (USERNAME, PASSWORD, CAP, EMAIL).
BAIVIET ( MABAIVIET, TIEUDE, NOIDUNG, CAP, NGAYGOIBAI, NGUOIGOI, CHUDE).
CHUDE ( MACHUDE, TEN, MOTA).
TINTUC ( MATIN, TIEUDE, NOIDUNG, HINHANH, NGAYTAO, NGUOIGOI, TRANGTIN).
TRANGTIN (MATRANGTIN, TENTRANGTIN, MOTA).
SACH (MASACH, TENSACH, MOTA, NOIDUNG, NGAYTAO, HINHANH, NGUOIGOI, NGONNGU, PHANLOAI).
PHANMUCSACH ( MAPMSACH, TENPMSACH).
NGONNGU ( MANN, TENNN).
III. Mô hình vật lý dữ liệu:
USER (USERNAME, PASSWORD, CAP, EMAIL).
Field Name
Data Type
Field Size
Validation Rule
USERNAME(K)
CHAR
16
6< = LEN()
PASSWORD
CHAR
16
6< = LEN()
CAP
INT
1
EMAIL
VARCHAR
100
Ý nghĩa:
USERNAME: Tên đăng ký và dùng khi đăng nhập.
PASSWORD: Mật khẩu đăng ký và dùng đăng nhập
CAP: Người quản trị(YES) hoặc người sử dụng (No).
EMAIL: Email của người sử dụng để liên hệ
BAIVIET ( MABAIVIET, TIEUDE, NOIDUNG, CAP, NGAYGOIBAI, NGUOIGOI, CHUDE).
Thuộc tính
Kiểu
Field Size
Validation Rule
MABAIVIET(K)
INT
TIEUDE
TEXT
20
NOIDUNG
TEXT
CAP
INT
1
NGAYGOIBAI
DATETIME
CHUDE
INT
LOOKUP(CHUDE)
NGUOIGOI
CHAR
16
LOOKUP(USER)
Ý nghĩa:
MABAIVIET: Mã số để phân biệt các bài viết với nhau
TIEUDE: Tiêu đề bài viết
NOIDUNG: Nội dung bài viết
CAP: Để phân biệt bài viết là bài trả lời hay là bài viết mới
NGAYGOIBAI: Ngày bài được post lên hệ thống
CHUDE: Cho biết bài viết thuộc chủ đề nào
NGUOIGOI: Cho biết người gởi bài
CHUDE ( MACHUDE, TEN, MOTA).
Field Name
Data Type
Field Size
Validation Rule
MACHUDE(K)
INT
TEN
CHAR
16
MOTA
VARCHAR
255
Ý nghĩa:
MACHUDE: Mã chủ đề để phân biệt các chủ đề khác nhau của diễn đàn
TEN: Tên chủ đề của diễn đàn
MOTA: Mô tả nội dung chủ đề được đề cập trong diễn đàn
TINTUC ( MATIN, TIEUDE, NOIDUNG, HINHANH, NGAYTAO, NGUOIGOI, TRANGTIN).
Field Name
Data Type
Field Size
Validation Rule
MATIN(K)
INT
TIEUDE
VARCHAR
255
NOIDUNG
TEXT
HINHANH
TEXT
NGAYTAO
INT
NGUOIGOI
INT
LOOKUP(USER)
TRANGTIN
VARCHAR
16
LOOKUP(TRANGTIN)
Ý nghĩa:
MATIN: Khoá phân biệt các tin khác nhau
TIEUDE: Tiêu đề của tin tức
NOIDUNG: Nội dung tin tức đề cập đến
NGAYTAO: Ngày tin được gởi lên hệ thống
NGUOIGOI: Mã để nhận biết người gởi tin
TRANGTIN: Để biết tin thuộc trang tin nào
TRANGTIN (MATRANGTIN, TENTRANGTIN, MOTA).
Field Name
Data Type
Field Size
Validation Rule
MATRANGTIN(K)
INT
TENTRANGTIN
VARCHAR
16
MOTA
TEXT
Ý nghĩa:
MATRANGTIN: Khoá phân biệt các trang tin trong mục tin
TENTRANGTIN: Tên trang tin
MOTA: Mô tả nội dung trang tin đề cập đến
SACH (MASACH, TENSACH, MOTA, NOIDUNG, NGAYTAO, HINHANH, NGUOIGOI, NGONNGU, PHANLOAI).
Field Name
Data Type
Field Size
Validation Rule
MASACH(K)
INT
TENSACH
CHAR
60
MOTA
VARCHAR
255
NOIDUNG
VARCHAR
255
HINHANH
TEXT
NGAYTAO
DATE
PHANLOAI
INT
LOOKUP(PHANMUCSACH)
NGUOIGOI
CHAR
16
LOOKUP(USER)
NGONNGU
INT
LOOKUP(NGONNGU)
Ý nghĩa:
MASACH: Mã phân biệt các sách khác nhau
TENSACH: Tên của sách
MOTA: Mô tả tóm lược nội dung sách
NOIDUNG: Liên kết tới nội dung chính của sách
HINHANH: Hình ảnh minh hoạ cho sách
NGAYTAO: Ngày sách được đưa lên hệ thống
PHANLOAI: Cho biết sách thuộc lĩnh vực nào
NGUOIGOI: Người đưa sách lên hệ thống
NGONNGU: Ngôn ngữ của sách sử dụng
PHANMUCSACH ( MAPMSACH, TENPMSACH).
Field Name
Data Type
Field Size
Validation Rule
MAPMSACH(K)
INT
TENPMSACH
CHAR
40
Ý nghĩa:
MAPMSACH: Mã phân loại các lĩnh vực của sách
TENPMSACH: Tên của phân loại sách
NGONNGU(MANN, TENNN)
Field Name
Data Type
Field Size
Validation Rule
MANN(K)
INT
TENNN
CHAR
20
MANN: Mã phân biệt giữa các ngôn ngữ
TENNN: Tên ngôn ngữ.
CHƯƠNG VI: MỘT SỐ MODULE XỬ LÝ CHÍNH
CỦA CHƯƠNG TRÌNH
Hàm xử lý đăng nhập
Function login($username, $password)
// check username and password with db
// if yes, return true
// else return false
{
// connect to db
$conn = db_connect();
if (!$conn)
return 0;
// check if username is unique
$result = mysql_query("select * from admin
where username='$username'
and password = password('$password')");
if (!$result)
return 0;
if (mysql_num_rows($result)>0)
return 1;
else
return 0;
}
Hàm xử lý đăng ký
Function register($username, $email, $password)
// register new person with db
// return true or error message
{
// connect to db
$conn = db_connect();
if (!$conn)
return "Khong ket noi duoc co so du lieu";
// check if username is unique
$result = mysql_query("select * from reader where namereader='$username'");
if (!$result)
return "Khong truy xuat duoc co so du lieu";
if (mysql_num_rows($result)>0)
return "Ten bi trung, xin vui long dang ky voi ten khac !";
// if ok, put in db
$result = mysql_query("insert into reader values
('$username', password('$password'), '$email')");
if (!$result)
return "Could not register you in database - please try again later.";
return true;
}
Hàm kiểm tra việc nhập dữ liệu vào các form nhập
Function filled_out($form_vars)
{
// test that each variable has a value
foreach ($form_vars as $key => $value)
{
if (!isset($key) || ($value == ""))
return false;
}
return true;
}
Hàm kiểm tra tính chính xác của địa chỉ Email
Function valid_email($address)
{
// check an email address is possibly valid
if (ereg("^[a-zA-Z0-9_\.\-]+@[a-zA-Z0-9\-]+\.[a-zA-Z0-9\-\.]+$", $address))
return true;
else
return false;
}
Hàm xử lý thêm sách
Function insert_book($isbn, $title, $catid, $description,$bm_URL)
// insert a new book into the database
{
$conn = db_connect();
$time=time();
// check category does not already exist
$query = "select *
from books
where bookid='$bookid'";
$result = mysql_query($query);
if (!$result || mysql_num_rows($result)!=0)
return false;
// insert new category
$query = "insert into books values ('','$isbn','$title','$catid','$description','$bm_URL',$time,$time)";
$result = mysql_query($query);
if (!$result)
return false;
else
return true;
}
Hàm xử lý xoá sách
Function delete_book($bookid)
// Deletes the book identified by $isbn from the database.
{
$conn = db_connect();
$query = "delete from books
where bookid='$bookid'";
$result = @mysql_query($query);
if (!$result)
return false;
else
return true;
}
Hàm xử lý sửa sách
Function update_book ($oldisbn, $isbn, $title, $catid, $description,$bm_URL)
// change details of book stored under $oldisbn in
// the database to new details in arguments
{
$conn = db_connect();
$time=time();
$query = "update books
set
bookid='$bookid',
isbn='$isbn',
title ='$title',
catid = '$catid',
description = '$description',
bm_URL= '$bm_URL',
modified='$time'
where isbn='$oldisbn'";
$result = @mysql_query($query);
if (!$result)
return false;
else
return true;
}
Hàm xừ lý truy vấn cơ sở dữ liệu sách
Function get_book_details($bookid)
{
// query database for all details for a particular book
if (!$bookid || $bookid=="")
return false;
$conn = db_connect();
$query = "select * from books where bookid='$bookid'";
$result = @mysql_query($query);
if (!$result)
return false;
$result = @mysql_fetch_array($result);
return $result;
}
Hàm xử lý hiển thị tất cả tiêu đề của bài viết trên diễn đàn
Function expand_all(&$expanded,$maforum)
{
// mark all threads with children as to be shown expanded
$conn = db_connect();
$query = "select postid from header where children = 1 and maforum=$maforum";
$result = mysql_query($query);
$num = mysql_numrows($result);
for($i = 0; $i<$num; $i++)
{
$expanded[mysql_result($result, $i, 0)]=true;
}
}
Hàm xử lý lưu trữ bài viết post lên diễn đàn
Function store_new_post($post)
{
// validate clean and store a new post
$conn = db_connect();
// check no fields are blank
if(!filled_out($post))
return false;
$post = clean_all($post);
//check parent exists
if($post["parent"]!=0)
{
$query = "select postid from header where maforum='".$post['maforum']."' and postid = '".$post['parent']."'";
$result = mysql_query($query);
if(mysql_numrows($result)!=1)
{
return false;
}
}
// check not a duplicate
$query = "select header.postid from header, body where
header.postid = body.postid and
header.parent = ".$post['parent']." and
header.poster = '".$post['poster']."' and
header.title = '".$post['title']."' and
header.area = ".$post['area']." and
header.maforum = ".$post['maforum']." and
body.message = '".$post['message']."'";
$result = mysql_query($query);
if (!$result)
{
return false;
}
if(mysql_numrows($result)>0)
return mysql_result($result, 0, 0);
$query = "insert into header values
('".$post['parent']."',
'".$post['poster']."',
'".$post['title']."',
0,
'".$post['area']."',
'".$post['maforum']."',
now(),
NULL
)";
$result = mysql_query($query);
if (!$result)
{
return false;
}
// note that our parent now has a child
$query = "update header set children = 1 where maforum = '".$post['maforum']."' and postid = ".$post['parent'];
$result = mysql_query($query);
if (!$result)
{
return false;
}
// find our post id, note that there could be multiple headers
// that are the same except for id and probably posted time
$query = "select header.postid from header left join body on header.postid = body.postid
where parent = '".$post["parent"]."'
and poster = '".$post["poster"]."'
and maforum= '".$post["maforum"]."'
and title = '".$post["title"]."'
and body.postid is NULL";
$result = mysql_query($query);
if (!$result)
{
return false;
}
if(mysql_numrows($result)>0)
$id = mysql_result($result, 0, 0);
if($id)
{
$query = "insert into body values ($id, '".$post["message"]."')";
$result = mysql_query($query);
if (!$result)
{
return false;
}
return $id;
}
}
Xử lý hiển thị bài viết theo cấu trúc cây
Class treenode
{
// each node in the tree has member variables containing
// all the data for a post except the body of the message
var $m_postid;
var $m_title;
var $m_poster;
var $m_posted;
var $m_children;
var $m_childlist;
var $m_depth;
Function treenode($postid, $title, $poster, $posted, $children,
$expand, $depth, $expanded, $sublist,$maforum)
{
// the constructor sets up the member variables, but more
// importantly recursively creates lower parts of the tree
$this->m_postid = $postid;
$this->m_title = $title;
$this->m_poster = $poster;
$this->m_posted = $posted;
$this->m_children =$children;
$this->m_childlist = array();
$this->m_depth = $depth;
// we only care what is below this node if it
// has children and is marked to be expanded
// sublists are always expanded
if(($sublist||$expand) && $children)
{
$conn = db_connect();
$query = "select * from header where maforum=$maforum and parent = $postid order by posted desc";
$result = mysql_query($query);
for ($count=0; $row = @mysql_fetch_array($result); $count++)
{
if($sublist||$expanded[ $row['postid'] ] == true)
$expand = true;
else
$expand = false;
$this->m_childlist[$count]= new treenode($row['postid'],$row['title'],
$row['poster'],$row['posted'],
$row['children'], $expand,
$depth+1, $expanded, $sublist,$maforum);
}
}
}
Function display($row, $sublist = false)
{
// as this is an object, it is responsible for displaying itself
// $row tells us what row of the display we are up to
// so we know what color it should be
// $sublist tells us whether we are on the main page
// or the message page. Message pages should have
// $sublist = true.
// On a sublist, all messages are expanded and there are
// no "+" or "-" symbols.
// if this is the empty root node skip displaying
if($this->m_depth>-1)
{
//color alternate rows
echo "<td bgcolor = ";
if ($row%2)
echo "'#cccccc'>";
else
echo "'#ffffff'>";
// indent replies to the depth of nesting
for($i = 0; $im_depth; $i++)
{
echo "<img src = 'images/spacer.gif' height = 22
width = 22 alt = '' valign = bottom>";
}
// display + or - or a spacer
if ( !$sublist && $this->m_children && sizeof($this->m_childlist))
// we're on the main page, have some children, and they're expanded
{
// we are expanded - offer button to collapse
echo "<a href = 'index.php?collapse=".
$this->m_postid."#$this->m_postid'
><img src = 'images/minus.gif' valign = bottom
height = 22 width = 22 alt = 'Collapse Thread' border = 0>";
}
else if(!$sublist && $this->m_children)
{
// we are collapsed - offer button to expand
echo "<a href = 'index.php?expand=".
$this->m_postid."#$this->m_postid'><img src = 'images/plus.gif'
height = 22 width = 22 alt = 'Expand Thread' border = 0>";
}
else
{
// we have no children, or are in a sublist, do not give button
echo "<img src = 'images/spacer.gif' height = 22 width = 22
alt = ''valign = bottom>";
}
echo " m_postid ><a href =
'view_post.php?postid=$this->m_postid'>$this->m_title -
$this->m_poster - ".reformat_date($this->m_posted)."";
echo "";
// increment row counter to alternate colors
$row++;
}
// call display on each of this node's children
// note a node will only have children in its list if expanded
$num_children = sizeof($this->m_childlist);
for($i = 0; $i<$num_children; $i++)
{
$row = $this->m_childlist[$i]->display($row, $sublist);
}
return $row;
}
};
Xử lý biến session của user đăng nhập
Function check_admin_user()
// see if somebody is logged in and notify them if not
{
global $admin_user;
if (session_is_registered("admin_user"))
return true;
else
return false;
}
CHƯƠNG VII: MỘT SỐ GIAO DIỆN CHÍNH
CỦA CHƯƠNG TRÌNH
Trang chủ:
Trang thư viện
Trang tin
Trang diễn đàn
Trang quản trị thư viện
Trang quản trị tin
Phần III: CÁC CÔNG CỤ, MÔI TRƯỜNG HỖ TRỢ XÂY DỰNG VÀ PHÁT TRIỂN HỆ THỐNG
Hệ thống mà em xây dựng là một trình ứng dụng được viết trên giao diện Web, người sử dụng có thể truy xuất các trang Web của hệ thống từ các máy con. Do vậy yêu cầu của hệ thống là phải có một máy chủ chạy phần mềm web server(như IIS,Apache,Personal Web Server…).
Thứ hai, do đây là trang Web có tương tác cơ sở dữ liệu nên cần phải có một hệ quản trị cơ sở dữ liệu(như SQL Server,Ocracle,MySQL,MS Access,…). Tuy có nhiều cách lựa chọn về môi trường làm việc nhưng trong thời gian làm đồ án tốt nghiệp, em chọn môi trường và công cụ làm việc cho ứng dụng gồm:
Web Server: Apache Web server
Cơ sở dữ liệu: MySQL
Ngôn ngữ: PHP
Ngoài ra, còn sử dụng một số chức năng của một số phần mềm như Dreamweaver, Flash MX để chuẩn bị cho việc xây dựng và phát triển đề tài để tạo giao diện
CHƯƠNG I: SƠ LƯỢC VỀ APACHE, PHP VÀ MYSQL
I. Apache Web server
Trên thị trường tồn tại nhiều phần mềm webserver khác nhau như: Xitami, Apache, IIS..., mỗi loại đều có ưu nhược điểm riêng. Điển hình là sản phẩm thương mại IIS do Microsoft phát triển, nó rất thích hợp với các trình dịch của Microsoft hơn còn với các trình biên dịch khác thì nó ít hỗ trợ, vả lại khả năng chống và chịu lỗi của IIS không cao . Còn Apache Web Server do công ty Apache phát triển, được cung cấp miễn phí, hỗ trợ nhiều ngôn ngữ, chạy trên nhiều môi trường như Microsoft, Linux, Unix.
Apache là Web server phổ biến nhất hiện nay, chiếm khỏang gần 60% thị trường máy chủ Web trên thế giới chứng tỏ sự mạnh mẽ và đáng tin cậy của nó. Trên Web server sẽ chứa những site mà các máy con có thể truy xuất đến các site này.
Cài đặt Apache và cấu hình Apache
Có thể download Apache tại địa chỉ
Có thể downloadn file .msi,( nếu trên máy có sẵn Windows Intaller), hoặc file .exe (dung lượng lớn hơn). Cài đặt theo các thông số mặc định của Apache.
Sau khi cài đặt, cần phải sửa file cấu hình của Apache( mặc định là: C:\Program Files\Apache Group\Apache\conf\httpd.conf ), tìm đến dòng có chứa lệnh DocumentRoot, thay tham số bằng thư mục sẽ chứa các trang Web của mình (Ví dụ:C:/MyWeb,hoặc C:\\MyWeb). Sau đó khởi động lại Apache.
II. Giới thiệu PHP:
Cùng với Apache, PHP và MySQL đã trở thành chuẩn trên các máy chủ Web. Rất nhiều phần mềm Web mạnh sử dụng PHP và MySQL (PHP Nuke, Post Nuke, vBulletin…).
PHP là ngôn ngữ có cú pháp gần giống Perl nhưng tốc độ dịch của nó được các chuyên gia đánh giá là nhanh hơn ASP 5 lần, chạy trên nhiều hệ điều hành như Unix, Window, Linux nó hỗ trợ kết nối các hệ cơ sở dữ liệu lớn như MySQL, ngoài ra nó còn được Apache hỗ trợ như là một modul cơ bản.
1. PHP là gì?
PHP (Personal Home Page hay PHP Hypertext Preprocessor) được giới thiệu năm 1994 bởi R.Lerdoft, như một bộ sưu tập của một ngôn ngữ chưa chặt chẽ dựa vào Perl và các công cụ của trang chủ. Vì quá trình xử lý dựa trên máy chủ nên các trang Web được viết bằng PHP sẽ dễ nhìn hơn ở bất cứ hệ điều hành nào. Nói một cách ngắn gọn: PHP là một ngôn ngữ lập trình kiểu script, chạy trên Server và trả về mã HTML cho trình duyệt. Xu hướng sử dụng PHP trong việc thiết kế Web đang ngày càng phát triển trong giai đọan hiện nay và trong tương lai.
Tới năm 1998, việc công bố phiên bản 3 thì PHP mới chính thức phát triển theo hướng tách riêng của mình. Giống như C và Perl, lúc này nó đã là một ngôn ngữ lập trình có cấu trúc và tính năng đa dạng, chính vì thế đã khuyến khích các nhà thiết kế Web sử dụng PHP. Nó có thể cung cấp một lượng cơ sở dữ liệu khá đồ sộ gồm cả MySQL, mSQL, dbm, Hyperwave, Informix, Ocracle, nó cũng có thể làm việc với các hình ảnh, các file dữ liệu, FTP, XML, và host của các kỹ thuật ứng dụng khác.
Mã PHP được đặt trong một kiểu tag đặc biệt cho phép ta có thể vào họăc ra khỏi chế độ PHP, cú pháp của PHP cơ bản cũng giống như một số ngôn ngữ lập trình khác, đặc biệt là C và Perl.
PHP được nhận dạng dưới 4 dạng phiên bản:
a.Ví dụ:
<?php //bắt đầu php
echo”Hello World”;
?> //Kết thúc php
b.Ví dụ
Echo”Hello,World”;
c.Ví dụ
<?
Echo”Hello,World”;
?>
d.Ví dụ:
<%
echo “Hello,World”;
%>
Tuy nhiên phiên bản đầu tiên vẫn được ưa chuộng và dùng phổ biến hơn.
2. Cài đặt và cấu hình PHP
Download PHP tại giải nén ( ví dụ:C:\PHP)
Vào file cấu hình của Apache (Mặc định là C:\Program Files\Apache Group\Apache\conf\httpd.conf) để setup PHP ở chế độ CGI.
ScriptAlias/php/"c:/php" AddType application/x-httpd-php .php .phtml Action application/x-httpd-php"/php/php.exe"
Nếu muốn sử dụng PHP như là một module của Apache, chuyển file php4ts.dll trong thư mục của PHP sang thư mục C:\WINDOWS\SYSTEM (Với WIN9X/ME/XP) hoặc thư mục WINNT\SYSTEM32 ( Với WINNT/2000). Sau đó thêm các dòng lệnh sau vào file httd.conf của Apache.
LoadMoule php4_module c:/php/sapi/php4apache.dll AddType application/x-httpd-php .php .phtml
Khởi động lại Apache.
3. Các kiểu dữ liệu:
3.1 Số nguyên:
Được khai báo và sử dụng giá trị giống như C:
VD: $a=1234; $a = -123;
3.2 Số thực:
VD:$a= 1.323; $a=1.2e3;
Chú ý: Khi sử dụng các số thực tế để tính tóan, có thể làm mất giá trị của nó. Vì vậy, nên sử dụng các hàm tóan học trong thư viện chuẩn để tính toán.
3.3 Xâu:
Có 2 cách để xác đinh 1 xâu: Đặt giữa 2 dấu nháy kép(“”) hoặc giữa 2 dấu nháy đơn (‘’).Chú ý là các biến giá trị sẽ không được khai triển trong xâu giữa 2 dấu ngoặc đơn.
3.4 Mảng:
Mảng thực chất là gồm 2 bảng: Bảng chỉ số và bảng liên kết
a. Mảng 1 chiều: Có thể dùng hàm list(), array() để liệt kê ca(c giá trị của từng phần tử trong mảng để tạo mảng. Có thể thêm các giá trị vào mảng để tạo thành 1 mảng --> Dùng giống trong C.
Có thể dùng các hàm asort(), arsort(), ksort(), rsort(), sort(), uasort(), usort(), and uksort() để sắp xếp mảng. Tùy thuộc vào việc sắp xếp theo kiểu gì.
b.Mảng nhiều chiều: Tương tự như C, có thể dùng như VD sau:
$a[1] = $f; $a["foo"] = $f; $a[1][0] = $f; $a["foo"][2] = $f;
$a[3]["bar"] = $f;
PHP không yêu cầu phải khai báo trước kiểu dữ liệu cho các biến, kiểu dữ liệu của biến sẽ phụ thuộc vào kiểu dữ liệu mà bạn gán cho nó.
VD :
$foo = "0"
Các file đính kèm theo tài liệu này:
- DA0667.doc