利用python编写后端程序 通用代码详解 项目实现

前言        

最近自己正好有时间,想要自己搭建微信小程序,也正好记录一下自己的搭建过程和内容。

搭建准备工作 

这里我使用的时pycharm编辑器。在后端开发中,我们需要三个库:

import pymysql
from flask import request, Flask, jsonify
from flask_cors import CORS

连接数据库方法

# 连接数据库
# db = pymysql.connect(host='连接数据库的ip地址',port='端口', user='用户名', password='密码', db='连接的数据库')
db = pymysql.connect(host='127.0.0.1', user='root', password='123456', db='sql_tp')
print(db.port)
cursor = db.cursor()  # 指定数据库指针

启动后端方法

#  启动后端
app = Flask(__name__)
CORS(app, resources=r'/*')  # 解决跨域问题

post和get请求方法

请求的方法基本就是这样,通过组合能实现不同的请求,不拘泥于形式。

# ------------------------------------------------------------------------------------
# ---------------------------------------测试使用方法-----------------------------------
# 接受post请求,收到值返回说明
@app.route('/url', methods=['POST'])
# 后端接口的入口,使用POST方法 比如进入在boot下的word表,可以设“/boot/word”
def func():  # 接口触发做的事情if request.method == "POST":  # 判断是不是post请求username = request.form.get("username")  # 接受前端的参数# t = [t1,t2,t3,t4,t5,t6,t7,t8,t9,t10]t = [1,2,3,1,2,3,1,2,3,1] # 假设接受了多个数据放到t列表中vales = ""for n,i in enumerate(t):  # 将vales变成字符串,就是将t中的数据连接做成sql。if n != len(t)-1:vales = vales+str(i)+","else:vales = vales + str(i)try:sql = "insert into wjy_xcx_tmp value ("+vales+");"   # 插入sql语句。cursor.execute(sql)  # 在后端执行的sql语句cursor.execute("commit;")  # 在后端执行的sql语句cursor.execute("select count(*) from wjy_xcx_tmp;")  # 在后端执行的sql语句date = cursor.fetchone()  # 获取所有查询到的记录,fechaone()返回一条print(date)return jsonify(date) # 返回sql查询出的数据。except Exception as e:return "-1"# return jsonify([]) 返回json数组
# ------------------------------------------------------------------------------------
# ------------------------------------------------------------------------------------#  login登录操作,返回数据库查询到的密码并返回(已完成返回密码操作)
@app.route('/my_system/login', methods=["POST"])  # 使用POST请求
def login():if request.method == 'POST':phone = request.form.get("phone")# 做异常测试try:# 发送数据库cursor.execute("select 密码 from tp_ghao20221230 where 手机号=" + str(phone))data_login = cursor.fetchone()  # 返回第一条查询信息if data_login != None:return jsonify(data_login)  # 号码查找到密码,返回密码else:return '1'  # 数据库未查询到,返回1except Exception as e:print("failed:", e)return '-1'  # 登录操作异常,返回-1#  修改密码操作(已完成修改密码操作)
@app.route('/my_system/login/update', methods=["POST"])  # 使用POST请求
def login_update():if request.method == 'POST':phone = request.form.get("phone")login_password = request.form.get("login_password")# 做异常测试try:# 发送数据库cursor.execute("update tp_ghao20221230 set 密码=\"" + str(login_password) + "\" where 手机号=" + str(phone))db.commit()return '1'  # 完成修改密码操作,返回1except Exception as e:print("failed:", e)return '-1'  # 未完成修改操作,返回-1

主函数

if __name__ == '__main__':app.run(host='0.0.0.0', port=自己定义的接口)  # 启动后端服务器,定义接口,监听端口;0.0.0.0表示都可以访问的地址。db.close()

总结

全部代码可以直接将所有代码放在一起就是一个python的后端程序了。实现起来还是比较简单的。大家可以通过修改sql和部分代码实现自己的python后端。

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

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

相关文章

设计模式详解(二):抽象工厂——Abstract Factory

目录导航 抽象工厂及其作用工厂方法的好处工厂方法的实现关系图实现步骤 工厂方法的适用场景工厂方法举例 抽象工厂及其作用 工厂方法是一种创建型设计模式。所谓创建型设计模式是说针对创建对象方面的设计模式。在面向对象的编程语言里,我们通过对象间的相互协作&…

SAP SD 创建交货单 报错 VL461 VL248

因为生产环境已经被改好了,无法跟踪 所以换到测试环境重现一把,如何追根究底 对比正常订单发现 计划行 VBEP-LMENG,VBEP-BMENG这两个字段上的值跟 订单数量不一致。 尝试修改2者的数据跟订单数据一致,则可以正常创建交货单 实际原因是&a…

【每日一坑】KiCAD导Gerber 文件

第一,软件版本 第二、操作选择注意点 第三,那个坑。。。 不知道什么原因,这第二个框里会选其他不必要得一些东西,导致最终光绘是废的; 一定切记只选edge.cut就好了。 最后,上Gerber图,还有一点…

机器学习入门(第六天)——支持向量机(升维打击)

Support vector machines 知识树 Knowledge tree 苹果表示重点 间隔:使用了几何间隔,保证w b的度量,感知机则是函数间隔 间隔最大化思想:则是支持向量机的独有,这使得它找到最优超平面 核函数:面试当中可…

防火墙补充NAT

目录 1.iptables保存规则 2.自定义链 3.NAT NAT的实现分为下面类型&#xff1a; SNAT实验操作 DNAT实验操作 1.iptables保存规则 永久保存方法一&#xff1a; iptables -save > /data/iptables_rule //输出重定向备份 iptables -restore < /data/iptables_r…

EsayExcel的使用

EsayExcel的使用 引入依赖 <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>3.1.1</version> </dependency>类属性中的注解 # 默认下标从0开始&#xff0c;index可以不…

Windows安装Kafka3.6,单机

Kafka版本&#xff1a;kafka_2.13-3.6.0 Windows10系统 安装与配置 下载 kafka_2.13-3.6.0.tgz 下载并解压Kafka 3.6.0的压缩包到你选择的目录。 Kafka3.6.0下载链接https://kafka.apache.org/downloads 说明&#xff1a;Kafka3.6内置了Zookeeper&#xff0c;使用内置的Zo…

Ps:用好钢笔工具

使用钢笔工具时&#xff0c;应随时注意鼠标指针的形状。 ◆ ◆ ◆ 基本操作方法 1、绘制闭合路径 路径绘制结束时回到起点即可创建闭合路径。 2、绘制开放路径 想结束绘制时&#xff0c;按住 Ctrl 键点击画布空白处&#xff0c;或者&#xff0c;直接按 Esc 键&#xff0c;即可…

传统算法: Pygame 实现快速排序

使用 Pygame 模块实现了快速排序的动画演示。首先,它生成一个包含随机整数的数组,并通过 Pygame 在屏幕上绘制这个数组的条形图。接着,通过快速排序算法对数组进行排序,动画效果可视化每一步的排序过程。在排序的过程中,程序选择一个基准元素(pivot),将数组分成两部分,…

IP地址更改的方法及注意事项,让你的网络更安全稳定

在互联网时代&#xff0c;IP地址是我们上网时的身份标识&#xff0c;它可以追踪我们的上网行为和地理位置。然而&#xff0c;有时我们可能需要更改IP地址&#xff0c;以保护个人隐私&#xff0c;解决网络问题或绕过某些限制。那么&#xff0c;IP地址更改在哪里呢&#xff1f;虎…

腾讯云手动下发指令到设备-用于设备调试

打开腾讯云API Explorer&#xff0c;Publish Msg https://console.cloud.tencent.com/api/explorer?Productiotcloud&Version2021-04-08&ActionPublishMessagehttps://console.cloud.tencent.com/api/explorer?Productiotcloud&Version2021-04-08&ActionPub…

C#图像处理OpenCV开发指南(CVStar,04)——图片像素访问与多种局部放大效果的实现代码

​​​​​​​ 使用本文代码需要预先设置一点开发环境&#xff0c;请阅读另外一篇博文&#xff1a; C#图像处理OpenCV开发指南&#xff08;CVStar&#xff0c;03&#xff09;——基于.NET 6的图像处理桌面程序开发实践第一步https://blog.csdn.net/beijinghorn/article/deta…

RocketMQ-RocketMQ快速实战及集群原理

一、MQ简介 ​ MQ&#xff1a;MessageQueue&#xff0c;消息队列。是在互联网中使用非常广泛的一系列服务中间件。 这个词可以分两个部分来看&#xff0c;一是Message&#xff1a;消息。消息是在不同进程之间传递的数据。这些进程可以部署在同一台机器上&#xff0c;也可以分布…

Nashorn 简介

1. 引言 本文重点介绍 Nashorn – 从 Java 8 开始&#xff0c;JVM 的新默认 JavaScript 引擎。 许多复杂的技术已被用于使 Nashorn 的性能比其前身 Rhino 高出几个数量级&#xff0c;因此这是一个值得的改变。让我们来看看它的一些使用方式。 本文大部分内容翻译自&#xff1…

element-ui表格滚动效果,el-table滚动条样式重置

项目首页需要展示一个表格滚动区域&#xff0c;特此来记录一下 HTML <div class"table-box" mouseenter"mouseenter" mouseleave"mouseleave"><el-table :data"tableList" border height"400px" v-loading"…

华为eNSP AR2220路由器配置教程

文章目录 华为eNSP AR2220路由器配置教程基础配置系统初始化设置用户密码配置设备IP地址 接口配置LAN接口配置WAN接口配置 路由配置静态路由配置动态路由协议配置OSPF配置 安全配置防火墙配置 故障排除查看接口状态日志和诊断测试网络连通性 华为eNSP AR2220路由器配置教程 华…

web前端开发简介及门槛、学习路线

1. 什么是web&#xff1f; Web是 world wide web,万维网,广域网,互联网 Web可以理解是网站 2. 什么网站和网页&#xff1f; 网站是由多个网页和其他文件组成的 3. 什么是web的前端和后端&#xff1f; 4.网页的组成&#xff1a; html: 在网页中真实存在的,例如: 文本,输入…

图像img2img任务任务中评估指标

均方误差&#xff08;Mean Squared Error&#xff0c;MSE&#xff09;&#xff1a;计算两个图像像素之间的平均差异的平方。MSE越小&#xff0c;表示两个图像越接近。 均方根误差&#xff08;Root Mean Squared Error&#xff0c;RMSE&#xff09;&#xff1a;MSE的平方根。RM…

编程之外,生活的美好航程

&#x1f680; 作者主页&#xff1a; 有来技术 &#x1f525; 开源项目&#xff1a; youlai-mall &#x1f343; vue3-element-admin &#x1f343; youlai-boot &#x1f33a; 仓库主页&#xff1a; Gitee &#x1f4ab; Github &#x1f4ab; GitCode &#x1f496; 欢迎点赞…

回顾Django的第二天

1.http 1.1http请求协议与响应协议 1.1.1简介 http协议包含由浏览器发送数据到服务器需要遵循的请求协议与服务器发送数据到浏览器需要遵循的请求协议。用于HTTP协议交互的信被为HTTP报文。请求端(客户端)的HTTP报文 做请求报文,响应端(服务器端)的 做响应报文。HTTP报文本身…