Flask框架小程序后端分离开发学习笔记《1》网络知识

这篇具有很好参考价值的文章主要介绍了Flask框架小程序后端分离开发学习笔记《1》网络知识。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Flask框架小程序后端分离开发学习笔记《1》网络知识

Flask是使用python的后端,由于小程序需要后端开发,遂学习一下后端开发。

一、网址组成介绍

  1. 协议:http,https (https是加密的http)
  2. 主机:g.cn zhihu.com之类的网址
  3. 端口:HTTP协议默认是80,因此一般不用填写
  4. 路径下面的「/question/31838184」是路径
    http://www.zhihu.com/question/31838184
    http://www.zhihu.com:80/

二、通信

电脑通信靠IP地址,IP地址记不住就发明了域名(domain name),然后电脑自动向DNS服务器(domain name server)查询域名对应的IP地址。

比如g.cn这样的网址,可以通过电脑的ping程序查出对应IP地址
ping g.cn
Flask框架小程序后端分离开发学习笔记《1》网络知识,flask,学习,笔记根据域名ping出来的ip不一定是一样的。

三、端口是什么?

一个比喻:
用邮局互相写信的时候,ip相当于地址(也可以看做邮编,地址是域名)
端口是收信人姓名(因为一个地址比如公司、家只有一个地址,但是却可能有很多收信人)
端口就是一个标记收信人的数字。
端口是一个16位的数字,所以范围是 0-65535 (2**16)

顺着ip地址可以找到你的电脑,但是找不到与哪个程序通信。
端口就是某一个程序网络服务的唯一表示,端口是由操作系统分配的,所以当程序关闭端口会被回收,之后重新打开不一定是原先的端口了。

四、HTTP协议

一个传输协议,协议就是双方都遵守的规范。
为什么叫超文本传输协议呢,因为收发的是文本信息。
1,浏览器(客户端)按照规定的格式发送文本数据(请求)到服务器
2,服务器解析请求,按照规定的格式返回数据到浏览器
3,浏览器解析得到的数据,并做相应处理

请求和返回是一样的数据格式,大致可分为4部分:
1,请求行或者响应行
2,Header(请求的 Header中 Host字段是必须的,其他都是可选)
3,lrlnlrln(连续两个换行回车符,用来分隔Header和Body)
4,Body(可选)(数据信息)

请求的格式,注意大小写(这是一个不包含Body的请求):原始数据如下
‘GET / HTTP/1.1\r\nhost:g.cn\r\n\r\n’
打印出来如下两行:
GET / HTTP/1.1
Host: g.cn

其中
1, GET是请求方法(还有POST等,这就是个标志字符串而己)
2,/是请求的路径(这代表根路径)
3,HTTP/1.1中,1.1是版本号,通用了20年
具体字符串是’GET / HTTP/1.1 \r\nhost:g.cn \r\n\r\n ’

返回的数据如下
HTTP/1.1 301 Moved Permanently (1.1为版本、301为状态码)
Alternate-Protocol: 80: quic, p=0,80:quic , p=o
cache-Control: private,max-aqe=2592000
Content-Length: 218 (常见:body页面长度218字节)
Content-Type: text/ html; charset=UTF-8
Date: Tue,07 Jul 2015 02:57:59 GMT
Expires: Tue,07 Jl 2015 02:57:59 GMT
Location: http : / /www. google.cn/
server: gws
X-Frame-options: SAMEORIGIN
X一xSS-Protection: l; mode=block
(header头部)

Body部分太长,先不贴了其中响应行(第一行):

  1. HTTP/1.1是版本
  2. 301 是状态码
  3. Moved Permanently 是状态码的描述
    浏览器会自己解析Header部分,然后将Body显示成网页

五、后端web服务器做什么

主要就是解析请求,发送相应的数据给客户端。
例如下面的代码就是模拟浏览器发送HTTP
请求给服务器并把收到的所有信息打印出来(使用的是最底层的socket,现阶段不必
关心这种低层,web开发是上层开发)

#codinq: utf-8

import socket
# socket 是操作系统用来进行网络通信的底层方案#简而言之,就是发送/接收数据
#创建一个socket对象
#参数socket.AF_INET表示是ipv4协议]#参数socket. sOCK_STREAM表示是tcp协议
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
#这两个其实是默认值,所以你可以不写,如下
#s = socket.socket()    socket只能用于http协议的,不能用于https
#s = ssl. wrap_socket ( socket.socket ( ) )   这个用于https


#主机(域名或者ip)和端口
host = 'g.cn'
port = 80
#用connect函数连接上主机,参数是一个tuple
s.connect( (host,port) )

#连接上后,可以通过这个函数得到本机的ip和端口(本地ip路由器分配得到,本地端口操作系统分配的)
ip, port = s.getsockname()
print('本机ip 和port {}\{}'.format(ip, port))

#构造一个HTTP请求
http_request = 'GET / HTTP/1.1\r\nhost:{}\r\n\r\n'.format(host)

#发送HTTP请求给服务器
#send函数只接受bytes 作为参数
# str.encode把str转换为bytes,编码是utf-8
request = http_request.encode('utf-8')
print('请求',request)
s.send(request)


# 接受服务器的响应数据
#参数是长度,这里为1023字节
#所以这里如果服务器返回的数据中超过1023的部分你就得不到了,正经一次性最长大概1500字节,
response = s.recv (1023)
#输出响应的数据,bytes类型
print('响应',response)
#转成str再输出
print('响应的str 格式',response.decode ('utf-8'))

# 这就是平时我们在浏览器输入“g.cn”时候的内部细节


# 运行结果
# 本机ip 和port 10.2.93.112\53538
# 请求 b'GET / HTTP/1.1\r\nhost:g.cn\r\n\r\n'
# 响应 b'HTTP/1.1 301 Moved Permanently\r\nLocation: https://google.cn/\r\nX-Content-Type-Options: nosniff\r\nServer: sffe\r\nContent-Length: 215\r\nX-XSS-Protection: 0\r\nDate: Tue, 16 Jan 2024 02:26:18 GMT\r\nExpires: Tue, 16 Jan 2024 02:56:18 GMT\r\nCache-Control: public, max-age=1800\r\nContent-Type: text/html; charset=UTF-8\r\nAge: 891\r\n\r\n<HTML><HEAD><meta http-equiv="content-type" content="text/html;charset=utf-8">\n<TITLE>301 Moved</TITLE></HEAD><BODY>\n<H1>301 Moved</H1>\nThe document has moved\n<A HREF="https://google.cn/">here</A>.\r\n</BODY></HTML>\r\n'
# 响应的str 格式 HTTP/1.1 301 Moved Permanently
# Location: https://google.cn/
# X-Content-Type-Options: nosniff
# Server: sffe
# Content-Length: 215
# X-XSS-Protection: 0
# Date: Tue, 16 Jan 2024 02:26:18 GMT
# Expires: Tue, 16 Jan 2024 02:56:18 GMT
# Cache-Control: public, max-age=1800
# Content-Type: text/html; charset=UTF-8
# Age: 891
#
# <HTML><HEAD><meta http-equiv="content-type" content="text/html;charset=utf-8">
# <TITLE>301 Moved</TITLE></HEAD><BODY>
# <H1>301 Moved</H1>
# The document has moved
# <A HREF="https://google.cn/">here</A>.
# </BODY></HTML>

# 上面一部分是浏览器的控制信息,我们看不到的,下面的是网页页面代码,经过浏览器渲染之后就会展示给我们看

本笔记是学习B站某视频的教程,作为一个自己的学习记录,侵删。文章来源地址https://www.toymoban.com/news/detail-796973.html

到了这里,关于Flask框架小程序后端分离开发学习笔记《1》网络知识的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Python - flask后端开发笔记

    ​ Flask入门 有一篇很全面的博客可以参考:Python Flask Web 框架入门 跨域问题处理 文件发送 ​

    2024年02月07日
    浏览(65)
  • Python前后端分离之Django框架最基本后端CRUD开发

    目录   Django介绍: 开发准备 后端编写Django项目里的app模块 编写models.py文件(写模型):  编写序列化文件(serializers.py) 编写视图(Views) 新建urls.py文件,填写路径 ​编辑 进行迁移: 前端: 编写接口文件api.js 编写CRUD文件 编写index.vue文件 前端界面使用: 运行项目: 提

    2024年01月23日
    浏览(68)
  • 聊天机器人开发实战--(微信小程序+SpringCloud+Pytorch+Flask)【后端部分】

    趁着五一有时间,先把大三下个学期的期末作业做了,把微信小程序和Java开发的一起做了。顺便把机器学习的也一起做了。所以的话,我们完整项目的技术体系主要有 微信小程序开发,Java Web开发(因为我喜欢把admin后台管理和用户端服务分开,所有我选择SpringCloud做一个切

    2024年02月03日
    浏览(52)
  • 【后端开发】尚硅谷 SpringCloud 学习笔记

    2.3.1 引入RestTemplate 2.3.2 远程调用支付模块 前面我们没有服务注册中心,也可以服务间调用,为什么还要服务注册? 当服务很多时,单靠代码手动管理是很麻烦的,需要一个公共组件,统一管理多服务,包括服务是否正常运行,等 Eureka用于** 服务注册 ,目前官网 已经停止更新** 创建项目

    2024年02月10日
    浏览(39)
  • 若依框架(前后端分离) 之IDEA中Maven后端打包

    Maven是一个跨平台的项目管理工具。作为Apache组织的一个颇为成功的开源项目,其主要服务于基于Java平台的项目创建,依赖管理和项目信息管理,是一个自动化构建工具。maven是Apache的顶级项目,解释为“专家,内行”,它是一个项目管理的工具,maven自身是纯java开发的(

    2024年02月09日
    浏览(56)
  • 【附源码】基于flask框架基于微信小程序的食疗坊软件开发 (python+mysql+论文)

    本系统(程序 + 源码)带文档 lw 万字以上   文末可获取本课题的源码和程序 选题背景: 随着科技的快速发展和智能手机的普及,微信小程序作为一种轻量级应用,已经渗透到人们日常生活的方方面面。它无需下载安装,即用即走的特点深受用户喜爱。在健康饮食领域,人们

    2024年04月08日
    浏览(74)
  • 前后端分离------后端创建笔记(02)

     本文章转载于【SpringBoot+Vue】全网最简单但实用的前后端分离项目实战笔记 - 前端_大菜007的博客-CSDN博客 仅用于学习和讨论,如有侵权请联系 源码:https://gitee.com/green_vegetables/x-admin-project.git 素材:https://pan.baidu.com/s/1ZZ8c-kRPUxY6FWzsoOOjtA 提取码:up4c 项目概述笔记:https://blog

    2024年02月12日
    浏览(37)
  • 全面解析若依框架(springboot-vue前后分离--后端部分)

    前端启动 后端启动 创建数据库ry-vue,导入ry_2021xxxx.sql,quartz.sql,加载好依赖直接启动。 后端技术 SpringBoot Spring Security JWT MyBatis Druid Fastjson 分页实现 导入导出 上传下载(框架使用的简单,不做讲解) 权限控制 事务管理(这里使用@Transactional,不做讲解,具体和Spring的8种事务

    2024年01月16日
    浏览(56)
  • Python-web开发学习笔记(3):Flask Demo,一个网站开发小案例

    ☕️ 推荐关注我的另一个专栏系列:大道至简,该系列收录了许多优质的人工智能算法博文,包括机器学习和自然语言处理等,持续更新中,欢迎各位关注~   介绍完Python-web开发学习笔记(2)--- HTML基础_尚拙谨言的博客-CSDN博客,我们来搞一个简单的网站小案例,带大家更进

    2024年02月06日
    浏览(44)
  • web开发学习笔记(8.java web后端开发基础知识)

    1.使用spring开发的优势,spring发展到今天已经形成了一种开发生态圈,提供了若干个子项目,每个项目用于完成特定的功能。使用spring全家桶,可以做到很多事情,可以很方便的套用很多的组件。 2.pom构成 指定父工程 指定web构件 指定springboot打包控件 3.启动类的写法 4.contro

    2024年01月18日
    浏览(65)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包