1 web 应用
2 c/s 和bs架构
3 python中的web框架
    a :socket
    b:路由跟视图函数匹配关系
    c:模板渲染
 django: uwsgi/wsgiref
    django: a: 用了别人的wsgiref   b:自己写的   c:自己写的        
    flask: a:用了别人的            b:自己写的   c:用了别人的:jinja2
    tornado: a 自己写的            b:自己写的   c:自己写的
4 http协议:
    -特点:1 基于TCP/IP协议之上的应用层协议
          2 基于请求-响应模式
          3 无状态保存
          4 无连接
 -请求头:
  请求首行 get /?name=sb http/1.1\r\n
     key:value\r\n
     key:value\r\n
     \r\n
     请求体的内容
    
 -响应头:
  响应首行 http/1.1 200 ok \r\n
  响应头:  key:value\r\n
     \r\n
  响应体:  html的代码
 -状态码: 1开头(正在处理)  2开头(处理成功) 3开头(重定向) 4开头(客)5开头(服务端)
5 django的安装和简单使用
    -安装:1 pip3 install django==1.11.9
          2 pycharm 下安装,选择版本号
    -使用:
         命令创建项目:django-admin startproject 项目名字
         创建app:python3 manage.py startapp app01
    -文件目录介绍:
        -manage.py---项目入口,执行一些命令
        -项目名
            -settings:全局配置信息
            -urls:总路由,请求地址跟视图函数的映射关系
        -app名字
            -migrations:数据库迁移的记录
            -models.py  数据库表模型
            -views  视图函数
    -运行项目:
        pytyon3 manage.py runserver 127.0.0.1:8001
  python3 manage.py runserver 8006
  python3 manage.py runserver
 -安装python3.7和django版本1.11.9兼容错误-----解决(逗号)
6 补充:
 0基于wsgiref定义自己的web框架
 from wsgiref.simple_server import make_server
 from url import urls
 from views import error
 def run(env, response):
  print(env) //请求头切分好 放进一个字典
  response("200 OK", [('Content-type', 'text/html')]) //
  position = env['PATH_INFO']
  func = None
  for url in urls:
   if position == url[0]:
    func = url[1]
    break
  if func:
   response = func(env)
  else:
   response = error(env)
  return [response.encode('utf-8'),]
 if __name__ == '__main__':
  ser = make_server('127.0.0.1', 8003, run)
  ser.serve_forever()
    1 decode和encode
        data = b'111111'
        data = str(data, encoding='utf-8')
        print(type(data))
        data = bytes(data, encoding='utf-8')
        print(type(data))
    2 pymysql链接数据库
        #拿到数据库链接
        conn = pymysql.connect(host='127.0.0.1', port=3306, user='root', db='lqz', password='admin')
        #获得游标,并且查询结果数据是字典格式
        cur=conn.cursor(pymysql.cursors.DictCursor)
        #执行sql
        cur.execute('select * from user')
        #获取全部查询结果
   链接数据库(防止注入,推荐以下写法)
     cur.execute('select * from user where name=%s and password=%s ',[name,pwd])
        dic=cur.fetchall()
    3 以后写项目:
        1 不要用中文
        2 计算机名不能用中文
        3 一个工程,就是一个项目

随机推荐

  1. UVA - 11732 "strcmp()" Anyone? (trie)

    https://vjudge.net/problem/UVA-11732 题意 给定n个字符串,问用strcmp函数比较这些字符串共用多少次比较. strcmp函数的实现 int strcmp(cha ...

  2. bzoj千题计划311:bzoj5017: [Snoi2017]炸弹(线段树优化tarjan构图)

    https://www.lydsy.com/JudgeOnline/problem.php?id=5017 暴力: 对于每一个炸弹,枚举所有的炸弹,看它爆炸能不能引爆那个炸弹 如果能,由这个炸弹向引爆 ...

  3. Git与GitHub学习笔记(六)使用 Github Pages 管理项目文档

    前言 你可能比较熟悉如何用 Github Pages 来分享你的工作,又或许你看过一堂教你建立你的第一个 Github Pages 网站的教程.近期 Github Pages 的改进使得从不同的数据源 ...

  4. Spark源码剖析 - SparkContext的初始化(八)_初始化管理器BlockManager

    8.初始化管理器BlockManager 无论是Spark的初始化阶段还是任务提交.执行阶段,始终离不开存储体系.Spark为了避免Hadoop读写磁盘的I/O操作成为性能瓶颈,优先将配置信息.计算结 ...

  5. js中检测数据类型的几种方式

    1.typeof 一元运算符,用来检测数据类型.只可以检测number,string,boolean,object,function,undefined. 对于基本数据类型是没有问题的,但是遇到引用数 ...

  6. oracle杀掉连接

    相关sql --查看当前连接 select count(*) from v$process --数据库允许的最大连接数 select value from v$parameter where name ...

  7. 普通用户从其他主机连接MySQL数据库

    一.登陆数据库 mysql -u root -p [超级用户密码]; 二.创建新用户 CREATE USER 'username'@'host' IDENTIFIED BY 'password'; 参 ...

  8. nexys4ddr数码管动态扫描Verilog例程

    题目:实现数码管动态扫描功能,将十六个开关的值以十六进制的方式在4个数码管上同时显示出来. `timescale 1ns / 1ps module top( clk, sw, seg, an ); / ...

  9. try}-with-resources

    今天看前人代码的时候,发现了一个以前一直没用过的东西, 公司目前使用的是jdk1.8(vertx3需要), 在某处代码里有这样一行代码: try( FileOutputStream fos=new F ...

  10. oracle 对对表匹配的进行修改匹配不上的可以进行新增 (MERGE INTO)

    MERGE语句是Oracle9i新增的语法,用来合并UPDATE和INSERT语句. 通过MERGE语句,根据一张表或子查询的连接条件对另外一张表进行查询, 连接条件匹配上的进行UPDATE,无法匹配 ...