Đề tài Thiết kế và lập trình website

BỘ GIÁO DỤC VÀ ĐÀO TẠO TRƯỜNG ĐẠI HỌC BÀ RỊA - VŨNG TÀU KHOA CÔNG NGHỆ KỸ THUẬT - NÔNG NGHIỆP CÔNG NGHỆ CAO  ĐỒ ÁN TỐT NGHIỆP ĐỀ TÀI THIẾT KẾ VÀ LẬP TRÌNH WEBSITE Giảng viên hướng dẫn : ThS. Nguyễn Lan Hương Sinh viên thực hiện : Phan Tiến Đạt Trình độ đào tạo : Đại Học Chính Quy Ngành đào tạo : Công Nghệ Thông Tin Chuyên Ngành : Máy Tính MSSV : 16031147 Lớp : DH16MT Niên khóa : 2016 - 2020 VŨNG TÀU, NĂM 2020 ĐẠI HỌC BÀ RỊA – VŨNG TÀU CỘNG HÒA

pdf168 trang | Chia sẻ: huong20 | Ngày: 07/01/2022 | Lượt xem: 448 | Lượt tải: 0download
Tóm tắt tài liệu Đề tài Thiết kế và lập trình website, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
XÃ HỘI CHỦ NGHĨA VIỆT NAM KHOA KỸ THUẬT CN-NNCN CAO Độc lập – Tự do – Hạnh phúc ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ ⎯ PHIẾU GIAO ĐỀ TÀI ĐỒ ÁN/ KHÓA LUẬN TỐT NGHIỆP Họ tên sinh viên: Phan Tiến Đạt Mã SV: 16031147 Lớp: DH16MT Ngành: Công Nghệ Thông Tin Khóa: 16 Tên đề tài: Thiết kế và lập trình Website Mục tiêu đề tài: Thiết kế và lập trình website giới thiệu, quảng bá về công ty (công ty lấy tên Viko), đưa tới mọi người hình ảnh về công ty cùng những thông tin sản phẩm, dự án của công ty đó. Đồng thời bên phía công ty cũng được cung cấp những chức năng để quản trị website một cách tốt nhất. Kết quả dự kiến: Sản phẩm website có giao diện đẹp mắt, bố cục đơn giản, tích hợp nhiều chức năng để người dùng dễ dàng tra cứu, tìm hiểu các thông tin về công ty. Qua đó hình ảnh công ty sẽ được quảng bá một cách tốt nhất đến mọi người. Thời gian thực hiện: Bắt đầu từ 02/03/2020 đến 10/05/2020. Vũng Tàu, ngày.. tháng..năm TRƯỞNG KHOA CNTT GIẢNG VIÊN HƯỚNG DẪN (Ký và ghi rõ họ tên) (Ký và ghi rõ họ tên) NHẬN XÉT CỦA GIÁO VIÊN HƯỚNG DẪN ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. Ngày.........Tháng..........Năm......... Giáo Viên Hướng Dẫn (Ký, ghi rõ họ và tên) NHẬN XÉT CỦA GIÁO VIÊN PHẢN BIỆN ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. ............................................................................................................................. Ngày.........Tháng..........Năm......... Giáo Viên Phản Biện (Ký, ghi rõ họ và tên) LỜI CAM ĐOAN Đồ án này là công trình nghiên cứu và xây dựng của cá nhân tôi, được thực hiện dưới sự hướng dẫn khoa học của Ths. Nguyễn Lan Hương. Các số liệu, những kết luận nghiên cứu được trình bày trong đồ án này là do tôi tự tìm hiểu và hoàn toàn trung thực. Tôi xin hoàn toàn chịu trách nhiệm về lời cam đoan này. Vũng Tàu, tháng 4 năm 2020 Sinh Viên Thực Hiện Phan Tiến Đạt LỜI CẢM ƠN Tôi xin chân thành cảm ơn khoa Công nghệ thông tin, trường Đại học Bà Rịa – Vũng Tàu đã tạo điều kiện thuận lợi cho tôi thực hiện đề tài này. Tôi cũng xin được gửi lời cảm ơn chân thành nhất đến Ths. Nguyễn Lan Hương, người đã tận tình chỉ bảo, định hướng đi và hướng dẫn tôi thực hiện đề tài này. Bên cạnh đó, tôi xin gửi lời cảm ơn đến các thầy cô, những người đã giảng dạy, tạo điều kiện cho tôi tích lũy được những kiến thức quý báu trong những năm học qua. Dù đã cố gắng hoàn thành đề tài Website giới thiệu công ty Viko, nhưng do thời gian hạn hẹp và khả năng còn hạn chế nên chắc chắn sẽ có những thiếu sót không tránh khỏi. Tôi mong nhận được sự thông cảm và tận tình chỉ bảo của các thầy cô và góp ý từ các bạn. Vũng Tàu, tháng 4 năm 2020 Sinh viên thực hiện Phan Tiến Đạt MỤC LỤC DANH MỤC CÁC BẢNG ........................................................................................ 1 DANH MỤC CÁC HÌNH ẢNH ............................................................................... 2 LỜI MỞ ĐẦU ............................................................................................................ 5 CHƯƠNG 1: CƠ SỞ LÝ THUYẾT VÀ KHẢO SÁT ........................................... 7 1.1 HTML,CSS và JavaScript ............................................................................. 7 1.1.1 HTML là gì? ............................................................................................... 7 1.1.2 CSS là gì? ................................................................................................... 7 1.1.3 JavaScript là gì? ......................................................................................... 8 1.2 Bootstrap .......................................................................................................... 8 1.2.1 Bootstrap là gì? .......................................................................................... 8 1.2.2 Tại sao nên dùng Bootstrap? ...................................................................... 9 1.3 JQuery .............................................................................................................. 9 1.3.1 JQuery là gì? .............................................................................................. 9 1.3.2 Tại sao nên dùng jQuery? .......................................................................... 9 1.4 Ajax ................................................................................................................. 10 1.4 Ajax là gì? ................................................................................................... 10 1.4.2 Tại sao nên dùng Ajax? ............................................................................ 11 1.5 Lararel ............................................................................................................ 11 1.5.1 Laravel là gì? ............................................................................................ 11 1.5.2 Tại sao nên dùng Laravel? ....................................................................... 13 1.6 PHP ................................................................................................................. 15 1.6.1 PHP là gì? ................................................................................................. 15 1.6.2 Tại sao nên dùng PHP .............................................................................. 16 1.7 Khảo Sát Hiện Trạng .................................................................................... 17 1.7.1 Khảo sát thực tế ........................................................................................ 17 1.7.2 Khảo sát các website tương tự ................................................................. 18 CHƯƠNG 2: TỔNG QUAN CHỨC NĂNG WEBSITE ..................................... 24 2.1 Quan Điểm Của Sản Phẩm........................................................................... 24 2.2 Chức Năng Sản Phẩm ................................................................................... 24 2.3 Người Dùng .................................................................................................... 24 2.4 Các Ràng Buộc .............................................................................................. 25 CHƯƠNG 3: YÊU CẦU CHỨC NĂNG WEBSITE ............................................ 26 3.1 Xem tin .......................................................................................................... 26 3.2 Tìm kiếm sản phẩm ...................................................................................... 26 3.3 Lọc sản phẩm ................................................................................................ 26 3.4 Gửi yêu cầu nhận báo giá ............................................................................ 26 3.5 Nhận xét bài viết về sản phẩm .................................................................... 26 3.6 Đăng nhập/đăng xuất ................................................................................... 26 3.7 Quản lý các tin đăng trên website ............................................................... 27 3.8 Nhận các thông báo yêu cầu từ khách hàng .............................................. 27 3.9 Quản lý thông tin tài khoản ........................................................................ 27 CHƯƠNG 4: MÔ HÌNH USECASE ..................................................................... 28 4.1 Tác nhân ........................................................................................................ 28 4.2 Các yêu cầu chức năng ................................................................................ 28 4.3 Lược Đồ Use Case ........................................................................................ 30 4.4 Chi Tiết Các Use Case.................................................................................. 31 CHƯƠNG 5: THIẾT KẾ WEBSITE .................................................................... 59 5.1 Thiết kế cơ sở dữ liệu ................................................................................... 59 5.1.1 Lược đồ cơ sở dữ liệu ............................................................................. 59 5.1.2 Chi tiết các trường ................................................................................... 59 5.2 Mối quan hệ giữa các bản dữ liệu ............................................................... 64 5.3 Thiết kế giao diện Website – Front-End .................................................... 64 5.4 Lập trình Website – Back-End với Laravel ................................................ 85 5.5 Một số đoạn code nổi bật ........................................................................... 145 KẾT LUẬN ............................................................................................................ 156 TÀI LIỆU THAM KHẢO .................................................................................... 159 DANH MỤC CÁC BẢNG TT Số hiệu Nội dung Trang Bảng các tác nhân và quyền của 1 Bảng 4.1 28 tác nhân trong UseCase Bảng các yêu cầu chức năng hệ 2 Bảng 4.2 28 thống 3 Bảng 4.3 Bảng chi tiết các UseCase 31 - 58 4 Bảng 5.1 Bảng Table tai_khoans 59 - 60 5 Bảng 5.2 Bảng Table infoct 60 6 Bảng 5.3 Bảng Table thanhpham 60 - 61 7 Bảng 5.4 Bảng Table baogia 61 8 Bảng 5.5 Bảng Table sanpham 61 9 Bảng 5.6 Bảng Table loaisanpham 62 10 Bảng 5.7 Bảng Table loaisanpham_sanpham 62 11 Bảng 5.8 Bảng Table hinhsanpham 62 12 Bảng 5.9 Bảng Table nhanxet 62 - 63 1 DANH MỤC CÁC HÌNH ẢNH TT Số hiệu Nội dung Trang Các phiên bản của laravel đến tháng 1 Hình 1.1 12 4 năm 2020 Cách thức hoạt động MVC trong 2 Hình 1.2 14 Laravel Những ngôn ngữ lập trình phổ biến 3 Hình 1.3 16 từ năm 1965 – 2019 4 Hình 1.4 So sánh giữa ASP và PHP 17 5 Hình 1.5 Slide hình ảnh sản phẩm 19 Mẫu gửi thông tin yêu cầu tới công 6 Hình 1.6 20 ty 7 Hình 1.7 Danh mục các sản phẩm 20 8 Hình 1.8 Bài đăng thông tin về sản phẩm 21 9 Hình 1.9 Bài đăng báo giá 22 10 Hình 1.10 Bài đăng tin tức 22 11 Hình 1.11 Danh sách các công trình khác 23 12 Hình 4.1 Lượt đồ tổng quan usecase 30 13 Hình 5.1 Lượt đồ cơ sở dữ liệu 59 Các bản dữ liệu có mối quan hệ với 14 Hình 5.2 64 nhau 15 Hình 5.3 Trang chủ website Viko 64 16 Hình 5.4 Mục giới thiệu trên trang chủ 65 17 Hình 5.5 Mục sản phẩm nổi bật trên trang chủ 66 2 Mục tiêu chí hoạt động trên trang 18 Hình 5.6 66 chủ Mục dự án đã thực hiên trên trang 19 Hình 5.7 67 chủ Mục khách hàng nói về chúng tôi 20 Hình 5.8 67 trên trang chủ 21 Hình 5.9 Mục liên hệ trên trang chủ 68 22 Hình 5.10 Trang danh sách sản phẩm 68 Mục lọc sản phẩm trên trang danh 23 Hình 5.11 69 sách sản phẩm 24 Hình 5.12 Trang chi tiết sản phẩm 69 Mục bài viết trên trang chi tiết sản 25 Hình 5.13 70 phẩm Mục nhận xét cùng mục sản phẩm 26 Hình 5.14 71 cùng loại trên trang chi tiết sản phẩm 27 Hình 5.15 Trang danh sách dự án đã thưc hiện 71 Mục các danh sách dự án đã thực 28 Hình 5.16 72 hiện trên trang dự án đã thực hiện 29 Hình 5.17 Trang chi tiết dự án 72 30 Hình 5.18 Mục bài viết trên trang chi tiết dự án 73 Mục các dự án khác trên trang chi 31 Hình 5.19 73 tiết dự án 32 Hình 5.20 Trang đăng nhập Admin 73 33 Hình 5.21 Trang Admin 74 34 Hình 5.22 Trang thêm loại sản phẩm 74 35 Hình 5.23 Trang danh sách loại sản phẩm 75 3 36 Hình 5.24 Trang sửa loại sản phẩm 75 37 Hình 5.25 Trang thêm sản phẩm 76 38 Hình 5.26 Trang danh sách sản phẩm 77 39 Hình 5.27 Trang sửa sản phẩm 78 40 Hình 5.28 Trang thêm dự án đã thực hiện 80 41 Hình 5.29 Trang danh sách dự án đã thực hiện 81 42 Hình 5.30 Trang sửa dự án đã thực hiện 82 43 Hình 5.31 Trang cập nhật thông tin công ty 83 44 Hình 5.32 Trang danh sách yêu cầu báo giá 84 45 Hình 5.33 Trang sửa thông tin tài khoản 84 Trang báo lỗi Not Found khi không 46 Hình 5.34 84 tìm thấy trang 4 LỜI MỞ ĐẦU 1. Tính cấp thiết của đề tài Theo thống kê mới nhất, tính đến đầu năm 2019, Việt Nam đã có hơn 60 triệu người sử dụng internet, chiếm hơn 60% dân số. Và trong tương lai con số này sẽ vẫn tiếp tục tăng lên không ngừng. Có thể nói đối với các nhà kinh doanh thì môi trường internet chính là một môi trường chứa đầy khách hàng tiềm năng nhất mà mọi doanh nghiệp hay tổ chức nào cũng đều thèm khát. Do đó để khai thác tiềm năng này một cách tốt nhất thì điều không thể thiếu đó chính là đầu tư, phát triển cho riêng mình một Website giới thiệu, quảng bá bản thân doanh nghiệp hoặc bất kỳ tổ chức nào. 2. Tình hình nghiên cứu Có thể nói việc nghiên cứu và phát triển website đã không còn là một vấn đề xa lạ trong kỷ nghiên 4.0 ngày này. Và đặc biệt trong thời đại kinh tế cạnh tranh thì các website phục vụ trong mục đích kinh doanh, quảng bá luôn được ưu tiên phát triển hàng đầu. Điều này có thể dễ dàng thấy thông qua các website của các thương hiệu nổi tiếng hàng đầu trong lĩnh vực kinh doanh như samsung.com, lazada.vn, sony.com.vn, Những website của các thương hiệu này luôn được trao chuốt một cách kĩ lưỡng. Ngoài ra không chỉ những các thương hiệu lớn mới có riêng cho mình một website để quảng bá thương hiệu của mình, mà còn hàng ngàn các công ty, doanh nghiêp lớn nhỏ đều sỡ hữu một website để quảng bá thương hiệu của mình đến mọi người. 5 3. Mục đích nghiên cứu Đề tài có mục đích xây dựng website giới thiệu công ty giúp đưa tới khách hàng những hình ảnh, thông tin một cách đầy đủ và rõ nét về công ty đó. Qua đó tạo được thêm nhiều ưu thế trên môi trường marketing. 4. Nhiệm vụ nghiên cứu Để thực hiện được đề tài một cách trọn vẹn phải trãi qua nhiều giai đoạn nghiên cứu, tìm hiểu, chọn lọc và cuối cùng mới đến công đoạn bắt tay vào xây dựng nên một website. Đầu tiên việc tìm hiểu về cơ sở lý thuyết để tạo ra một website là điều tất yếu. Kế đến cần phải khảo sát thực tế xem website có phù hợp cũng như đồng thời tham khảo những website tương tự. Tiếp đến phải xây dựng mô hình về website như các chức năng, ràng buộc, Và cuối cùng là công việc xây dựng website hoàn chỉnh. 5. Các kết quả đạt được của đề tài Thông qua đề tài sẽ mang đến những kiến thức và cách xây dựng lên một website hoàn chỉnh. Đồng thời website được xây dựng trong đề tài sẽ đạt được một cách đầy đủ và tốt nhất các mục tiêu ban đầu đề. 6 CHƯƠNG 1: CƠ SỞ LÝ THUYẾT VÀ KHẢO SÁT 1.1 HTML,CSS và JavaScript − HTML, CSS và JavaScript là những khái niệm không hề xa lạ với những người lập trình website chuyên nghiệp. Chúng chính là nền tảng không thể thiếu để xây dựng,tô vẽ và làm sống động cho chính những trang web. Và vì lẽ đó mà HTML, CSS, JavaScript là những khái niệm mà bắt buộc ai cũng phải có khi muốn bước chân vào con đường phát triển website. 1.1.1 HTML là gì? − HTML là viết tắt của HyperText Markup Language (ngôn ngữ đánh dấu siêu văn bản) dùng mô tả cấu trúc của các trang Web và tạo ra các loại tài liệu có thể xem được trong trình duyệt. − HTML là cốt lõi của mọi trang web. Mỗi trang web được tạo thành từ một loạt các thẻ HTML mà chúng biểu thị từng loại nội dung trên trang. Mỗi loại nội dung trên trang được “bọc”, tức là được bao quanh bởi các thẻ HTML. − HTML không phải là ngôn ngữ lập trình, đồng nghĩa với việc nó không thể tạo ra các chức năng “động” được. Nó chỉ giống như Microsoft Word, dùng để bố cục và định dạng trang web. 1.1.2 CSS là gì? − CSS (viết tắt của Cascading Style Sheets) là một ngôn ngữ định dạng được sử dụng để mô tả trình bày các trang Web, bao gồm màu sắc, cách bố trí và phông chữ. Nó cho phép hiển thị nội dung tương thích trên các loại thiết bị có kích thước màn hình khác nhau, chẳng hạn như màn hình lớn, màn hình nhỏ, hoặc máy in. 7 − Trong khi HTML là cấu trúc cơ bản của trang web. CSS mang lại cho trang web của bạn phong cách mà bạn muốn. CSS gần như tạo nên bộ mặt của một website. − Cũng giống như HTML, CSS không phải là một ngôn ngữ lập trình. 1.1.3 JavaScript là gì? − JS (viết tắt của Javascript) là một nền tảng (cross-platform), ngôn ngữ kịch bản hướng đối tượng (object-oriented). Nó là một ngôn ngữ nhỏ và nhẹ. Chạy trong môi trường máy chủ lưu trữ (ví dụ: trình duyệt web), JavaScript có thể được kết nối với các đối tượng của môi trường để cung cấp kiểm soát chương trình đối với chúng. − JavaScript là ngôn ngữ lập trình dựa trên logic. Nó có thể được sử dụng để sửa đổi nội dung trang web. Và khiến nó hoạt động theo nhiều cách khác nhau để đáp ứng với hành động của người dùng. Các cách sử dụng phổ biến cho JavaScript bao gồm các hộp xác nhận, kêu gọi hành động và thêm các danh tính mới vào thông tin hiện có. 1.2 Bootstrap 1.2.1 Bootstrap là gì? − Bootstrap là một front-end framework miễn phí giúp quá trình phát triển web nhanh chóng và dễ dàng hơn. − Bootstrap bao gồm các mẫu thiết kế dựa trên HTML và CSS như typography, forms, buttons, tables, navigation, modals, image carousels cũng như các plugin JavaScript tùy chọn. − Bootstrap cũng cung cấp cho bạn khả năng tạo ra các responsive designs một cách dễ dàng. 8 1.2.2 Tại sao nên dùng Bootstrap? − Dễ sử dụng: Bất kỳ ai có kiến thức cơ bản về HTML và CSS đều có thể bắt đầu sử dụng Bootstrap. − Các tính năng đáp ứng (Responsive features): responsive CSS của Bootstrap điều chỉnh cho điện thoại, máy tính bảng và máy tính để bàn. − Khả năng tương thích trình duyệt: Bootstrap tương thích với tất cả các trình duyệt hiện đại (Chrome, Firefox, Internet Explorer, Edge, Safari và Opera). − Tiết kiệm thời gian: Bootstrap giúp cho lập trình viên thiết kế giao diện website tiết kiệm rất nhiều thời gian và công sức, bởi các thư viện của Bootstrap có nhiều đoạn mã có thể sẵn sàng áp dụng ngay vào website. Khi đó sẽ tiết kiệm được rất nhiều thời gian để tự viết code cho giao diện website của bản thân. 1.3 JQuery 1.3.1 JQuery là gì? − JQuery là thư viện được viết từ JavaScript, jQuery giúp xây dựng các chức năng bằng Javascript dễ dàng, nhanh và giàu tính năng hơn. jQuery được tích hợp nhiều module khác nhau. Từ module hiệu ứng cho đến module truy vấn selector. jQuery được sử dụng đến 99% trên tổng số website trên thế giới. − JQuery không phải là một ngôn ngữ lập trình riêng biệt mà hoạt động liên kết với JavaScript. Với jQuery, bạn có thể làm được nhiều việc hơn mà lại tốn ít công sức hơn. 1.3.2 Tại sao nên dùng jQuery? − Gọn nhẹ: jQuery là một thư viện khá gọn nhẹ – có kích cỡ khoảng 19KB. 9 − Tương thích đa nền tảng: Nó tự động sửa lỗi và chạy được trên mọi trình duyệt phổ biến như Chrome, Firefox, Safari, MS Edge, IE, Android và iOS. − Dễ dàng tạo Ajax: Nhờ thư viện jQuery, code được viết bởi Ajax có thể dễ dàng tương tác với server và cập nhật nội dung tự động mà không cần phải tải lại trang. − Xử lý nhanh nhạy thao tác DOM: jQuery giúp lựa chọn các phần tử DOM để traverse (duyệt) một cách dễ dàng, và chỉnh sửa nội dung của chúng bằng cách sử dụng Selector mã nguồn mở, mà còn được gọi là Sizzle. − Đơn giản hóa việc tạo hiệu ứng: Giống với code snippet có hiệu ứng animation, nó phủ các dòng code và bạn chỉ việc thêm biến/nội dung vào thôi. − Hỗ trợ tốt phương thức sự kiện HTML: Xử lý sự kiện − jQuery xử lý các sự kiện đa dạng mà không làm cho HTML code trở nên lộn xộn với các Event Handler. 1.4 Ajax 1.4 Ajax là gì? − AJAX là chữ viết tắt của Asynchronous JavaScript and XML. Đây là một công nghệ giúp chung ta tạo ra những Web động mà hoàn toàn không reload lại trang. − Cả JavaScript và XML đều hoạt động bất đồng bộ trong AJAX. Kết quả là, nhiều ứng dụng web có thể sử dụng AJAX để gửi và nhận data từ server mà không phải toàn bộ trang. 10 1.4.2 Tại sao nên dùng Ajax? − Callbacks: Ajax được sử dụng để thực hiện một cuộc gọi lại. AJAX thực hiện việc truy xuất và / hoặc lưu dữ liệu mà không gửi toàn bộ trang trở lại máy chủ. Bằng cách gửi lại một phần trang web đến máy chủ, việc sử dụng mạng được giảm thiểu và các hoạt động diễn ra nhanh hơn. Trong các trang web băng thông hạn chế, điều này có thể cải thiện đáng kể hiệu suất mạng. Dữ liệu được gửi đến và đi từ máy chủ một cách tối thiểu. − Thực hiện các cuộc gọi không đồng bộ: Ajax cho phép bạn thực hiện các cuộc gọi không đồng bộ đến một máy chủ web. Điều này cho phép trình duyệt của người dùng tránh phải chờ tất cả dữ liệu đến trước khi cho phép người dùng hành động một lần nữa. − Thân thiện với người dùng: Vì không phải post lại trang lên server, các ứng dụng hỗ trợ Ajax sẽ luôn nhanh hơn và thân thiện với người dùng hơn. − Tăng tốc độ: Mục đích chính của Ajax là cải thiện tốc độ, hiệu suất và khả năng sử dụng của một ứng dụng web. Một ví dụ tuyệt vời của Ajax là tính năng xếp hạng phim trên Netflix. Người dùng đánh giá một bộ phim và xếp hạng cá nhân của họ cho bộ phim đó sẽ được lưu vào cơ sở dữ liệu của họ mà không cần chờ trang làm mới hoặc tải lại. 1.5 Lararel 1.5.1 Laravel là gì? − Là một framework PHP có mã nguồn mở miễn phí, giúp xây dựng các ứng dụng theo mô hình MVC (Model - View – Controller) một cách nhanh chóng, được tạo ra bởi một lập trình viên kỳ cựu từng làm .NET 11 đó là Taylor Otwell. Được phát hành lần đầu vào ngày 9 tháng 6 năm 2011. Các phiên bản của laravel đến tháng 4 năm 2020 − Trước đây Laravel có tên là Bootplant sau đó thì đổi thành là Laravel, nguồn gốc tên bắt nguồn từ tên một tòa lâu đài ở Narnia, một vùng đất không có thật, mà nó ở trong một thế giới được tưởng tượng ra 12 bởi nhà văn Clive Staples Lewis, và viết thành cuốn tiểu thuyết “Biên niên sử Narnia” [4] rất nổi tiếng được dựng thành phim. Tòa lâu đài có tên là Paravel đọc lái đi sẽ thành Laravel, mục đích của Taylor Otwell là mong muốn đứa con tinh thần Laravel phát triển một cách mạnh mẽ và vững trải như tòa lâu đài. Và rồi đến tận bây giờ thì Laravel vẫn luôn là một trong những framework tốt nhất của PHP. 1.5.2 Tại sao nên dùng Laravel? − Laravel có thể xây dựng hệ thống các ứng dụng web phức tạp với hiệu năng cao. Cho dù laravel rất đơn giản và dễ dàng cho người mới tiếp cận với framework PHP nhưng vẫn đảm bảo hệ thống có kiến trúc thống nhất và khoa học. − Cộng đồng Laravel rất lớn trên Laracast, bạn có thể tìm câu trả lời cho những vấn đề, tình huống mà bạn thắc mắc hay là không biết trong Laravel. Không những thế các tài nguyên liên quan đến Laravel cũng rất đa dạng, dễ sử dụng. Tác giả của framework này -Taylor Otwell cũng đã biên soạn ra tài liệu để cho các lập trình viên khám phá và trải nghiệm. − Có tích hợp công cụ dòng lệnh là Artisan, hỗ trợ rất nhiều trong việc phát triển ứng dụng: tối ưu hóa ứng dụng, migrate dữ liệu, tạo các template, controller, − Trong Laravel có một bộ máy template rất hay, đó là blade template, giúp thực hiện làm việc tương tác giữa PHP và HTML đơn giản hơn, tách biệt hơn giữa mã hiển thị và mã logic nghiệp, cái mà trước đó chỉ có thể biết đến ở .NET hoặc Java. Blade template còn có thể kế thừa một template khác và có thể còn script js, jquery − Laravel sử dụng gói thư viện Webpack kết hợp với npm, yarn... nhằm giúp bạn tự động hóa thay vì build thủ công các ứng dụng và triển 13 khai sản phẩm. Từ đó có thể thấy được Laravel hỗ trợ việc các đặt các gói thư viện và sử dụng nhằm tạo ra các tính năng tuyệt vời. − Laravel rất an toàn trong việc chỉn chu bảo mật với CSRF tokens. Với cách kiểm tra mã CSRF trong mỗi POST, về cơ bản là đã bảo vệ chương trình khi bị cố tình thay đổi bản chất, kể cả từ POST đến GET. Ngoài ra Laravel còn cung cấp sẵn các Middleware cho trước hoặc lập trình viên có thể được hỗ trợ để tạo riêng cho mình một Middleware nhằm mục đích tăng thêm độ bảo mật cho ứng dụng website. − Laravel hỗ trợ lập trình theo mô hình MVC khá mạnh mẽ. Ngoài ...ời dùng password VarChar Mật khẩu của người dùng, được mã hóa created_at TimeStamp Thời gian tài khoản được tạo updated_at TimeStamp Thời gian tài khoản được sửa đổi Bảng Table infoct Tên trường Kiểu dữ liệu Mô tả ID Int Xác định từng bản ghi riêng TenCT Text Tên công ty DiaChi Text Địa chỉ của công ty SDT VarChar Số điện thoại liên hệ công ty FB VarChar Facebook liên hệ công ty Email VarChar Email liên hệ công ty HinhAnh VarChar Hình ảnh về công ty GioiThieu MediumText Bài đăng giới thiệu về công ty Bảng Table thanhpham Tên trường Kiểu dữ liệu Mô tả ID Int Xác định từng bản ghi riêng TenTP Text Tên thành phẩm đã hoàn thiện DiaChi Text Địa chỉ của khách hàng TomTat Text Tóm tắt về bài đăng thành phẩm NoiDung MediumText Nội dung bài đăng thành phẩm TenKH Text Tên khách hàng 60 NhanXet Text Nhận xét của khách hàng về thành phẩm AnhKH VarChar Ảnh khách hàng AnhTP VarChar Ảnh thành phẩm Bảng Table baogia Tên trường Kiểu dữ liệu Mô tả ID Int Xác định từng bản ghi riêng HoTen Text Họ tên khách hàng yêu cầu nhận báo giá DiaChi Text Địa chỉ khách hàng yêu cầu nhận báo giá SDT VarChar Số điện thoại khách hàng yêu cầu nhận báo giá GhiChu Text Nội dung yêu cầu của khách hàng DaXem Int Đánh dấu tin yêu cầu đã đọc hay chưa created_at TimeStamp Thời gian yêu cầu được tạo updated_at TimeStamp Thời gian yêu cầu được sửa đổi Bảng Table sanpham Tên trường Kiểu dữ liệu Mô tả ID Int Xác định từng bản ghi riêng TenSP Text Tên sản phẩm công ty cung cấp TomTat Text Tóm tắt về bài đăng MoTa MediumText Nội dung bài đăng NhaSX Text Nhà sản xuất ra sản phẩm mà công ty cung cấp AnhTD Varchar Ảnh đại diện sản phẩm NoiBat Int Đánh dấu sản phẩm có nổi bật hay không 61 Bảng Table loaisanpham Tên trường Kiểu dữ liệu Mô tả ID Int Xác định từng bản ghi riêng TenLoai Text Tên loại sản phẩm công ty cung cấp MoTa Text Mô tả về loại sản phẩm HinhAnh VarChar Hình ảnh loại sản phẩm Bảng Table loaisanpham_sanpham Tên trường Kiểu dữ liệu Mô tả ID Int Xác định từng bản ghi riêng sanpham_id Int ID sản phẩm liên kết với ID của bản sanpham loaisanpham_id Int ID loại sản phẩm liên kết với ID của bản loaisanpham Bảng Table hinhsanpham Tên trường Kiểu dữ liệu Mô tả ID Int Xác định từng bản ghi riêng IDSanPham Int ID sản phẩm liên kết với ID của bản sanpham HinhAnh Varchar Hình ảnh của sản phẩm Bảng Table nhanxet Tên trường Kiểu dữ liệu Mô tả ID Int Xác định từng bản ghi riêng 62 IDSanPham Int ID sản phẩm liên kết với ID của bản sanpham HoTen Text Họ tên người đăng nhận xét NoiDung Text Nội dung nhận xét created_at TimeStamp Thời gian nhận xét được tạo updated_at TimeStamp Thời gian nhận xét được sửa 63 5.2 Mối quan hệ giữa các bản dữ liệu Các bản dữ liệu có mối quan hệ với nhau 5.3 Thiết kế giao diện Website – Front-End − Danh sách các trang: + Trang chủ. Trang chủ website Viko 64 Mục giới thiệu trên trang chủ Mục sản phẩm trên trang chủ 65 Mục sản phẩm nổi bật trên trang chủ Mục tiêu chí hoạt động trên trang chủ 66 Mục dự án đã thực hiên trên trang chủ Mục khách hàng nói về chúng tôi trên trang chủ 67 Mục liên hệ trên trang chủ + Trang danh sách sản phẩm. Trang danh sách sản phẩm 68 Mục lọc sản phẩm trên trang danh sách sản phẩm + Trang chi tiết sản phẩm. Trang chi tiết sản phẩm 69 Mục bài viết trên trang chi tiết sản phẩm Mục bài viết trên trang chi tiết sản phẩm 70 Mục nhận xét cùng mục sản phẩm cùng loại trên trang chi tiết sản phẩm + Trang danh sách dự án thực hiện. Trang danh sách dự án đã thưc hiện 71 Mục các danh sách dự án đã thực hiện trên trang dự án đã thực hiện + Trang chi tiết dự án. Trang chi tiết dự án 72 Mục bài viết trên trang chi tiết dự án Mục các dự án khác trên trang chi tiết dự án + Trang đăng nhập Admin. Trang đăng nhập Admin 73 + Trang Admin. Trang Admin + Trang thêm loại sản phẩm (Admin). Trang thêm loại sản phẩm 74 + Trang danh sách loại sản phẩm (Admin). Trang danh sách loại sản phẩm + Trang sửa loại sản phẩm(Admin). Trang sửa loại sản phẩm 75 + Trang thêm sản phẩm (Admin). Trang thêm sản phẩm 76 + Trang danh sách sản phẩm (Admin). Trang danh sách sản phẩm 77 + Trang sửa sản phẩm (Admin). Trang sửa sản phẩm 78 + Trang cập nhập hình ảnh sản phẩm liên quan (Admin). Trang cập nhập hình ảnh sản phẩm liên quan 79 + Trang thêm dự án đã thực thiện (Admin). Trang thêm dự án đã thực hiện 80 + Trang danh sách dự án đã thực thiện (Admin). Trang danh sách dự án đã thực hiện 81 + Trang sửa dự án đã thực thiện (Admin). Trang sửa dự án đã thực hiện 82 + Trang cập nhập thông tin công ty (Admin). Trang cập nhật thông tin công ty 83 + Trang danh sách yêu cầu báo giá sản phẩm (Admin). Trang danh sách yêu cầu báo giá + Trang sửa thông tin tài khoản (Admin). Trang sửa thông tin tài khoản + Trang báo lỗi Not Found. Trang báo lỗi Not Found khi không tìm thấy trang 84 5.4 Lập trình Website – Back-End với Laravel − Tạo các Route định hướng request cho trang người dùng: − Route::get('/home','HomeController@getHome') ->name('home'); − Route::post('/tim-kiem', 'HomeController@postSearchAjax')- >name('timkiem'); − Route::post('/nhan-bao-gia', 'HomeController@postBaoGia')- >name('baogia'); − Route::get('/du-an','ShowDuAnController@getDuAn') - >name('duan'); − Route::get('/du-an/chi- tiet/{id}','ShowDuAnController@getChiTiet') - > name('chitietduan'); − Route::get('/san- pham/{id?}','ShowSanPhamController@getDanhSach') - >name('sanpham'); − Route::get('/san-pham/chi- tiet/{id}','ShowSanPhamController@getChiTiet') - >name('chitietsanpham'); − Route::post('/san-pham/chi-tiet/them-nhan- xet/{id}','ShowSanPhamController@postNhanXet') - >name('nhanxet'); − Tạo các Route định hướng request kết hợp cùng Middleware để kiểm tra đăng nhập cho trang admin: − Route::get('/admin/dang-nhap','UserController@getDangNhap'); − Route::post('/admin/dang-nhap','UserController@postDangNhap')- >name('postdangnhap'); 85 − Route::get('/admin/dang-xuat','UserController@getDangXuat')- >name('getdangxuat'); − Route::group(['prefix'=>'admin','middleware'=>'AdminLogin'],funct ion () { − Route::group(['prefix'=>'loai-san-pham'],function () { − Route::get('/danh-sach','TheLoaiController@getDanhSach') - >name('dsloaisp'); − Route::get('/them','TheLoaiController@getThem') - >name('getthemloaisp'); − Route::post('/them','TheLoaiController@postThem') - >name('postthemloaisp'); − Route::get('/sua/{id}','TheLoaiController@getSua') - >name('getsualoaisp'); − Route::post('/sua/{id}','TheLoaiController@postSua') - >name('postsualoaisp'); − Route::get('/xoa/{id}','TheLoaiController@postXoa') - >name('postxoaloaisp'); − }); − Route::group(['prefix'=>'du-an-da-thuc-hien'],function () { − Route::get('/danh-sach','DuAnController@getDanhSach') - >name('dsduan'); − Route::get('/them','DuAnController@getThem') - >name('getthemduan'); − Route::post('/them','DuAnController@postThem') - >name('postthemduan'); 86 − Route::get('/sua/{id}','DuAnController@getSua') - >name('getsuaduan'); − Route::post('/sua/{id}','DuAnController@postSua') - >name('postsuaduan'); − Route::get('/xoa/{id}','DuAnController@postXoa') - >name('postxoaduan'); − Route::get('/noi-dung/{id}','DuAnController@getNoiDung') - >name('getndduan'); − }); − Route::group(['prefix'=>'thong-tin-cong-ty'],function () { − Route::get('/sua/{id}','InfoCtController@getSua') - >name('getsuainfoct'); − Route::post('/sua/{id}','InfoCtController@postSua') - >name('postsuainfoct'); − }); − Route::group(['prefix'=>'san-pham'],function () { − Route::get('/danh-sach','SanPhamController@getDanhSach') - >name('dssanpham'); − Route::get('/them','SanPhamController@getThem') - >name('getthemsanpham'); − Route::post('/them','SanPhamController@postThem') - >name('postthemsanpham'); − Route::get('/sua/{id}','SanPhamController@getSua') - >name('getsuasanpham'); − Route::post('/sua/{id}','SanPhamController@postSua') - >name('postsuasanpham'); 87 − Route::get('/xoa/{id}','SanPhamController@postXoa') - >name('postxoasanpham'); − Route::get('/xoacmt/{id}','SanPhamController@postXoaCmt') - >name('postxoacmt'); − Route::get('/noi- dung/{id}','SanPhamController@getNoiDung') - >name('getndsanpham'); − Route::get('/tom-tat/{id}','SanPhamController@getTomTat') - >name('getttsanpham'); − Route::get('/hinh- anh/{id}','SanPhamController@getHinhAnh') - >name('gethasanpham'); − Route::post('/hinh- anh/{id}','SanPhamController@postHinhAnh') - >name('posthasanpham'); − }); − Route::group(['prefix'=>'user'],function () { − Route::get('/sua/{id}','UserController@getSua') - >name('getsuauser'); − Route::post('/sua/{id}','UserController@postSua') - >name('postsuauser'); − }); − Route::group(['prefix'=>'bao-gia'],function () { − Route::get('/danh-sach','BaoGiaController@getDanhSach') - >name('dsbaogia'); 88 − Route::get('/xoa/{id}','BaoGiaController@postXoa') - >name('postxoabaogia'); − Route::get('/chi-tiet/{id}','BaoGiaController@getChiTiet') - >name('getchitietbaogia'); − }); − }); − Tạo Middleware AdminLogin để xác nhận đăng nhập: − <?php − − namespace App\Http\Middleware; − − use Closure; − use Illuminate\Support\Facades\Auth; − class AdminLogin − { − /** − * Handle an incoming request. − * − * @param \Illuminate\Http\Request $request − * @param \Closure $next − * @return mixed − */ − public function handle($request, Closure $next) − { − if(Auth::check()){ 89 − return $next($request); − } − else{ − return redirect("admin/dang-nhap"); − } − } − } − Tạo các Eloquent ORM tương ứng với từng bảng trong Database, thông qua đó mỗi bảng trong Database sẽ là một Model giúp cho việc thao tác với Database một cách dễ dàng: + Bảng baogia: + <?php + + namespace App; + + use Illuminate\Database\Eloquent\Model; + + class baogia extends Model + { + // + protected $table = 'baogia'; + public $primaryKey = 'ID'; + } + 90 + Bảng thanhpham: + <?php + + namespace App; + + use Illuminate\Database\Eloquent\Model; + + class thanhpham extends Model + { + // + protected $table = 'thanhpham'; + public $timestamps = false; + public $primaryKey = 'ID'; + } + + Bảng infoct: + <?php + + namespace App; + + use Illuminate\Database\Eloquent\Model; + + class infoct extends Model + { + // 91 + protected $table = 'infoct'; + public $timestamps = false; + public $primaryKey = 'ID'; + } + Bảng tai_khoans: + <?php + + namespace App; + + use Illuminate\Notifications\Notifiable; + use Illuminate\Contracts\Auth\MustVerifyEmail; + use Illuminate\Foundation\Auth\User as Authenticatable; + + class tai_khoan extends Authenticatable + { + // + use Notifiable; + + /** + * The attributes that are mass assignable. + * + * @var array + */ + protected $fillable = [ + 'tendn','tenuser', 'password', + ]; 92 + + /** + * The attributes that should be hidden for arrays. + * + * @var array + */ + protected $hidden = [ + 'password', 'remember_token', + ]; + } + + Bảng sanpham: + <?php + + namespace App; + + use Illuminate\Database\Eloquent\Model; + + class sanpham extends Model + { + // + protected $table = 'sanpham'; + public $timestamps = false; + public $primaryKey = 'ID'; + public function loaisanpham(){ 93 + return $this- >belongsToMany('App\loaisanpham','loaisanpham_sanpham','sa npham_id','loaisanpham_id'); + } + + public function hinhsanpham(){ + return $this- >hasMany('App\hinhsanpham','IDSanPham','ID'); + } + + public function nhanxet(){ + return $this -> hasMany('App\nhanxet','IDSanPham','ID'); + } + } + + Bảng loaisanpham: + <?php + + namespace App; + + use Illuminate\Database\Eloquent\Model; + + class loaisanpham extends Model + { + // 94 + protected $table = 'loaisanpham'; + public $timestamps = false; + public $primaryKey = 'ID'; + + public function sanpham(){ + return $this- >belongsToMany('App\sanpham','loaisanpham_sanpham','loaisa npham_id','sanpham_id'); + } + } + + Bảng nhanxet: + <?php + + namespace App; + + use Illuminate\Database\Eloquent\Model; + + class nhanxet extends Model + { + // + protected $table = 'nhanxet'; + public $primaryKey = 'ID'; + public function sanpham(){ + return $this -> belongsTo('App\sanpham','IDSanPham','ID'); 95 + } + } + + Bảng hinhsanpham: + <?php + + namespace App; + + use Illuminate\Database\Eloquent\Model; + + class hinhsanpham extends Model + { + // + protected $table = 'hinhsanpham'; + public $timestamps = false; + public $primaryKey = 'ID'; + + public function sanpham(){ + return $this -> belongsTo('App\sanpham','IDSanPham','ID'); + } + } − Tạo các Controller để xử lý, điều hướng giữa Model và View sau khi nhận request thông qua Route từ trình duyệt: 96 + BaoGiaController: + <?php + + namespace App\Http\Controllers; + + use Illuminate\Http\Request; + use App\baogia; + + class BaoGiaController extends Controller + { + // + public function getDanhSach(){ + $baogias = baogia::all(); + return view('admin.baogia.danhsachbaogia',['dsbaogias'=>$ baogias]); + } + public function postXoa(Request $request){ + $query = $request ->id; + $baogia = baogia::find($query); + if(isset($baogia)){ + $baogia ->delete(); + return redirect('admin/bao-gia/danh-sach') - >with('thongbao','Xóa thành công'); + } + else{ + return view('admin.erorr.notfound'); 97 + } + } + public function getChiTiet(Request $request){ + $query = $request ->id; + $ctbaogia = baogia::find($query); + if(isset($ctbaogia)){ + $ctbaogia ->DaXem=1; + $ctbaogia ->save(); + return view('admin.baogia.chitietbaogia',['ctbaogia'=>$ctbao gia]); + } + else{ + return view('admin.erorr.notfound'); + } + } + } + DuAnController: + <?php + + namespace App\Http\Controllers; + + use Illuminate\Http\Request; + use App\thanhpham; + use SebastianBergmann\Environment\Console; + 98 + class DuAnController extends Controller + { + // + public function getDanhSach(){ + $thanhpham = thanhpham::all(); + return view('admin.thanhpham.danhsachduan',['thanhphams' => $thanhpham]); + } + public function getThem(){ + return view('admin.thanhpham.themduan'); + } + public function postThem(Request $request){ + if($request ->hasFile('file')){ + $hinhanh = $request ->file('file'); + $name = $hinhanh ->getClientOriginalName(); + $destinationPath = 'img/'; + if (!file_exists($destinationPath)) { + mkdir($destinationPath, 0755, true); + } + $hinhanh->move($destinationPath, $name); + } + else if($request ->input('anhtieude')!="" && $request - >input('anhkh')!="" && $request - >input('noidung')!="" && $request ->input('nhanxet')!=""){ + $this -> validate($request,[ + 'tenduan' =>'required|min:2|max:50', 99 + 'diachi' =>'required|min:2|max:100', + 'tenkh' =>'required|min:2|max:50', + 'nhanxet' =>'required|min:2', + 'noidung' =>'required|min:2', + 'tomtat' =>'required|min:2|max:300', + ], + [ + 'tenduan.required'=>'Bạn chưa nhập tên dự án', + 'tenduan.min'=>'Tên dự án phải có độ dài lớn hơn 1 ký tự', + 'tenduan.max'=>'Tên dự án phải có độ dài nhỏ hơn 50 ký tự', + 'diachi.required'=>'Bạn chưa nhập địa chỉ', + 'diachi.min'=>'Địa chỉ phải có độ dài lớn hơn 1 ký tự', + 'diachi.max'=>'Địa chỉ phải có độ dài nhỏ hơn 100 ký t ự', + 'tenkh.required'=>'Bạn chưa nhập tên khách hàng', + 'tenkh.min'=>'Tên khách hàng phải có độ dài lớn hơn 1 ký tự', + 'tenkh.max'=>'Tên khách hàng có độ dài nhỏ hơn 50 ký tự', + 'nhanxet.required'=>'Bạn chưa nhập nhận xét', + 'nhanxet.min'=>'Nhận xét phải có độ dài lớn hơn 1 ký t ự', + 'noidung.required'=>'Bạn chưa nhập nội dung', 100 + 'noidung.min'=>'Nội dung phải có độ dài lớn hơn 1 ký tự', + 'tomtat.required'=>'Bạn chưa nhập tóm tắt', + 'tomtat.min'=>'Tóm tắt phải có độ dài lớn hơn 1 ký tự', + 'tomtat.max'=>'Tóm tắt phải có độ dài nhỏ hơn 300 ký tự', + ]); + $thanhpham = new thanhpham; + $thanhpham -> TenTP = $request -> tenduan; + $thanhpham -> DiaChi = $request -> diachi; + $thanhpham -> NoiDung = $request -> noidung; + $thanhpham -> TenKH = $request -> tenkh; + $thanhpham -> NhanXet = $request -> nhanxet; + $thanhpham -> TomTat =$request -> tomtat; + $thanhpham -> AnhKH = $request -> anhkh; + $thanhpham -> AnhTP = $request -> anhtieude; + $thanhpham ->save(); + return redirect('/admin/du-an-da-thuc-hien/them') - > with('thongbao','Thêm thành công'); + + } + else{ + return redirect('/admin/du-an-da-thuc-hien/them')- > with('err','Bạn cần thêm đầy đủ các trường bắt buộc'); + } + } 101 + public function postXoa(Request $request){ + $query = $request ->id; + $thanhpham = thanhpham::find($query); + if(isset($thanhpham)){ + $image_path1 = "img/".$thanhpham -> AnhKH; + $image_path2 = "img/".$thanhpham -> AnhTP; + + if (file_exists($image_path1)) { + + @unlink($image_path1); + } + if (file_exists($image_path2)) { + + @unlink($image_path2); + } + $thanhpham ->delete(); + return redirect('/admin/du-an-da-thuc-hien/danh-sach') - >with('thongbao','Xóa thành công'); + } + else{ + return view('admin.erorr.notfound'); + } + } + public function getSua(Request $request){ + $query = $request ->id; + $thanhpham = thanhpham::find($query); 102 + if(isset($thanhpham)){ + return view('admin.thanhpham.suaduan',['thanhpham'=>$tha nhpham]); + } + else{ + return view('admin.erorr.notfound'); + } + } + public function postSua(Request $request){ + $query = $request ->id; + $thanhpham = thanhpham::find($query); + if($request ->hasFile('file')){ + $hinhanh = $request ->file('file'); + $name = $hinhanh ->getClientOriginalName(); + $destinationPath = 'img/'; + if (!file_exists($destinationPath)) { + mkdir($destinationPath, 0755, true); + } + $hinhanh->move($destinationPath, $name); + } + else if($request ->input('tenduan')!="" && $request - >input('diachi')!=""&& $request - >input('tenkh')!="" && $request - >input('nhanxet')!="" && $request ->input('noidung')!=""){ + $this -> validate($request,[ + 'tenduan' =>'required|min:2|max:50', 103 + 'diachi' =>'required|min:2|max:100', + 'tenkh' =>'required|min:2|max:50', + 'nhanxet' =>'required|min:2', + 'noidung' =>'required|min:9', + 'tomtat' =>'required|min:2|max:300', + ], + [ + 'tenduan.required'=>'Bạn chưa nhập tên dự án', + 'tenduan.min'=>'Tên dự án phải có độ dài lớn hơn 1 ký tự', + 'tenduan.max'=>'Tên dự án phải có độ dài nhỏ hơn 50 ký tự', + 'diachi.required'=>'Bạn chưa nhập địa chỉ', + 'diachi.min'=>'Địa chỉ phải có độ dài lớn hơn 1 ký tự', + 'diachi.max'=>'Địa chỉ phải có độ dài nhỏ hơn 100 ký t ự', + 'tenkh.required'=>'Bạn chưa nhập tên khách hàng', + 'tenkh.min'=>'Tên khách hàng phải có độ dài lớn hơn 1 ký tự', + 'tenkh.max'=>'Tên khách hàng có độ dài nhỏ hơn 50 ký tự', + 'nhanxet.required'=>'Bạn chưa nhập nhận xét', + 'nhanxet.min'=>'Nhận xét phải có độ dài lớn hơn 1 ký t ự', + 'noidung.required'=>'Bạn chưa nhập nội dung', 104 + 'noidung.min'=>'Nội dung phải có độ dài lớn hơn 1 ký tự', + 'tomtat.required'=>'Bạn chưa nhập tóm tắt', + 'tomtat.min'=>'Tóm tắt phải có độ dài lớn hơn 1 ký tự', + 'tomtat.max'=>'Tóm tắt phải có độ dài nhỏ hơn 300 ký tự', + ]); + $thanhpham -> TenTP = $request -> tenduan; + $thanhpham -> DiaChi = $request -> diachi; + $thanhpham -> TenKH = $request -> tenkh; + $thanhpham -> NhanXet = $request -> nhanxet; + $thanhpham -> TomTat =$request -> tomtat; + $thanhpham -> NoiDung = $request -> noidung; + if($request -> anhtieude !="" && $request - > anhtieude != $thanhpham -> AnhTP){ + $image_path = "img/".$thanhpham -> AnhTP; + + if (file_exists($image_path)) { + + @unlink($image_path); + } + $thanhpham -> AnhTP =$request -> anhtieude; + } + if($request -> anhkh !="" && $request - > anhkh != $thanhpham -> AnhKH){ + $image_path = "img/".$thanhpham -> AnhKH; 105 + + if (file_exists($image_path)) { + + @unlink($image_path); + } + $thanhpham -> AnhKH =$request -> anhkh; + } + $thanhpham ->save(); + return view('admin.thanhpham.suaduan',['thanhpham'=>$ thanhpham]) -> with('thongbao','Sửa thành công'); + + } + else{ + return view('admin.thanhpham.suaduan',['thanhpham'=>$ thanhpham]) -> with('err','Bạn không được bỏ trống nội dung'); + } + } + public function getNoiDung(Request $request){ + $query = $request ->id; + $thanhpham = thanhpham::find($query); + if(isset($thanhpham)){ + return view('admin.thanhpham.noidungduan',['thanhpham' = > $thanhpham]); + } + else{ + return view('admin.erorr.notfound'); 106 + } + } + } + InfoCtController: + <?php + + namespace App\Http\Controllers; + + use Illuminate\Http\Request; + use App\infoct; + use SebastianBergmann\Environment\Console; + + class InfoCtController extends Controller + { + // + public function getSua(){ + $info = infoct::all() ->first(); + return view('admin.thongtinct.thongtinct',['info'=>$info]); + } + public function postSua(Request $request){ + $query = $request ->id; + $info = infoct::find($query); + if($request ->hasFile('file')){ + $hinhanh = $request ->file('file'); + $name = $hinhanh ->getClientOriginalName(); 107 + $destinationPath = 'img/'; + if (!file_exists($destinationPath)) { + mkdir($destinationPath, 0755, true); + } + $hinhanh->move($destinationPath, $name); + } + else if($request ->input('tenct')!="" && $request - >input('diachi')!=""&& $request ->input('gioithieu')!="" + && $request ->input('sdt')!="" && $request - >input('fb')!="" && $request ->input('email')!=""){ + $this -> validate($request,[ + 'tenct' =>'required|min:2|max:50|', + 'diachi' =>'required|min:2|max:100|', + 'sdt' =>'required|numeric|digits_between:3,10', + 'fb' =>'required|min:2|max:100|', + 'email' =>'required|email|', + 'gioithieu' =>'required|min:2|', + ], + [ + 'tenct.required'=>'Bạn chưa nhập tên công ty', + 'tenct.min'=>'Tên công ty phải có độ dài lớn hơn 1 ký t ự', + 'tenct.max'=>'Tên công ty phải có độ dài nhỏ hơn 50 k ý tự', + 'diachi.required'=>'Bạn chưa nhập địa chỉ', + 'diachi.min'=>'Địa chỉ phải có độ dài lớn hơn 1 ký tự', 108 + 'diachi.max'=>'Địa chỉ phải có độ dài nhỏ hơn 100 ký t ự', + 'sdt.required'=>'Bạn chưa nhập số điện thoại', + 'sdt.numeric'=>'Số điện thoại chỉ bao gồm số', + 'sdt.digits_between'=>'Số điện thoại phải lớn hơn 2 số và nhỏ hơn 11 số', + 'fb.required'=>'Bạn chưa nhập thông tin facebook', + 'fb.min'=>'Thông tin facebook phải có độ dài lớn hơn 1 ký tự', + 'fb.max'=>'Thông tin facebook phải có độ dài nhỏ hơn 100 ký tự', + 'email.required'=>'Bạn chưa nhập thông tin email', + 'email.email'=>'Email không hợp lệ', + 'gioithieu.required'=>'Bạn chưa nhập giới thiệu', + 'gioithieu.min'=>'Gới thiệu phải có độ dài lớn hơn 1 ký tự', + ]); + $info -> TenCT = $request -> tenct; + $info -> DiaChi = $request -> diachi; + $info -> SDT = $request -> sdt; + $info-> FB = $request -> fb; + $info -> Email = $request -> email; + $info -> GioiThieu = $request -> gioithieu; + if($request -> anhct !="" && $request -> anhct != $info - > HinhAnh){ + $image_path = "img/".$info -> HinhAnh; 109 + + if (file_exists($image_path)) { + + @unlink($image_path); + } + $info -> HinhAnh =$request -> anhct; + } + $info ->save(); + return view('admin.thongtinct.thongtinct',['info'=>$info]) -> with('thongbao','Sửa thành công'); + + } + else{ + return view('admin.thongtinct.thongtinct',['info'=>$info]) -> with('err','Bạn không được bỏ trống phần giới thiệu'); + } + } + } + + SanPhamController: + <?php + + namespace App\Http\Controllers; + + use Illuminate\Http\Request; 110 + use App\sanpham; + use App\loaisanpham; + use App\hinhsanpham; + use App\nhanxet; + class SanPhamController extends Controller + { + // + public function getDanhSach() { + $sanpham = sanpham::all(); + return view('admin.sanpham.danhsachsanpham',['sanphams' => $sanpham]); + } + public function getThem(){ + $loaisanphams =loaisanpham::all(); + return view('admin.sanpham.themsanpham',['loaisanphams' => $loaisanphams]); + } + public function postThem(Request $request){ + if($request ->hasFile('file')){ + $hinhanh = $request ->file('file'); + $name = $hinhanh ->getClientOriginalName(); + $destinationPath = 'img/'; + if (!file_exists($destinationPath)) { + mkdir($destinationPath, 0755, true); + } + $hinhanh->move($destinationPath, $name); 111 + } + else if($request ->input('hinhanh')!="" && $request - >input('noidung')!="" && $request ->input('tomtat')!=""){ + $this -> validate($request,[ + 'tensp' =>'required|min:2|max:50|unique:sanpham,TenS P', + 'tomtat' =>'required|min:9', + 'noidung' =>'required|min:9', + 'nhasx' =>'required|min:2|max:50', + + ], + [ + 'tensp.required'=>'Bạn chưa nhập tên sản phẩm', + 'tensp.min'=>'Tên sản phẩm phải có độ dài lớn hơn 1 k ý tự', + 'tensp.max'=>'Tên sản phẩm phải có độ dài nhỏ hơn 50 ký tự', + 'tensp.unique'=>'Tên sản phẩm đã tồn tại', + 'tomtat.required'=>'Bạn chưa nhập tóm tắt', + 'tomtat.min'=>'Phần tóm tắt phải có độ dài lớn hơn 1 k ý tự', + 'noidung.required'=>'Bạn chưa nhập nội dung', + 'noidung.min'=>'Phần nội dung phải có độ dài lớn hơn 1 ký tự', + 'nhasx.required'=>'Bạn chưa nhập tên nhà sản xuất', 112 + 'nhasx.min'=>'Phần tên nhà sản xuất phải có độ dài lớn hơn 1 ký tự', + 'nhasx.max'=>'Phần tên nhà sản xuất phải có độ dài nh ỏ hơn 50 ký tự', + ]); + $sanpham = new sanpham; + $sanpham -> TenSP = $request -> tensp; + $sanpham -> TomTat = $request -> tomtat; + $sanpham -> MoTa =$request -> noidung; + $sanpham -> NhaSX =$request -> nhasx; + if ( $request->has('noibat')) { + $sanpham ->NoiBat = 1; + } + else{ + $sanpham ->NoiBat = 0; + } + $sanpham -> AnhTD = $request -> hinhanh; + $sanpham ->save(); + $pivot= sanpham::find($sanpham ->ID); + foreach($request ->loaisp as $lsp){ + $pivot ->loaisanpham()->attach($lsp); + } + return redirect('/admin/san-pham/them') - >with('thongbao','Thêm thành công'); + + } 113 + else{ + return redirect('/admin/san-pham/them') - >with('err','Bạn cần nhập đầy đủ các trường bắt buộc'); + } + } + public function postXoa(Request $request){ + $query = $request ->id; + $sanpham = sanpham::find($query); + if(isset($sanpham)){ + $image_path = "img/".$sanpham -> AnhTD; + + if (file_exists($image_path)) { + + @unlink($image_path); + } + $sanpham ->delete(); + return redirect('/admin/san-pham/danh-sach') - >with('thongbao','Xóa thành công'); + } + else{ + return view('admin.erorr.notfound'); + } + } + public function postXoaCmt(Request $request){ + $query = $request ->id; + $cmt = nhanxet::find($query); 114 + if(isset($cmt)){ + $idsanpham =$cmt->IDSanPham; + $cmt ->delete(); + return redirect('/admin/san-pham/sua/'.$idsanpham) - >with('thongbao','Xóa thành công'); + } + else{ + return view('admin.erorr.notfound'); + } + } + public function getSua(Request $request){ + $query = $request ->id; + $sanpham = sanpham::find($query); + if(isset($sanpham)){ + $loaisanphams =loaisanpham::all(); + $comments = $sanpham ->nhanxet()->get(); + $loaidcchons = $sanpham ->loaisanpham()- >select('TenLoai')->get(); + return view('admin.sanpham.suasanpham',['sanpham'=>$san pham,'loaisanphams'=>$loaisanphams,'loaidcchons'=>$loaidcch ons,'comments'=>$comments]); + } + else{ + return view('admin.erorr.notfound'); + } + } 115 + public function postSua(Request $request){ + $query = $request ->id; + $sanpham = sanpham::find($query); + $comments = $sanpham ->nhanxet()->get(); + if($request ->hasFile('file')){ + $hinhanh = $request ->file('file'); + $name = $hinhanh ->getClientOriginalName(); + $destinationPath = 'img/'; + if (!file_exists($destinationPath)) { + mkdir($destinationPath, 0755, true); + } + $hinhanh->move($destinationPath, $name); + } + else if($request ->input('noidung')!="" &&$reque...st ->hinhanh2; + $hinhsp -> save(); + } + if($request ->idanh3=="" && $request - >hinhanh3 !=""&& $request ->hinhanh3 !="xoa"){ + $hinhsp = new hinhsanpham; + $hinhsp ->IDSanPham = $query; + $hinhsp ->HinhAnh =$request ->hinhanh3; + $hinhsp -> save(); + } 122 + if($request ->idanh4=="" && $request - >hinhanh4 !=""&& $request ->hinhanh4 !="xoa"){ + $hinhsp = new hinhsanpham; + $hinhsp ->IDSanPham = $query; + $hinhsp ->HinhAnh =$request ->hinhanh4; + $hinhsp -> save(); + } + if($request ->idanh5=="" && $request - >hinhanh5 !=""&& $request ->hinhanh5 !="xoa"){ + $hinhsp = new hinhsanpham; + $hinhsp ->IDSanPham = $query; + $hinhsp ->HinhAnh =$request ->hinhanh5; + $hinhsp -> save(); + } + //Xoa + if($request ->idanh1!="" && $request - >hinhanh1 =="xoa"){ + $hinhsp = hinhsanpham::find($request ->idanh1); + $image_path = "img/".$hinhsp -> HinhAnh; + + if (file_exists($image_path)) { + + @unlink($image_path); + } + $hinhsp -> delete(); + } 123 + if($request ->idanh2!="" && $request - >hinhanh2 =="xoa"){ + $hinhsp = hinhsanpham::find($request ->idanh2); + $image_path = "img/".$hinhsp -> HinhAnh; + + if (file_exists($image_path)) { + + @unlink($image_path); + } + $hinhsp -> delete(); + } + if($request ->idanh3!="" && $request - >hinhanh3 =="xoa"){ + $hinhsp = hinhsanpham::find($request ->idanh3); + $image_path = "img/".$hinhsp -> HinhAnh; + + if (file_exists($image_path)) { + + @unlink($image_path); + } + $hinhsp -> delete(); + } + if($request ->idanh4!="" && $request - >hinhanh4 =="xoa"){ + $hinhsp = hinhsanpham::find($request ->idanh4); + $image_path = "img/".$hinhsp -> HinhAnh; 124 + + if (file_exists($image_path)) { + + @unlink($image_path); + } + $hinhsp -> delete(); + } + if($request ->idanh5!="" && $request - >hinhanh5 =="xoa"){ + $hinhsp = hinhsanpham::find($request ->idanh5); + $image_path = "img/".$hinhsp -> HinhAnh; + + if (file_exists($image_path)) { + + @unlink($image_path); + } + $hinhsp -> delete(); + } + //Sua + if($request ->idanh1!="" && $request - >hinhanh1 !="xoa"&& $request ->hinhanh1 !=""){ + $hinhsp = hinhsanpham::find($request ->idanh1); + if($request->hinhanh1 != $hinhsp ->HinhAnh){ + $image_path = "img/".$hinhsp -> HinhAnh; + if (file_exists($image_path)) { + 125 + @unlink($image_path); + } + } + $hinhsp ->HinhAnh =$request ->hinhanh1; + $hinhsp -> save(); + } + if($request ->idanh2!="" && $request - >hinhanh2 !="xoa"&& $request ->hinhanh2 !=""){ + $hinhsp = hinhsanpham::find($request ->idanh2); + if($request->hinhanh2 != $hinhsp ->HinhAnh){ + $image_path = "img/".$hinhsp -> HinhAnh; + if (file_exists($image_path)) { + + @unlink($image_path); + } + } + $hinhsp ->HinhAnh =$request ->hinhanh2; + $hinhsp -> save(); + } + if($request ->idanh3!="" && $request - >hinhanh3 !="xoa"&& $request ->hinhanh3 !=""){ + $hinhsp = hinhsanpham::find($request ->idanh3); + if($request->hinhanh3 != $hinhsp ->HinhAnh){ + $image_path = "img/".$hinhsp -> HinhAnh; + if (file_exists($image_path)) { + 126 + @unlink($image_path); + } + } + $hinhsp ->HinhAnh =$request ->hinhanh3; + $hinhsp -> save(); + } + if($request ->idanh4!="" && $request - >hinhanh4 !="xoa"&& $request ->hinhanh4 !=""){ + $hinhsp = hinhsanpham::find($request ->idanh4); + if($request->hinhanh4 != $hinhsp ->HinhAnh){ + $image_path = "img/".$hinhsp -> HinhAnh; + if (file_exists($image_path)) { + + @unlink($image_path); + } + } + $hinhsp ->HinhAnh =$request ->hinhanh4; + $hinhsp -> save(); + } + if($request ->idanh5!="" && $request - >hinhanh5 !="xoa"&& $request ->hinhanh5 !=""){ + $hinhsp = hinhsanpham::find($request ->idanh5); + if($request->hinhanh5 != $hinhsp ->HinhAnh){ + $image_path = "img/".$hinhsp -> HinhAnh; + if (file_exists($image_path)) { + 127 + @unlink($image_path); + } + } + $hinhsp ->HinhAnh =$request ->hinhanh5; + $hinhsp -> save(); + } + $hinhanhs= $sanpham -> hinhsanpham() - >select('ID','HinhAnh')->get(); + return view('admin.sanpham.hinhanhsanpham',['sanpham' = > $sanpham,'hinhanhs' => $hinhanhs]) - >with('thongbao','Cập nhập thành công'); + } + } + + TheLoaiController: + <?php + + namespace App\Http\Controllers; + + use Illuminate\Http\Request; + use App\loaisanpham; + use SebastianBergmann\Environment\Console; + + class TheLoaiController extends Controller + { 128 + // + public function getDanhSach(){ + $loaisp = loaisanpham::all(); + return view('admin.loaisanpham.danhsachloai',['theloais' => $loaisp]); + } + public function getThem(){ + return view('admin.loaisanpham.themloai'); + } + public function postThem(Request $request){ + if($request ->hasFile('file')){ + $hinhanh = $request ->file('file'); + $name = $hinhanh ->getClientOriginalName(); + $destinationPath = 'img/'; + if (!file_exists($destinationPath)) { + mkdir($destinationPath, 0755, true); + } + $hinhanh->move($destinationPath, $name); + } + else if($request ->input('hinhanh')!=""){ + $this -> validate($request,[ + 'tenloai' =>'required|min:2|max:50|unique:loaisanpham, TenLoai', + 'mota' =>'required|min:2|max:200' + ], + [ 129 + 'tenloai.required'=>'Bạn chưa nhập tên loại', + 'tenloai.min'=>'Tên loại phải có độ dài lớn hơn 1 ký tự', + 'tenloai.max'=>'Tên loại phải có độ dài nhỏ hơn 50 ký t ự', + 'tenloai.unique'=>'Tên loại đã tồn tại', + 'mota.required'=>'Bạn chưa nhập mô tả', + 'mota.min'=>'Phần mô tả phải có độ dài lớn hơn 1 ký t ự', + 'mota.max'=>'Phần mô tả phải có độ dài nhỏ hơn 200 k ý tự' + ]); + $loaisp = new loaisanpham; + $loaisp -> TenLoai = $request -> tenloai; + $loaisp -> MoTa = $request -> mota; + $loaisp -> HinhAnh =$request -> hinhanh; + $loaisp ->save(); + return redirect('/admin/loai-san-pham/them') - > with('thongbao','Thêm thành công'); + + } + else{ + return redirect('/admin/loai-san-pham/them') - > with('err','Bạn cần thêm đầy đủ các trường bắt buộc'); + } + } + public function getSua(Request $request){ 130 + $query = $request ->id; + $loaisp = loaisanpham::find($query); + if(isset($loaisp)){ + return view('admin.loaisanpham.sualoai',['loaisp'=>$loaisp]) ; + } + else{ + return view('admin.erorr.notfound'); + } + } + public function postSua(Request $request){ + $query = $request ->id; + $loaisp = loaisanpham::find($query); + if($request ->hasFile('file')){ + $hinhanh = $request ->file('file'); + $name = $hinhanh ->getClientOriginalName(); + $destinationPath = 'img/'; + if (!file_exists($destinationPath)) { + mkdir($destinationPath, 0755, true); + } + $hinhanh->move($destinationPath, $name); + } + else if($request ->input('tenloai')!="" && $request - >input('mota')!=""){ + if($request ->input('tenloai')== $loaisp -> TenLoai){ + $this -> validate($request,[ 131 + 'tenloai' =>'required|min:2|max:50|', + 'mota' =>'required|min:2|max:200' + ], + [ + 'tenloai.required'=>'Bạn chưa nhập tên loại', + 'tenloai.min'=>'Tên loại phải có độ dài lớn hơn 1 ký tự', + 'tenloai.max'=>'Tên loại phải có độ dài nhỏ hơn 50 ký t ự', + 'mota.required'=>'Bạn chưa nhập mô tả', + 'mota.min'=>'Phần mô tả phải có độ dài lớn hơn 1 ký t ự', + 'mota.max'=>'Phần mô tả phải có độ dài nhỏ hơn 200 k ý tự' + ]); + }else{ + $this -> validate($request,[ + 'tenloai' =>'required|min:2|max:50|unique:loaisanpha m,TenLoai', + 'mota' =>'required|min:2|max:200' + ], + [ + 'tenloai.required'=>'Bạn chưa nhập tên loại', + 'tenloai.min'=>'Tên loại phải có độ dài lớn hơn 1 ký tự', + 'tenloai.max'=>'Tên loại phải có độ dài nhỏ hơn 50 k ý tự', 132 + 'tenloai.unique'=>'Tên loại đã tồn tại', + 'mota.required'=>'Bạn chưa nhập mô tả', + 'mota.min'=>'Phần mô tả phải có độ dài lớn hơn 1 ký tự', + 'mota.max'=>'Phần mô tả phải có độ dài nhỏ hơn 20 0 ký tự' + ]); + } + $loaisp -> TenLoai = $request -> tenloai; + $loaisp -> MoTa = $request -> mota; + if($request -> hinhanh !="" && $request - > hinhanh != $loaisp -> HinhAnh){ + $image_path = "img/".$loaisp -> HinhAnh; + + if (file_exists($image_path)) { + + @unlink($image_path); + } + $loaisp -> HinhAnh =$request -> hinhanh; + } + $loaisp ->save(); + return view('admin.loaisanpham.sualoai',['loaisp'=>$loais p]) -> with('thongbao','Sửa thành công'); + + } + } 133 + public function postXoa(Request $request){ + $query = $request ->id; + $loaisp = loaisanpham::find($query); + if(isset($loaisp)){ + $image_path = "img/".$loaisp -> HinhAnh; + + if (file_exists($image_path)) { + + @unlink($image_path); + } + $loaisp ->delete(); + return redirect('/admin/loai-san-pham/danh-sach') - >with('thongbao','Xóa thành công'); + } + else{ + return view('admin.erorr.notfound'); + } + } + } + + UserController: + <?php + + namespace App\Http\Controllers; + 134 + use Illuminate\Http\Request; + use Illuminate\Support\Facades\Auth; + use App\tai_khoan; + class UserController extends Controller + { + // + public function getSua(Request $request){ + $query = $request ->id; + $user = tai_khoan::find($query); + if(isset($user)){ + return view('admin.user.suauser',['user'=>$user]); + } + else{ + return view('admin.erorr.notfound'); + } + } + public function postSua(Request $request){ + $query = $request ->id; + $user = tai_khoan::find($query); + $this -> validate($request,[ + 'tendn' =>'required|min:4|max:12', + 'tenuser' =>'required|min:2|max:50', + + ], + [ + 'tendn.required'=>'Bạn chưa nhập tên đăng nhập', 135 + 'tendn.min'=>'Tên đăng nhập phải có độ dài lớn hơn 3 ký tự', + 'tendn.max'=>'Tên đăng nhập phải có độ dài nhỏ hơn 13 k ý tự', + 'tenuser.required'=>'Bạn chưa nhập tên người dùng', + 'tenuser.min'=>'Tên người dùng phải có độ dài lớn hơn 1 ký tự', + 'tenuser.max'=>'Tên người dùng phải có độ dài nhỏ hơn 5 0 ký tự', + ]); + $user ->tendn =$request->tendn; + $user ->tenuser =$request->tenuser; + if($request->has('doimk')){ + $this -> validate($request,[ + 'mk' =>'required|min:4|max:12', + 'nhaplaimk' =>'required|same:mk', + ], + [ + 'mk.required'=>'Bạn chưa nhập mật khẩu', + 'mk.min'=>'Mật khẩu phải có độ dài lớn hơn 3 ký tự', + 'mk.max'=>'Mật khẩu phải có độ dài nhỏ hơn 13 ký tự', + 'nhaplaimk.required'=>'Bạn chưa nhập nhập lại mật kh ẩu', + 'nhaplaimk.same'=>'Nhập lại mật khẩu không khớp với mật khẩu', + ]); 136 + $user ->password =bcrypt($request->mk); + } + $user ->save(); + return view('admin.user.suauser',['user'=>$user])- >with('thongbao','Cập nhập thành công'); + } + public function getDangNhap(){ + return view('admin.user.login'); + } + public function postDangNhap(Request $request){ + + $this -> validate($request,[ + 'tendn' =>'required|min:4|max:12', + 'matkhau' =>'required|min:4|max:12', + + ], + [ + 'tendn.required'=>'Bạn chưa nhập tên đăng nhập', + 'tendn.min'=>'Tên đăng nhập phải có độ dài lớn hơn 3 ký tự', + 'tendn.max'=>'Tên đăng nhập phải có độ dài nhỏ hơn 13 k ý tự', + 'matkhau.required'=>'Bạn chưa nhập mật khẩu', + 'matkhau.min'=>'Mật khẩu phải có độ dài lớn hơn 3 ký tự' , 137 + 'matkhau.max'=>'Mật khẩu phải có độ dài nhỏ hơn 13 ký tự', + ]); + if(Auth::attempt(['tendn'=>$request- >tendn,'password'=>$request->matkhau])){ + return redirect("admin/loai-san-pham/danh-sach"); + }else{ + return view('admin.user.login')- >with('err','Sai tên tài khoản hoặc mật khẩu'); + }; + + } + public function getDangXuat(){ + Auth::logout(); + return view('admin.user.login'); + } + } + + HomeController: + <?php + + namespace App\Http\Controllers; + use Illuminate\Http\RedirectResponse; + use App\baogia; + use Illuminate\Http\Request; 138 + use App\sanpham; + use App\infoct; + use App\loaisanpham; + use App\thanhpham; + use DB; + + class HomeController extends Controller + { + // + public function getHome(){ + $rdsanphams = sanpham::all()->toArray(); + $intro = infoct::all(); + $loaisanphams= loaisanpham::all(); + $sanphamnoibats= sanpham::where('NoiBat',1)->get(); + $thanhphams= thanhpham::all()->sortByDesc('ID'); + shuffle($rdsanphams); + return view('pages.home.home',['rdsanphams'=>$rdsanpham s,'intro'=>$intro,'loaisanphams'=>$loaisanphams,'sanphamnoibat s'=>$sanphamnoibats,'thanhphams'=>$thanhphams]); + } + public function postSearchAjax(Request $request){ + if($request->get('query')) + { + $query = $request->get('query'); + $data = DB::table('sanpham') + ->where('TenSP', 'LIKE', "%{$query}%") 139 + ->get(); + $output = ''; + foreach($data as $row) + { + $output .= ' + ID .'">'.$row- >TenSP.' + '; + } + $output .= ''; + echo $output; + } + } + public function postBaoGia(Request $request){ + $baogia = new baogia; + $baogia -> HoTen = $request->tenkh; + $baogia -> DiaChi = $request->diachi; + $baogia -> SDT =$request->sdt; + if($request->ghichu !=""){ + $baogia -> GhiChu = $request->ghichu; + } + $baogia -> save(); + return redirect('/home')- >with('thongbao', 'Đăng Ký Nhận Báo Giá Thành Công'); + } + } 140 + + ShowSanPhamController: + <?php + + namespace App\Http\Controllers; + + use Illuminate\Http\Request; + use DB; + use App\sanpham; + use App\nhanxet; + use App\loaisanpham; + use Illuminate\Support\Carbon; + class ShowSanPhamController extends Controller + { + // + public function getDanhSach(Request $request){ + $selected = $request->id; + $kproducts =DB::table('loaisanpham') ->get(); + $sproducts =DB::table('sanpham') - > join('loaisanpham_sanpham','sanpham.ID','=','loaisanpham_san pham.sanpham_id') - > select('sanpham.ID','sanpham.TenSP','sanpham.AnhTD','loaisa npham_sanpham.loaisanpham_id') - >orderBy('sanpham.ID', 'desc')-> get() ->toArray() ; + for($i = 0; $i < count($sproducts); $i++){ 141 + $sproducts[$i]->loaisanpham_id = 'filter-'.$sproducts[$i]- >loaisanpham_id; + } + for($i = 1; $i < count($sproducts); $i++){ + if($sproducts[$i]->ID == $sproducts[$i-1]->ID){ + $sproducts[$i]->loaisanpham_id = $sproducts[$i]- >loaisanpham_id .' '. $sproducts[$i-1]->loaisanpham_id; + array_splice($sproducts,$i-1,1); + --$i; + } + } + return view('pages.sanpham.danhsachsanpham')- > with(['kproducts' => $kproducts,'sproducts' => $sproducts,'sele cted' =>$selected]); + + } + public function getChiTiet(Request $request){ + $query = $request->id; + $sanpham= sanpham::find($query); + if(isset($sanpham)){ + $hinhanhs = $sanpham->hinhsanpham()->get(); + $comment = $sanpham->nhanxet()->orderBy('ID','desc')- >get(); + $cungloais = DB::table('loaisanpham_sanpham') - >select('loaisanpham_id')->where('sanpham_id',$query)->get()- >toArray(); 142 + $spcungloais=array(); + foreach($cungloais as $loai){ + $loais =loaisanpham::find($loai->loaisanpham_id)- >sanpham()->get()->toArray(); + $spcungloais= array_merge($spcungloais,$loais); + } + return view('pages.sanpham.chitietsanpham',['sanpham'=>$s anpham,'nhanxet'=>$comment,'hinhanhs'=>$hinhanhs,'spcungloa is'=>$spcungloais]); + } + else{ + return view('admin.erorr.notfound'); + } + } + public function postNhanXet(Request $request){ + $query = $request->id; + $nhanxet = new nhanxet; + $nhanxet ->IDSanPham = $query; + $nhanxet ->HoTen= $request ->name; + $nhanxet ->NoiDung= $request->cmt; + $nhanxet ->save(); + return redirect("/san-pham/chi-tiet/".$query."#comment"); + } + } + 143 + ShowDuAnController: + <?php + + namespace App\Http\Controllers; + use App\thanhpham; + use Illuminate\Http\Request; + use Illuminate\Database\Eloquent\Collection; + + class ShowDuAnController extends Controller + { + // + public function getDuAn(){ + $duans = thanhpham::where('ID','>',0)- >orderBy('ID','desc') ->paginate(6) ; + return view('pages.duan.danhsachduan',['duans'=>$duans]); + } + public function getChiTiet(Request $request){ + $query = $request->id; + $duan= thanhpham::find($query); + if(isset($duan)){ + $duans=thanhpham::all()->toArray(); + shuffle($duans); + return view('pages.duan.chitietduan',['duan'=>$duan,'duans' =>$duans]); + } + else{ 144 + return view('admin.erorr.notfound'); + } + } + } + − Sử dụng Laravel Blade template để đổ và xử lý dữ liệu ngoài View: − @foreach($thanhphams as $nhanxet) − @if($loop->iteration <=4) − − <img src="{{ Asset('img/'. $nhanxet- >AnhKH) }}" class="testimonial-img" alt=""> − {{$nhanxet->TenKH}} − {{$nhanxet->DiaChi}} − − {{$nhanxet->NhanXet}} − − − @else − @break − @endif − @endforeach 5.5 Một số đoạn code nổi bật − CODE Autocomplete kết quả tìm kiếm sử dụng Ajax: 145 − − $(document).ready(function(){ − $("#timkiem").keyup(function(){ − var query = $(this).val(); − if(query !=""){ − var _token = $('input[name="_token"]').val(); − $.ajax({ − url:"{{ route('timkiem') }}", − method:"POST", − data:{query:query, _token:_token}, − success:function(data){ − $('#kq').fadeIn(); − $('#kq').html(data); − } − }); − } − }); − $(document).on('click', function(){ − $('#timkiem').val(""); − $('#kq').fadeOut(); − }); − − CODE load dữ liệu cho bộ lọc: − $selected = $request->id; − $kproducts =DB::table('loaisanpham') ->get(); 146 − $sproducts =DB::table('sanpham') - > join('loaisanpham_sanpham','sanpham.ID','=','loaisanpham_sanpham. sanpham_id') - > select('sanpham.ID','sanpham.TenSP','sanpham.AnhTD','loaisanpham _sanpham.loaisanpham_id') ->orderBy('sanpham.ID', 'desc')-> get() - >toArray() ; − for($i = 0; $i < count($sproducts); $i++){ − $sproducts[$i]->loaisanpham_id = 'filter-'.$sproducts[$i]- >loaisanpham_id; − } − for($i = 1; $i < count($sproducts); $i++){ − if($sproducts[$i]->ID == $sproducts[$i-1]->ID){ − $sproducts[$i]->loaisanpham_id = $sproducts[$i]- >loaisanpham_id .' '. $sproducts[$i-1]->loaisanpham_id; − array_splice($sproducts,$i-1,1); − --$i; − } − } − CODE phân trang danh sách dự án: − public function getDuAn(){ − $duans = thanhpham::where('ID','>',0)->orderBy('ID','desc') - >paginate(6) ; − return view('pages.duan.danhsachduan',['duans'=>$duans]); − } 147 − CODE xác thực đăng nhập: − − if(Auth::attempt(['tendn'=>$request->tendn,'password'=>$request- >matkhau])){ − return redirect("admin/loai-san-pham/danh-sach"); − }else{ − return view('admin.user.login')- >with('err','Sai tên tài khoản hoặc mật khẩu'); − }; − − CODE xử lý dữ liệu từ Ajax gọi đến trong chức năng tìm kiếm: − if($request->get('query')) − { − $query = $request->get('query'); − $data = DB::table('sanpham') − ->where('TenSP', 'LIKE', "%{$query}%") − ->get(); − $output = ''; − foreach($data as $row) − { − $output .= ' − ID .'">'.$row- >TenSP.' − '; − } 148 − $output .= ''; − echo $output; − } − CODE thông báo số yêu cầu từ khách hàng chưa xem: − $this->middleware(function($request,$next){ − if(Auth::check()){ − $baogia = baogia::where('DaXem',0)->get(); − view()->share('baogia',$baogia); − } − return $next($request); − }); − CODE tạo multi-slide: − − $('.owl-top').owlCarousel({ − loop:true, − margin:20, − autoplay:true, − autoplayTimeout:5000, − autoplayHoverPause:true, − responsive:{ − 0:{ − items:1 − }, − 400:{ 149 − items:2 − }, − 800:{ − items:3 − }, − 1200:{ − items:4 − } − } − }); − − CODE tạo bộ lọc với dữ liệu được load lên từ Database thông qua Controller: − $(window).on('load', function () { − var portfolioIsotope = $('.portfolio-container').isotope({ − itemSelector: '.portfolio-item' − }); − portfolioIsotope.isotope({ filter: $('#portfolio- flters li.first').attr('data-filter') }); − $('#portfolio-flters li').on( 'click', function() { − if($(this).hasClass('all')){ − $("#portfolio-flters li").removeClass('filter-active'); − $(this).addClass('filter-active'); − portfolioIsotope.isotope({ filter: $(this).data('filter') }) − } 150 − else if($(this).hasClass('elem')){ − $("#portfolio-flters li.all").removeClass('filter-active'); − var selected = $("#portfolio-flters li.elem") − var inclusives = []; − if($(this).hasClass('filter-active')){ − $(this).removeClass('filter-active'); − selected.each( function() { − if ($(this).hasClass('filter-active')) { − inclusives.push( $(this).attr('data-filter') ); − } − }); − var filterValue = inclusives.join(""); − if(filterValue !=""){ − portfolioIsotope.isotope({ filter: filterValue }) − } − else{ − portfolioIsotope.isotope({ filter: '.nothing' }) − } − } − else{ − $(this).addClass('filter-active'); − selected.each( function() { − if ($(this).hasClass('filter-active')) { − inclusives.push( $(this).attr('data-filter') ); − } − }); 151 − var filterValue = inclusives.join(""); − portfolioIsotope.isotope({ filter: filterValue }) − } − } − }); − }); − CODE tạo thanh điều hướng nổi khi scroll: − $(window).scroll(function() { − if ($(this).scrollTop() > 50) { − $('header').addClass('header-scrolled'); − } else { − $('header').removeClass('header-scrolled'); − } − }); − CODE tạo hiệu hứng hoạt hình khi scroll đến một mục tin: − function isScrolledIntoView(elem) { − var docViewTop = $(window).scrollTop(); − var docViewBottom = docViewTop + $(window).height(); − var elemTop = $(elem).offset().top- $(window).height()/2; − var elemBottom = elemTop + $(elem).height(); − return elemBottom = docViewTo p; − } − $(window).scroll(function() { 152 − $("#hlservices .owl-hl").each(function() { − if (isScrolledIntoView(this) === true) { − $(this).css("opacity",1); − $(this).addClass("fadeInRight"); − } − }); − }); − $(window).scroll(function() { − $("#services .wown").each(function() { − if (isScrolledIntoView(this) === true) { − $(this).css("opacity",1); − $(this).addClass("bounceInUp"); − } − }); − }); − CODE cho button Back-to-top: − $(window).scroll(function() { − if ($(this).scrollTop() > 100) { − $('.back-to-top').fadeIn('slow'); − } else { − $('.back-to-top').fadeOut('slow'); − } − }); − $('.back-to-top').click(function(){ − $('html, body').animate({scrollTop : 0},"slow"); 153 − return false; − }); − $('#header .logo .text-light').click(function(){ − $('html, body').animate({scrollTop : 0},"slow"); − return false; − }); − CODE biến đổi thanh điều hướng sang dạng mục điều hướng khi website chạy trên các thiết bị có màn hình nhỏ: − if ($('.main-nav').length) { − var $mobile_nav = $('.main-nav').clone().prop({ − class: 'mobile-nav d-lg-none' − }); − $('body').append($mobile_nav); − $('body').prepend('<button type="button" class="mobile-nav- toggle d-lg-none">'); − $('body').append(''); − − $(document).on('click', '.mobile-nav-toggle', function(e) { − $('body').toggleClass('mobile-nav-active'); − $('.mobile-nav-toggle i').toggleClass('fa-times fa-bars'); − $('.mobile-nav-overly').toggle(); − }); − $(document).on('click', '.mobile-nav .drop-down > a', function(e) { − e.preventDefault(); − $(this).next().slideToggle(300); 154 − $(this).parent().toggleClass('active'); − }); − − $(document).click(function(e) { − var container = $(".mobile-nav, .mobile-nav-toggle"); − if (!container.is(e.target) && container.has(e.target).length === 0) { − if ($('body').hasClass('mobile-nav-active')) { − $('body').removeClass('mobile-nav-active'); − $('.mobile-nav-toggle i').toggleClass('fa-times fa-bars'); − $('.mobile-nav-overly').fadeOut(); − } − } − }); − } else if ($(".mobile-nav, .mobile-nav-toggle").length) { − $(".mobile-nav, .mobile-nav-toggle").hide(); − } 155 KẾT LUẬN 1. Mức độ hoàn thành − Chọn đề tài, phân tích đề tài, tìm hiểu thực tế: + Đã gặp giáo viên và trao đổi, nhận đề tài. + Phân tích về đề tài ở chương 1 của tài liệu này. + Đã khảo sát thực tế các trang web ở chương 2 mục 7 của tài liệu này. − Thiết kế giao diện trang web: + Đã có trang chủ với các chức năng: Xem bài đăng, Tìm kiếm sản phẩm, Gửi yêu cầu nhận báo giá. + Đã có giao diện các chi tiết bài đăng trong đó bài đăng chi tiết về sản phẩm có chức năng nhận xét. + Đã có giao diện các mục danh sách bài đăng trong đó bài đăng về danh sách sản phẩm chức năng lọc sản phẩm. + Đã có giao diện trang thông báo Not Found. + Đã có giao diện trang Đăng nhập/Đăng xuất. + Đã có giao diện trang Admin sau khi Đăng nhập. + Đã có các giao diện quản lý thông tin bài đăng trên trang Admin. + Đã có giao diện trang Admin quản lý tài khoản và nhận danh sách yêu cầu báo giá. + Đã có thể tương thích trên nhiều thiết bị khác nhau. − Tạo và thiết kế cơ sở dữ liệu: + Đã có lược đồ cơ sở dữ liệu và database. + Đã tạo lược đồ usecase và chi tiết các usecase. 156 − Phần code: + Hoàn thành đăng tin, xử lý hình ảnh trong đăng tin. + Hoàn thành xem bài đăng, hiệu ứng hoạt hình, multi-slide trong bài đăng và phân trang cho mục danh sách. + Hoàn thành hiển thị chi tiết bài đăng. + Đăng nhập thành công với authentication. + Hoàn thành Chức năng tìm kiếm sử dụng Ajax, chức năng lọc dữ liệu. + Hoàn thành chức năng gửi yêu cầu nhận báo giá, chức năng nhận xét. + Hoàn thành quản lí bài đăng, quản lý tài khoản, thông báo số yêu cầu từ khách hàng chưa đọc, hiển thị danh sách các yêu cầu. − Cho dữ liệu vào Database: + Đã thêm dữ liệu vào database. + Đã chạy thử ra phần giao diện ở trang chủ và trang đăng tin. − Mức độ hoàn thành:100% 2. Các khó khăn gặp phải − Sử dụng công nghệ cho ứng dụng còn chưa thành thạo. − Phải dành nhiều thời gian tìm hiểu về công nghệ. 3. Ưu, Nhược điểm của website − Ưu điểm: + Có tính năng nhận thông báo yêu cầu từ khách hàng. + Đăng tin, sữa tin một cách dễ dàng dành cho Admin. + Xem tin dễ dàng khi vừa truy cập trang web. 157 + Giao diện bắt mắt, đơn giản tạo cảm giác thoải mái cho người xem. + Có tính năng gợi ý tìm kiếm sản phẩm cho người dùng. + Có khả năng lọc sản phẩm thuộc nhiều loại cùng một lúc. + Gửi yêu cầu nhận báo giá đến công ty một cách nhanh chóng. + Tích hợp google map trong phần liên hệ với công ty. − Nhược điểm: + Nội dung cho website còn chưa được nhiều. + Chưa có hộp chat trực tuyến giữa khách hàng với công ty. 4. Ý tưởng phát triển − Xây hộp chat trực tuyến giữa khách hàng với công ty. − Phát triển thêm nhiều nội dung cho website. 158 TÀI LIỆU THAM KHẢO Tài liệu tiếng việt Tài liệu từ internet 1. Văn Giang. Bootstrap là gì? Vì sao nên sử dụng Bootstrap?, ngày 2 tháng 5 năm 2020, https://tech.bizflycloud.vn/bootstrap-la-gi-vi-sao-nen-su-dung- bootstrap-20181123141649382 2. Nguyễn Thị Thu Hà. Tìm hiểu cơ bản về HTML và CSS, ngày 2 tháng 5 năm 2020, https://viblo.asia/p/tim-hieu-ve-html-va-css-co-ban-phan-1- 7ymwGXV0R4p1 3. Nguyễn Hiền. PHP là gì? Tổng quan về ngôn ngữ PHP, ngày 2 tháng 5 năm 2020, https://toidayhoc.com/lap-trinh/php-la-gi-tong-quan-ve-ngon-ngu- php/ 4. Đào Quang Huy. Giới thiệu về Laravel, ngày 2 tháng 5 năm 2020, https://viblo.asia/p/gioi-thieu-ve-laravel-924lJrnzlPM 5. Bá Huỳnh. TOP 5 hình thức marketing online hiệu quả nhất năm 2019, ngày 2 tháng 5 năm 2020, https://crmviet.vn/cac-hinh-thuc-marketing-online-pho-bien-nhat- nam-2018/ 6. Nguyễn Nhật. JQuery là gì? Vì sao nên sử dụng JQuery?, ngày 2 tháng năm 2020, https://topdev.vn/blog/jquery-la-gi/ 7. Thành Phú. JavaScript là gì? Vài trò của JavaScript trên website, ngày 2 tháng 5 năm 2020, 159 https://quantrimang.com/javascript-la-gi-155978 8. Phạm Thạch. CSS là gì? Vai trò của nó trên website, ngày 2 tháng 5 năm 2020, https://thachpham.com/web-development/html-css/css-la-gi-va-vai- tro.html 9. Lê Thảo. Ajax là gì? Cách thức hoạt động và lợi ích mang lại, ngày 2 tháng 5 năm 2020, https://topdev.vn/blog/ajax-la-gi-cach-thuc-hoat-dong-va-loi-ich- ma-no-mang-lai/ 10. Nguyễn Việt. Ngôn ngữ HTML là gì? Vai trò của HTML trong lập trình web?, ngày 2 tháng 5 năm 2020, https://blog.webico.vn/ngon-ngu-html-la-gi-vai-tro-cua-html-trong- lap-trinh-web/ 11. VNETWORK. Các số liệu thống kê Internet Việt Nam 2019, ngày 2 tháng 5 năm 2020, https://vnetwork.vn/news/cac-so-lieu-thong-ke-internet-viet-nam- 2019 160

Các file đính kèm theo tài liệu này:

  • pdfde_tai_thiet_ke_va_lap_trinh_website.pdf