• Trang Chủ
  • Lập Trình
    Phân biệt giữa Public Cloud, Private Cloud và Hybrid Cloud

    Phân biệt giữa Public Cloud, Private Cloud và Hybrid Cloud

    Top 9 ứng dụng xem phim hoạt hình tốt nhất

    Top 9 ứng dụng xem phim hoạt hình tốt nhất

    Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!

    Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!

    Căn hộ thương mại là gì? Có nên đầu tư vào loại hình bất động sản này không?

    Căn hộ thương mại là gì? Có nên đầu tư vào loại hình bất động sản này không?

    Xu hướng phát triển thị trường bất động sản 

    Bán hàng qua app di động giúp ích gì cho việc kinh doanh của bạn? 

    Lập trình di động và tốc độ tải của thiết bị 3G

    Lập trình di động và tốc độ tải của thiết bị 3G

    Top 7 địa chỉ cung cấp rèm cửa sổ uy tín

    Top 7 địa chỉ cung cấp rèm cửa sổ uy tín

    Cách mua cổ phiếu cho người mới bắt đầu chơi chứng khoán

  • Công Nghệ
  • Tool
    Phân biệt giữa Public Cloud, Private Cloud và Hybrid Cloud

    Phân biệt giữa Public Cloud, Private Cloud và Hybrid Cloud

    Top 9 ứng dụng xem phim hoạt hình tốt nhất

    Top 9 ứng dụng xem phim hoạt hình tốt nhất

    Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!

    Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!

    Căn hộ thương mại là gì? Có nên đầu tư vào loại hình bất động sản này không?

    Căn hộ thương mại là gì? Có nên đầu tư vào loại hình bất động sản này không?

    Xu hướng phát triển thị trường bất động sản 

    Bán hàng qua app di động giúp ích gì cho việc kinh doanh của bạn? 

    Lập trình di động và tốc độ tải của thiết bị 3G

    Lập trình di động và tốc độ tải của thiết bị 3G

    Top 7 địa chỉ cung cấp rèm cửa sổ uy tín

    Top 7 địa chỉ cung cấp rèm cửa sổ uy tín

    Cách mua cổ phiếu cho người mới bắt đầu chơi chứng khoán

  • Tài Liệu
  • Việc Làm
    Phân biệt giữa Public Cloud, Private Cloud và Hybrid Cloud

    Phân biệt giữa Public Cloud, Private Cloud và Hybrid Cloud

    Top 9 ứng dụng xem phim hoạt hình tốt nhất

    Top 9 ứng dụng xem phim hoạt hình tốt nhất

    Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!

    Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!

    Căn hộ thương mại là gì? Có nên đầu tư vào loại hình bất động sản này không?

    Căn hộ thương mại là gì? Có nên đầu tư vào loại hình bất động sản này không?

    Xu hướng phát triển thị trường bất động sản 

    Bán hàng qua app di động giúp ích gì cho việc kinh doanh của bạn? 

    Lập trình di động và tốc độ tải của thiết bị 3G

    Lập trình di động và tốc độ tải của thiết bị 3G

    Top 7 địa chỉ cung cấp rèm cửa sổ uy tín

    Top 7 địa chỉ cung cấp rèm cửa sổ uy tín

    Cách mua cổ phiếu cho người mới bắt đầu chơi chứng khoán

  • Blog
  • Trang Chủ
  • Lập Trình
    Phân biệt giữa Public Cloud, Private Cloud và Hybrid Cloud

    Phân biệt giữa Public Cloud, Private Cloud và Hybrid Cloud

    Top 9 ứng dụng xem phim hoạt hình tốt nhất

    Top 9 ứng dụng xem phim hoạt hình tốt nhất

    Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!

    Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!

    Căn hộ thương mại là gì? Có nên đầu tư vào loại hình bất động sản này không?

    Căn hộ thương mại là gì? Có nên đầu tư vào loại hình bất động sản này không?

    Xu hướng phát triển thị trường bất động sản 

    Bán hàng qua app di động giúp ích gì cho việc kinh doanh của bạn? 

    Lập trình di động và tốc độ tải của thiết bị 3G

    Lập trình di động và tốc độ tải của thiết bị 3G

    Top 7 địa chỉ cung cấp rèm cửa sổ uy tín

    Top 7 địa chỉ cung cấp rèm cửa sổ uy tín

    Cách mua cổ phiếu cho người mới bắt đầu chơi chứng khoán

  • Công Nghệ
  • Tool
    Phân biệt giữa Public Cloud, Private Cloud và Hybrid Cloud

    Phân biệt giữa Public Cloud, Private Cloud và Hybrid Cloud

    Top 9 ứng dụng xem phim hoạt hình tốt nhất

    Top 9 ứng dụng xem phim hoạt hình tốt nhất

    Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!

    Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!

    Căn hộ thương mại là gì? Có nên đầu tư vào loại hình bất động sản này không?

    Căn hộ thương mại là gì? Có nên đầu tư vào loại hình bất động sản này không?

    Xu hướng phát triển thị trường bất động sản 

    Bán hàng qua app di động giúp ích gì cho việc kinh doanh của bạn? 

    Lập trình di động và tốc độ tải của thiết bị 3G

    Lập trình di động và tốc độ tải của thiết bị 3G

    Top 7 địa chỉ cung cấp rèm cửa sổ uy tín

    Top 7 địa chỉ cung cấp rèm cửa sổ uy tín

    Cách mua cổ phiếu cho người mới bắt đầu chơi chứng khoán

  • Tài Liệu
  • Việc Làm
    Phân biệt giữa Public Cloud, Private Cloud và Hybrid Cloud

    Phân biệt giữa Public Cloud, Private Cloud và Hybrid Cloud

    Top 9 ứng dụng xem phim hoạt hình tốt nhất

    Top 9 ứng dụng xem phim hoạt hình tốt nhất

    Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!

    Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!Tìm hiểu về các loại hình tại dự án Richmond City, xem ngay!

    Căn hộ thương mại là gì? Có nên đầu tư vào loại hình bất động sản này không?

    Căn hộ thương mại là gì? Có nên đầu tư vào loại hình bất động sản này không?

    Xu hướng phát triển thị trường bất động sản 

    Bán hàng qua app di động giúp ích gì cho việc kinh doanh của bạn? 

    Lập trình di động và tốc độ tải của thiết bị 3G

    Lập trình di động và tốc độ tải của thiết bị 3G

    Top 7 địa chỉ cung cấp rèm cửa sổ uy tín

    Top 7 địa chỉ cung cấp rèm cửa sổ uy tín

    Cách mua cổ phiếu cho người mới bắt đầu chơi chứng khoán

  • Blog
Trang Chủ Lập Trình

Hướng dẫn Cách lập trình Web với Python hiệu quả mới nhất 2020

Cv.com.vn Bởi Cv.com.vn
31/12/2019
Trong Lập Trình
0
Tải Xuống (48)
Mục lục

    Lập trình Web với Python là một trong những từ khóa được tìm kiếm nhiều nhất trên google về chủ đề lập trình Web với Python. Trong bài viết này, coder.com.vn sẽ viết bài Hướng dẫn Cách lập trình Web với Python hiệu quả mới nhất 2020

    Khi nói tới lập trình website thì có lẽ cực kì nhiều lập trình viên sẽ liên tưởng ngay tới ngôn ngữ php. Ngôn ngữ php được biết đến là ngôn ngữ được tạo ra để phục vụ cho việc làm web với rất nhiều framework, cms có thêm với một cộng đồng rất đông , hung hãn nhưng tại bài viết tôi mong muốn trình bày một đến gần hơn khác, bằng ngôn ngữ khác cho công cuộc làm web đấy là lập trình web với ngôn ngữ python.

    I. Tạo môi trường

    Chọn lựa framework: Hiện tại có rất nhiều framework hỗ trợ lập trình website bằng ngôn ngữ python trong đó có 3 cái tên đó là Django, Flask, Pyramid … Mỗi framework đều có điểm mạnh và điểm yếu riêng của nó, để hiểu cụ thể hơn hãy tham khảo phần “Link tham khảo” ở phần cuối của bài viết này. tại chẳng hạn như này tôi recommend về framework Flask (Flask là một microframework cho Python dựa trên Werkzeug, Jinja 2.)

    Thiết lập framework Flask:

    Thiết lập python và pid như link sau:

    https://docs.python-guide.org/starting/install3/osx/

    Cài đặt Flask

    pip install flask

    Tạo thư mục của dự án:

    mkdir hoctiengnhatonline

    Tạo một tệp khởi tạo app.py trong thư mục “hoctiengnhatonline”, sau đó cấu hình để sử dụng module Flask tại tệp app.py

    from flask import Flask
    app = Flask(__name__)@app.route("/")defmain():return"Welcome"if __name__ == "__main__":
      app.run()

    Thực thi app.py

    python app.py

    Vào trình duyệt và truy xuất đường link dưới đây
    http://localhost:5000/

    uc?id=1TpT-SKEpkC0OZmsUZe6qEruNSAPweRqg&export=download

    II. Xây dựng trang chủ

    Tại folder hoctiengnhatonline tạo folder templates, tại thư mục templates xây dựng một tệp đặt tên là index.html, mở tệp index.html thêm đoạn code HTML sau đây vào:

    <htmllang="en">
     
    <head>
        <title>Hoc Tieng Nhat online Apptitle>
     
     
        <đường linkhref="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css"rel="stylesheet">
     
        <linkhref="https://hroy.eu/bootstrap/docs/examples/jumbotron-narrow/jumbotron-narrow.css"rel="stylesheet">
     
     
    head>
     
    <body>
     
        <divclass="container">
            <divclass="header">
                <nav>
                    <ulclass="nav nav-pills pull-right">
                        <lirole="presentation"class="active"><ahref="#">Homea>
                        li>
                        <lirole="presentation"><ahref="#">Sign Ina>
                        li>
                        <lirole="presentation"><ahref="showSignUp">Sign Upa>
                        li>
                    ul>
                nav>
                <heading 3class="text-muted">Hoc tieng Nhat online AppH3>
            div>
     
            <divclass="jumbotron">
                <heading 1>Japanese Lesson Appheading 1>
                <pclass="lead">p>
                <p><aclass="btn btn-lg btn-success"href="showSignUp"role="button">Sign up todaya>
                p>
            div>
     
            <divclass="row marketing">
                <divclass="col-lg-6">
                    <h4>Lesson Listh4>
                    <p>Lesson List Lesson List Lesson List Lesson List Lesson List Lesson List Lesson List Lesson Listp>
    
                    <h4>Lesson Listh4>
                    <p>Lesson List Lesson List Lesson List Lesson List Lesson List Lesson List Lesson List Lesson Listp>
    
                    <h4>Lesson Listh4>
                    <p>Lesson List Lesson List Lesson List Lesson List Lesson List Lesson List Lesson List Lesson Listp>
                div>
     
                <divclass="col-lg-6">
                    <h4>Lesson Listh4>
                    <p>Lesson List Lesson List Lesson List Lesson List Lesson List Lesson List Lesson List Lesson Listp>
    
                    <h4>Lesson Listh4>
                    <p>Lesson List Lesson List Lesson List Lesson List Lesson List Lesson List Lesson List Lesson Listp>
    
                    <h4>Lesson Listh4>
                    <p>Lesson List Lesson List Lesson List Lesson List Lesson List Lesson List Lesson List Lesson Listp>
                div>
            div>
     
            <footerclass="footer">
                <p>© Copyright 2019p>
            footer>
     
        div>
    body>
     
    html>

    Mở app.py , import render_template, cái mà chúng ta sẽ sử dụng để kết xuất những tập tin template.

    from flask import Flask, render_template

    Sửa phương thức chủ đạo để trả về tập tin template đã được kết xuất.

    defmain():return render_template('index.html')

    Mở trình duyệt , truy cập http://localhost:5000/ , sẽ thấy màn hình dưới đây:

    uc?id=1Q8L4CtBTaTZFx5fiTEZwbmDPUKm9J9Qq&export=download

    >>> Blog chia sẻ kiến thức xây dựng website

    III. Xây dựng trang đăng ký

    Bước 1: xây dựng Database

    Tạo database tên là hoctiengnhatonline

    CREATEDATABASE hoctiengnhatonline;

    xây dựng bảng lưu người sử dụng tbl_user

    CREATETABLE`hoctiengnhatonline`.`tbl_user` (`user_id`BIGINT AUTO_INCREMENT,`user_name`VARCHAR(4.) NULLvà`user_username`VARCHAR(4) NULLvà`user_password`VARCHAR(4) NULL,
      PRIMARY KEY (`user_id`));

    tạo thủ tục để lưu nội dung người dùng đặt tên là sp_createUser

    DELIMITER $CREATE DEFINER=`root`@`localhost`PROCEDURE`sp_createUser`(IN p_name VARCHAR(2),IN p_username VARCHAR(2.),IN p_password VARCHAR(2)
    )BEGINif ( selectexists (select1from tbl_user where user_username = p_username) ) THENselect'Username Exists !!';
         
        ELSEinsertinto tbl_user
            (
                user_name,
                user_username,
                user_password
            )values(
                p_name,
                p_username,
                p_password
            );ENDIF;END$
    DELIMITER ;

    Bước 2. Tạo bố cụ và giao diện đăng ký

    Trong folder hoctiengnhatonline/templates xây dựng một tệp HTML đặt tên là signup.html, sau đó chèn đoạn code phía dưới vào tập tin signup.html

    <htmllang="en">
    <head>
       <title>Hoc Tieng Nhat online Apptitle>
    
       <linkhref="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css"rel="stylesheet">
       <linkhref="https://hroy.eu/bootstrap/docs/examples/jumbotron-narrow/jumbotron-narrow.css"rel="stylesheet">
       <linkhref="../static/signup.css"rel="stylesheet">
    
    head>
    
    <body>
    
    <divclass="container">
       <divclass="header">
           <nav>
               <ulclass="nav nav-pills pull-right">
                   <lirole="presentation" ><ahref="main">Homea>li>
                   <lirole="presentation"><ahref="#">Sign Ina>li>
                   <lirole="presentation"class="active"><ahref="#">Sign Upa>li>
               ul>
           nav>
           <H3class="text-muted">Hoc tieng Nhat Trực tuyến AppH3>
       div>
    
       <divclass="jumbotron">
           <heading 1>Học tiếng Nhật Trực tuyến AppH1>
           <formclass="form-signin">
               <labelfor="inputName"class="sr-only">Namelabel>
               <inputtype="name"name="inputName"id="inputName"class="form-control"placeholder="Name"requiredautofocus>
               <labelfor="inputEmail"class="sr-only">Email addresslabel>
               <inputtype="email"name="inputEmail"id="inputEmail"class="form-control"placeholder="Email address"requiredautofocus>
               <labelfor="inputPassword"class="sr-only">Passwordlabel>
               <inputtype="password"name="inputPassword"id="inputPassword"class="form-control"placeholder="Password"required>
    
               <buttonid="btnSignUp"class="btn btn-lg btn-primary btn-block"type="button">Sign upbutton>
           form>
       div>
    
    
    
       <footerclass="footer">
           <p>© Copyright 2019p>
       footer>
    
    div>
    body>
    html>

    Tạo thêm tệp CSS trong folder static bên trong hoctiengnhatonline

    body  padding-top: 40px; padding-bottom: 40px;
    .form-signin  max-width: 330px; padding: 15px; margin: 0 auto;
    .form-signin.form-signin-headingvà.form-signin.checkbox  margin-bottom: 10px;
    .form-signin.checkbox  font-weight: normal;
    .form-signin.form-control  position: relative; height: auto; -webkit-box-sizing: border-box;-moz-box-sizing: border-box;box-sizing: border-box; padding: 10px; font-size: 16px;
    .form-signin.form-control:focus  z-index: 2;
    .form-signininput[type="email"]  margin-bottom: -1px; border-bottom-right-radius: 0; border-bottom-left-radius: 0;
    .form-signininput[type="password"]  margin-bottom: 10px; border-top-left-radius: 0; border-top-right-radius: 0;
    

    Thêm đoạn code sau vào trong file app.py

    @app.route('/showSignUp')defshowSignUp():return render_template('signup.html')

    Nhập chuột vào nút SignUp màn hình ảnh dưới đây được hiển thị:
    uc?id=16jRmSKXWt68XbVl8Wqt7kILt-HSdERYT&export=download

    Bước 3 Xây dựng phương thức đăng ký

    Thêm đoạn code giải quyết đăng ký signUp và import thêm thư viện vào tệp app.py

    @app.route('/signUp',methods=['POST'])defsignUp():# read the posted values from the UI_name = request.form['inputName']
        _email = request.form['inputEmail']
        _password = request.form['inputPassword']# validate the received valuesif _name and _email and_password:return json.dumps('html':'All fields good !!')else:return json.dumps('html':'Enter the required fields')

    ,

    from flask import Flask, render_template, json, request

    Bước 4 Tạo đăng ký từ client

    $(function() 
        $('#btnSignUp').click(function() 
            $.ajax(url: '/signUp',data: $('form').serialize(),type: 'POST'vàsuccess: function(response) console.log(response);
                ,error: function(error) console.log(error);
                
            );
        );
    );

    Bước 5. Lưu thông tin bằng thủ tục của Mysql

    đầu tiên cài đặt thư viện mysql cho flask bằng lệnh sau:

    pip install flask-mysql

    trong file app.py import thêm thư viện , thêm các đoạn code giải quyết sau vào

    from flask import Flask, render_template, json, requestfrom flaskext.mysql import MySQLfrom werkzeug import generate_password_hash, check_password_hash
    
    mysql = MySQL()
    app = Flask(__name__)# MySQL configurationsapp.config['MYSQL_DATABASE_USER'] = 'root'app.config['MYSQL_DATABASE_PASSWORD'] = '12345678'app.config['MYSQL_DATABASE_DB'] = 'hoctiengnhatonline'app.config['MYSQL_DATABASE_HOST'] = 'localhost'mysql.init_app(app)

    Tại function giải quyết đăng ký thông tin người dùng thêm đoạn code sau:

    # validate the received valuesif _name and _email and _password:# All Good, let's call MySQLconn = mysql.connect()
        cursor = conn.cursor()
        _hashed_password = generate_password_hash(_password)
        cursor.callproc('sp_createUser',(_name,_email,_hashed_password))
        data = cursor.fetchall()if len(data) is0:
            conn.commit()return json.dumps('message':'User created successfully !')else:return json.dumps('error':str(data[0]))else:return json.dumps('html':'Enter the required fields')except Exception as e:return json.dumps('error':str(e))finally:
        cursor.close() 
        conn.close()

    Lưu những thay đổi và khởi động lại máy chủ. Đi đến trang đăng ký và nhập name, email và mật khẩu , nhấp vào nút Sign Up. Khi xây dựng chiến thắng người sử dụng, bạn sẽ có khả năng thấy một thông báo trong bố cụ và giao diện console của trình duyệt.

    "message": "User created successfully !"

    VI. Tổng kết

    Trong bài đăng này, tôi trình bày bí quyết cơ bản nhất khi lập trình website bằng ngôn ngữ python dùng framework Flask mong rằng sẽ phần nào giúp ích được phần nào đó cho bạn đọc lần đầu lập trình web bằng ngôn ngữ python. Hãy tham khảo tất cả source code ở link tham khảo dưới đây. trong bài đăng kế tiếp tôi sẽ thuyết trình kỹ hơn về các lưu ý khi lập trình website bằng python.

    Xem thêm:  Business Intelligence là gì? Các thuật ngữ thông dụng mà doanh nghiệp đang dùng

    >>>> Blog chia sẻ kiến thức xây dựng website

    V. Đường link tìm đọc

    Học lập Trình

    Nguồn: https://blog.vietnamlab.vn/

    Tags: khóa học djangokhóa học lập trình web pythonlập trình backend pythonlập trình pythonlập trình web bằng pycharmpython djangopython webthiết kế web với python
    Bài Viết Trước

    Kinh nghiệm cách học cấu trúc dữ liệu và giải thuật mới nhất 2020

    Bài Viết Tiếp Theo

    Các trang Web diễn đàn lập trình trao đổi kiến thức mới nhất 2020

    Bài Viết Tiếp Theo
    Tải Xuống (50)

    Các trang Web diễn đàn lập trình trao đổi kiến thức mới nhất 2020

    CODER

    Cần Hỗ Trợ

    Chuyên mục

    • Tool
    • Blog
    • Tài Liệu
    • Lập Trình
    • Việc Làm
    • Công Nghệ

    Phần mềm - Công cụ

    • Brands
    • Alosoft
    • Seeding
    • Top Việc
    • Tổng Hợp
    • Quản Trị Nhân Sự

    Liên kết

    • Top Vui
    • Xe Mô Tô
    • Quản Lý Kho
    • Blog Việc Làm
    • Giải Pháp Việc Làm
    • Phần Mềm Miễn Phí

    Coder.com.vn là blog cá nhân, mọi thông tin đều mang tính chất tham khảo. Do đó, chúng tôi không chịu bất cứ trách nhiệm nào đối với việc sử dụng các thông tin trên website.
    Xem thêm Miễn Trừ Trách Nhiệm

    • Trang Chủ
    • Lập Trình
    • Công Nghệ
    • Tool
    • Tài Liệu
    • Việc Làm
    • Blog

    © 2025 JNews - Premium WordPress news & magazine theme by Jegtheme.