• Trang Chủ
  • Lập Trình

    WordPress Update: What’s New and Why You Should Upgrade

    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ông Nghệ
  • Tool

    WordPress Update: What’s New and Why You Should Upgrade

    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

    Trending Tags

    • Tài Liệu
    • Việc Làm

      WordPress Update: What’s New and Why You Should Upgrade

      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

    • Blog
    • Trang Chủ
    • Lập Trình

      WordPress Update: What’s New and Why You Should Upgrade

      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ông Nghệ
    • Tool

      WordPress Update: What’s New and Why You Should Upgrade

      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

      Trending Tags

      • Tài Liệu
      • Việc Làm

        WordPress Update: What’s New and Why You Should Upgrade

        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

      • 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)

      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.

      Mục Lục

      Toggle
      • I. Tạo môi trường
        • Thiết lập framework Flask:
      • II. Xây dựng trang chủ
      • III. Xây dựng trang đăng ký
      • VI. Tổng kết
        • V. Đường link tìm đọc

      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.