Django的各种初识

1,django项目的各个文件的介绍

1.1>项目的根目录:是各个子文件的根目录,在各个文件相互导入文件的时候使用

1.2>配置文件:为django的各个文件配置相关的各种默认配置

1.3>路径和函数的对应关系:是当form表单提交数据的时候和有关于网址的东西都会来urls来查找向对应的东西

1.4> 项目的静态文件:用于存放于静态的比如:css,js,bootstrap,jQuery,img文件等

1.5>templates:存放HTML文件的地方

1.6>manager:是命令行入口文件

1.7>db.aqlite3:django开发环境默认的文件数据库

2,浏览器和django服务器请求,响应的过程

 第一步先向服务器get login的页面这次是请求,(method=get)

第二步,当访问服务器的时候,服务器获取到login/(通过request)去urls去寻找login函数

在第三步,django会帮助login自动执行login函数,并传一个request的参数,这个request是django封装了所有和浏览器请求有关的所有的键值对

第四步执行login函数的以后,要返回login的html文件,在这里render是返回文件的专属

 

在第四步return返回给调用者,(其实是返回给了request)此时,request里有html文件的路径,然后浏览器去渲染这个html文件 

3,form表单提交数据的三要素:

  3.1>form标签必须标签必须要有action和method属性(action是向那提交数据,method是以什么样的方式提交数据(post,get))

   3.2>所有获取用户输入的标签必须放在form表单中,必须要有name属性(name=值的键值对 ) 

    3.3>必须要有submit按钮(提交)

4,django基础必会三件套

  from django.shortcuts import  HttpResponse,render,redirect

  4.1>HttpResponse:返回一个指定的字符串

  4.2>render:返回一个html文件

  4.3>redirect:跳转

5,request相关的属性

  5.1>request.method  --->返回的是请求的方法(全大写):GET/POST...

  5.2>request.GET      --->取得的是URL里面的参数,类似于字典的节后数据

  5.3>request.POST   --->post提交的数据,类似于字典的数据结构

6,Django的模板数据语言:{{变量名}}

7,程序连接pymysql

  7.1>导入偏移MySQL模块

  7.2>创建连接

  7.3>获取执行命令的油表

  7.4>用油表去执行sql语句

  7.5>获取sql语句查询的结果

  7.6>关闭油表

  7.7>关闭连接

7.8>在django中有一种工具帮助翻译sql语句  -->ORM(Object Relationship Model)

优点:1>开发效率高

  2>开发并不用直接写sql语句

缺点:执行效率低

从面向对象的角度去看数据库中的表,一张表就是一个类,表中的每一个字段就是一个类中的属性,每一行就是类实例化的一个对象

8,django项目中的APP --->项目中又分了一级python包,不同的功能房到不同的包里面

  8.1>创建app-->python manage.py startapp app01

  8.2>告诉Django创建一个APP

    在setting.py找到那个INSTALLED_APPS中添加创建的app

9,Django中ORM的使用

  9.1>操作数据表

  9.2>操作数据行

10,使用

  10.1>手动创建一个数据库:---->create database 数据库名

  10.2>告诉Django连那个数据库

    DATABASES = {

      default:{

          "ENGINE":"django.db.backends.mysql"#连接数据库的类型

          "NAME":"数据库名",#数据库名

          "HOST":"127.0.0.1",#数据主机的地址

          "PORT":"3306",#数据库的端口

          "USER":"root",#数据的使用者是管理员

          "PASSEORD":""  

}

}

  10.3>连接数据库的方式

    利用第三方的包,eg:pymysql和MYSQLdb,告诉django用pymysql模块代替默认的MYSQLdb去连接MYSQL数据库和setting.py同级的__init__.py文件,写上:

    import pymysql

    pymysql.install_as_MYSQLdb()

  10.4>在app/models.py的文件中创建类

    类必须继承models.Model

  10.5>两个命令

    10.5.1>python manage.py makemigrations --->找个本本把models.py的变更记录一下

    10.5.2>python manage.py migrate  -->把上面变更的记录翻译成SQL语句,去数据库中执行

11,ORM查询

  类名(表名).object,filter(email="",pwd="")表的字段

11,登录函数的代码

# views业务逻辑代码
from app01.models import UserInfo  # 把数据库导入进来
def login(request):# 定义一个全局变量当第一次进来获取页面的时候,不显示html变量的信息error_msg = ""if request.method == "POST": # 1, 第二次进来的时候是POST请求要获取用户输入的用户名和密码 new_email = request.POST.get("email") new_pwd = request.POST.get("pwd") # 2, 从数据库中读取数据并校验用户输入的是否合法 ret_obj = UserInfo.objects.filter(email= new_email, pwd= new_pwd) # 判断匹配是否成功 if ret_obj: # 此时如果匹配成功,得到的是匹配的对象 # 如果匹配成功,就说明存在该用户,让用户执行可执行得到操作页面 return redirect("/index/") # 跳转到index这个页面,同网站跳转用绝对路径 # 假如没有匹配成功就要给用于提示页面 error_msg = "邮箱或者密码不正确 " # 3, 如果是第一次进来,用户需要获得一个登录页面,这时是一个get请求 return render(request, "login.html", {"error_msg":error_msg}) def index(reuest): return render(request, "index.html", {"error_msg":error_msg})

 

 

 

 

 

 

转载于:https://www.cnblogs.com/ljc-0923/p/9801817.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/426607.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IIS介绍

IIS7及以上版本提供的请求-处理架构包括以下内容: • Windows Process Activation Service(WAS)可以让站点支持更多协议,不仅仅是HTTP和HTTPS • 可以通过增加或移除模块来自定义Web服务器引擎 • 集成IIS和ASP.NET请求-处理管线 IIS中的组件 IIS包含多个…

Linux卸载MariaDB

CentOS7.5 安装MySQL8.0.12 安装前:  先卸载 CentOS7.5默认安装的MariaDB,配置文件在/etc/my.cnf rpm -qa | grep mariadb 找到 使用 yum remove mariadb-libs-5.5.56-2.el7.x86_64 再次查找 rpm -qa | grep mariadb 同时,配置文件在/etc/my.cnf 也已经…

win10安装iis(亲测,工作需要)

• 点击“Windows”键进入“开始”菜单,点击“所有应用”,在所有应用菜单里点击“Windows系统”里的“控制面板” • 在控制面板对话框里点击“程序” • 在“程序”对话框里点击“启用或关闭Windows功能” • 在“Windows功能”对话框里选中“Interne…

视频展示

作业要求:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2189 视频链接:http://v.youku.com/v_show/id_XMzg2Mzg1NzE0OA.html 视频播放截图及介绍: 1.成语考试中: 2.少年面对成语难得直挠头: 3.父亲发现孩子…

java 8 io_Java IO8:IO简单总结

字节流、字符流继承关系前几篇文章讲解了字节流、字符流的使用,不过Java提供给用户的流类远不止此,限于篇幅原因,没办法一一讲解,而且也没有必要一一讲解,就像我在写博客的时候多次提到的,有问题的时候学会…

java学习(37):二维数组

/4 利用嵌套循环完成以下二维数组的遍历,体会二维数组或多维数组元素的遍历方法及每个维数数组元素的下标特点。/ import java.util.Scanner; public class test06 { public static void main(String[] args){ Scanner in new Scanner(System.in); System.out.print…

java学习(38):数组排序(直接排序)

/5 有一个长度为10的int类型数组,存储了10个年龄数据,利用Eclipse工具设计一个java控制台程序, 完成将这个int类型数组中年龄进行算法对比,将10个年龄重新存储在新数组中,新数组中存储年龄应符合以下规则: 降序排列 ./ import java.util.Scanner; public class test07 { public…

java学习(39):九九乘法表

public class test08{ public static void main(String[] args){ for(int i1;i<9;i){ System.out.println(); for(int j1;j<i;j){ System.out.print("\t"i""j""(ij)); } } } }

java学习(40):成员实例的定义和访问

定义一个student类 public class student { String name;//输入姓名 int age;//输入年龄 String address;//输入地址 char sex;//输入性别 double height;//输入身高 } 定义一个teststudent类 //成员实例的定义和访问 public class testStudent { public static void main(Stri…

java学习(41):成员实例的定义和访问续

定义一个studentstudy类 /1 使用Eclipse编写控制台应用程, 编写一个用来表示学生的java类&#xff0c; 并在类中定义描述学生特征的属性&#xff0c;姓名&#xff0c;年龄&#xff0c;性别&#xff0c;身高&#xff0c;体重和电话&#xff0c; 要求属性设置为私有访问级别并为私…

ftp的本地用户搭建

前期的准备跟虚拟用户一样&#xff0c;就是配置文件不一样 修改配置文件 就是共享的都是自己的账号的家目录&#xff0c;然后启动服务就可以了 本地登陆的都是自己的账号密码 ftp本地的黑名单&#xff0c; 转载于:https://www.cnblogs.com/cash-su/p/9824553.html

java学习(42):巩固练习

定义一个testjava类 /*4 编写一个TestStudentOverrideConstructor.java类&#xff0c; 包含main方法&#xff0c;从控制台接收用户输入的学生信息&#xff0c;包括学生姓名&#xff0c;性别和年龄&#xff0c;使用带参数的构造器创建学生对象并将接收到的输入传递给这个构造器参…

oracle 11g数据库数据操作(亲测)

oracle 11g安装和oracle数据库监听配置就不说了&#xff0c;直接说数据库的相关操作 建立 wiicare 用户 create directory dump_dir as ‘d:\test\dump’; 使用 PLSQL Developer 连接数据库 登陆数据库&#xff0c;用户名:system 密码: 123456 连接为&#xff1a;sysdba 新建表…

【论文阅读】Deep Adversarial Subspace Clustering

导读&#xff1a; 本文为CVPR2018论文《Deep Adversarial Subspace Clustering》的阅读总结。目的是做聚类&#xff0c;方法是DASCDSC&#xff08;Deep Subspace Clustering&#xff09;GAN&#xff08;Generative Adversarial Networks&#xff09;。本文从以下四个方面来对论…

java 值相同 hashcode_搞懂 Java equals 和 hashCode 方法

image搞懂 Java equals 和 hashCode 方法分析完 Java List 容器的源码后&#xff0c;本来想直接进入 Set 和 Map 容器的源码分析&#xff0c;但是对于这两种容器&#xff0c;内部存储元素的方式的都是以键值对相关的&#xff0c;而元素如何存放&#xff0c;便与 equals 和 hash…

Hadoop学习笔记

1.Hadoop安装 Apache的国内镜像地址&#xff1a; 地址1&#xff1a;http://mirror.bit.edu.cn/apache/ 地址2&#xff1a;https://mirrors.tuna.tsinghua.edu.cn/apache Fuck CSDN&#xff0c;谁给你的权利把开源的东西作为商品&#xff08;下载积分&#xff09;售卖&#xff1…

玩转oracle 11g(1):Oracle 11g的安装

由于工作需要&#xff0c;本人现在要对oracle 11g做一段攻坚战&#xff0c;先从安装开始 基本是傻瓜程序&#xff0c;网上也有大量教程 1 安装数据库软件 安装前准备工作 a.必须使用超级用户安装&#xff08;adminstrator&#xff09; b.服务器的名称不要有汉字 c.服务器的名称…

WEB基本架构

转载于:https://www.cnblogs.com/JerryZao/p/9843804.html

玩转oracle 11g(2):创建数据库

纯属个人操作&#xff0c;不懂私聊我 在程序列表中 oracle 的文件下&#xff0c;找到 database configuration assistant 下一步 继续下一步 定制数据库 命名测试歌谣 取消勾选&#xff0c;下一步 为所有用户设置密码 geyao 下一步 点击编辑归档参数 档案资料库取消勾…

玩转oracle 11g(3):配置监听

1打开oracle net configuration 2下一步 3服务名歌谣 4下一步 5主机名电脑的 6测试 输入账号密码总会把&#xff0c;不多说