zoukankan      html  css  js  c++  java
  • 12 Jun 18 Django

    12 Jun 18

    一. 登录功能的实现

        1. form表单提交数据的注意事项:

            1. 是form不是from,必须要有method和action

            2. 所有获取用户输入的表单标签要放在form表单里面,表单标签(input,select)必须要有name属性

            3. form表单必须要有submit按钮

     

        2. GET和POST

            用GET: 向服务端请求一个网页的时候;搜索引擎检索时

            用POST: 使用表单向服务器提交数据时

     

        3. request.method --> 获取的是你请求的方法(GET/POST...)

          # 返回的GET,POST都是大写的,所以在编写业务逻辑时,必须大写!!!

     

        4. request.POST   --> 获取POST提交过来的全部数据(字典)

           # ps request.POST的格式{'name':[], 'password': []}. 可以根据[key]的形式取value,但推荐用.get(),这样没有的话,返回None,不报错。

        5. redirect        --> 跳转到指定页面!!!

           # 当浏览器解析到3**时,直接向redirect的url发请求,不会继续解析。

     

    总结: 基础必会三件套

         from django.shortcuts import HttpResponse,render,redirect

            a. HttpResponse("OK")

            b. render(request, "login.html")

            c. redirect("URL")

     

        6. app: app之于project,相当于学院之于学校;一个学校可以有多个学院;当项目较大时,推荐将不同的文件放入不同的app中

     

            创建APP:

                a. 在pycharm中的terminal中

                   python3 manage.py startapp app01  

    # /usr/local/bin/python3.6 manage.py startapp app01

                b. 在项目创立初期,在application中填写app01

                c. Tools -> Run manage.pyTask -> startapp app01

     

            创建好APP,记得告诉Django, 我有这个app:

                在settings.py中,

                # 安装的app都有哪一些

                INSTALLED_APPS = [

                    'django.contrib.admin',

                   'django.contrib.auth',

                   'django.contrib.contenttypes',

                   'django.contrib.sessions',

                   'django.contrib.messages',

                   'django.contrib.staticfiles',

                    'app01',

                    # 'app01.apps.App01Config',  # 推荐这一种,不过目前两种方式都可以

                ]

     

             推荐将函数放到app01下的views.py中

     

         7. 如果出现forbidden,去settings.py中将46行附近的csrf相关行注释掉

                                       

    二. ORM(对象关系映射)

                1. 复习导入pymysql模块,操作数据库数据

                            import pymysql

                            conn = pymysql.connect(

                                        host="127.0.0.1",

                                        port=3306,

                                        user="root",

                                        password="123",

                                        database="day62",

                                        charset="utf8"

                            )

                            cursor = conn.cursor()

                            cursor.execute("select * from user;")

                            ret = cursor.fetchall()

     

                2. 用orm操作数据库(相当于导入jQuery,用jQuery语句($("#id"))替代原生sql语句(   document.getElementById(id)))

            数据表    --对应-->    类

            数据行    --对应-->    实例对象

            字段      --对应-->    属性

                

                3. 代码操作数据库的方式比较;

                            直接执行SQL

                                        优点:执行效率高

                                        缺点:开发效率低

                            按照特定的语法写,翻译成SQL语句再去执行

                                        优点:开发效率高

                                        缺点:执行效率低,你会忘记SQL语句

     

                            总结:ORM和原生的SQL语句,根据具体的应用场景自行取舍。

     

                4. 不同框架用不同的orm

                    e.g. sqlAlchemy  (Flask的orm)

                            

    三. Django里面的ORM的使用:

        1. 告诉Django连接那个数据库 (在settings.py的databases中配置mysql)

            DATABASES = {

                'default': {

                    'ENGINE': 'django.db.backends.mysql',

                    'NAME': 'db1',  # 哪个database

                    'HOST': '127.0.0.1',

                    'PORT': 3306,

                    'USER': 'root',

                    'PASSWORD': '123',

                }

            }

     

        2. 告诉Django怎么连接

            Django默认使用的是MySQLdb模块 连接数据库, 但MySQLdb不支持python3。所以,要告诉Django用pymysql这个模块去连接MySQL

            在settings.py同目录下的__init__.py文件中,指定使用pymysql模块代替MySQLdb

                import pymysql

                pymysql.install_as_MySQLdb()

     

        3. 在app/models.py文件中定义类

            一定要继承models.Model

        4. 执行创建表的操作(在pycharm的terminal中键入)

            1. python3 (/usr/local/bin/python3.6)manage.py makemigrations  --> 将models.py的修改登记到小本本上

            2. python3 (/usr/local/bin/python3.6)manage.py migrate         --> 将修改翻译成SQL语句,去数据库执行

            亦可: Tools -> Run manage.pyTask -> makemigrations;migrate

     

        5. 编辑表

           a. 在pycharm中的Database中(若没有,view-> tool buttons), + -> data source -> mysql -> download missing driver files -> test connection

              添加数据后,找绿色向上箭头保存

     

           b. navicate

     

           c. cmd中sql语句 

     

    四. 常规步骤

    1. 在models中建立一个类

     

    2. 在urls中加上对应关系

     

    3. 在views中添加该函数

     

    4. 在templates中创建该html文件

     

    五. 图书管理系统(项目)

                1. 表结构设计

                            1. 出版社

                            2. 书

                            3. 作者

     

                2. Django的模板语言

                {% for publisher in publisher_list %}  # 注意{%中间没有空格

        <tr>

            <td>{{ publisher.id }}</td>

            <td>{{ publisher.name }}</td>

        </tr>

        {% endfor %}

  • 相关阅读:
    .net基础学java系列(一)视野
    技术栈
    Apollo(阿波罗)携程开源配置管理中心
    .NET 动态调用WCF
    RPC 工作原理
    ServiceStack 简单使用
    PRC 框架选择
    栈vs堆,最详细的对比
    使用SuperSocket打造逾10万长连接的Socket服务
    开源项目练习EF+jQueryUI前后端分离设计
  • 原文地址:https://www.cnblogs.com/zhangyaqian/p/py20180612.html
Copyright © 2011-2022 走看看