项目概括

  本项目用于针对Django框架的练习,主要分为前端和后端两部分。前端负责用户注册、登录、商品展示以及添加购物车和显示订单列表的功能;后端负责会员信息、商品类别、商品信息的增删改查以及订单状态修改。

知识点总结

  一、Ajax(异步发送请求给后台)

  

// 参数以键值对的形式
$.ajax({
"type": "post"; //请求的方式,一般为post或者get
"url": "/test/" ; //请求的地址
"data": "{}" //携带参数,键值对,可以为空
"dataType": "json"; //返回结果的类型
success: function(data){
//成功执行的方法
} ;
error: function(){
//失败执行的方法
} })

  二、分页(导入django.core.paginator的Paginator包)

  

from django.core.paginator import Paginator

def index(pindex):
if pindex == "":
pindex = 1
user = Users.objects.all()
# 传入需要分页的对象,和每页显示数据的条数
p = Paginator(user,4)
# 获取页码列表
p_num = p.page_range
# 返回第pindex页的实例
pindex = int(pindex)
page = p.page(pindex) '''
判断当前页是否有上一页:page.has_previous
判断当前页是否有下一页:page.has_next
获取上一页的页码:page.previous_page_number
获取下一页的页码:page.next_page_number
'''

  三、密码以md5形式存储数据库

  

import hashlib

# 实例化md5对象
md5 = hashlib.md5()
# md5.update()方法的参数必须是字节型数据
md5.update(bytes(request.POST['password'],encoding="UTF-8"))
# 以16进制格式存储
md5.hexdigest() '''
这里有个坑必须注意:
md5.update()方法会将每次加密的字符进行拼接,所以每次加密前都要重新实例化一次md5实例
'''
import hashlib md5=hashlib.md5()
md5.update(''.encode('utf-8'))
print(md5.hexdigest())
# 输出结果:202cb962ac59075b964b07152d234b70
md5.update(''.encode('utf-8'))
print(md5.hexdigest())
# 输出结果:4297f44b13955235245b2497399d7a93 //有没有发现 和上面对字符串“123”md5加密后的结果不一样 md5=hashlib.md5() //重新定义md5
md5.update(''.encode('utf-8'))
print(md5.hexdigest())
# 输出结果:4297f44b13955235245b2497399d7a93 //发现123123 和上面的结果一样 就验证了 md5.update 是拼接的效果

  四、获取前台传输文件并写入到服务器

import os
import time def write_file(request):
try:
# 使用request.FILES得到上传的文件
pic = request.FILES.get("picture_name")
# 文件.name获取上传文件的名称
# 截取后缀
suffix = pic.name.split('.')[-1]
if suffix.lower() in ['jpg','png']:
# 格式化文件名
file_name = str(time.strftime('%Y%m%d%H%M%S',time.localtime())) + '.' + suffix
upload_path = 'myweb' + os.path.sep + file_name
# 以二进制格式写入文件
with open(upload_path,"wb+") as f:
# chunks():当上传文件比较大时可以采用此方法,先读取一部分内容加载到内存,写入到服务器,然后清空内存;如此重复,可以节省内存空间
for file in pic.chunks():
f.write(file)
context = {"info":"上传成功"}
else:
context = {"info":"上传格式有误!"}
except:
context = {"info":"请选择你要上传的图片!“}
return render(request,"myweb/info.html",context)

  五、模板

    1.模板继承

    {% extends 'myweb/base.html' %}

    需要写在所有的前面,即模板的最顶端

    

    2.加载静态文件

    {% load static from staticfiles %}

    在settings.py文件中配置静态文件路径

    

STATIC_URL = '/static/' STATIC_ROOT = os.path.join(BASE_DIR,'/static/ STATICFILES_DIRS = [ os.path.join(BASE_DIR,'static'), ]

    

    3. 模板填充

    {% block myblock %}

    {% endblock %}

  六、创建虚拟环境

  每次开始一个新的项目最好新创建一个独立的虚拟环境运行,防止多个项目之间环境不兼容。

  • anaconda虚拟环境搭建

    • 查看所有虚拟环境列表

           conda env list

    • 切换虚拟环境

      conda activate my_env

    • 查看当前虚拟环境安装包

      conda list

    • 创建新的虚拟环境

      conda create -n env_name python=x.x

    • 安装django

      pip install django==x.x

    • 虚拟环境中安装额外的包

      conda install -n env_name [package]

    • 删除虚拟环境

      conda remove -n env_name --all

    • 删除虚拟环境中的某个包  

      conda remove --name $env_name $package_name

  

python商城项目总结的更多相关文章

  1. django 商城项目之购物车以及python中的一些redis命令

    最近在用django restframe框架做一个商城项目,有一个关于购物车的业务逻辑,是用cookie和redis存储的购物车信息,在这里记录一下. 完成一个商城项目,如果不做一个购物车,就是十分可 ...

  2. python框架Django实战商城项目之工程搭建

    项目说明 该电商项目类似于京东商城,主要模块有验证.用户.第三方登录.首页广告.商品.购物车.订单.支付以及后台管理系统. 项目开发模式采用前后端不分离的模式,为了提高搜索引擎排名,页面整体刷新采用j ...

  3. Django商城项目笔记No.11用户部分-QQ登录1获取QQ登录网址

    Django商城项目笔记No.11用户部分-QQ登录 QQ登录,亦即我们所说的第三方登录,是指用户可以不在本项目中输入密码,而直接通过第三方的验证,成功登录本项目. 若想实现QQ登录,需要成为QQ互联 ...

  4. Django商城项目笔记No.4用户部分-注册接口-图片验证码

    Django商城项目笔记No.4用户部分-注册接口-图片验证码 1.首先分析注册业务接口 1.1.分析可得,至少这么几个接口 图片验证码 短信验证码 用户名是否存在 手机号是否存在 整体注册接口 图片 ...

  5. Django商城项目笔记No.3用户部分-用户模型类

    Django商城项目笔记No.3用户部分-用户模型类 Django提供了认证系统,文档资料https://yiyibooks.cn/xx/Django_1.11.6/topics/auth/index ...

  6. Django商城项目笔记No.2项目准备工作

    Django商城项目笔记No.2项目准备工作 接着上篇开始,创建好工程之后,随之而来的是怎么配置工程,这篇文章记录如何进行相关的配置 1.pycharm打开工程,进行相关的配置 通过pycharm打开 ...

  7. Github上的python开源项目

    Python开源项目,期待大家和我们一起共同维护 github排名榜单 https://github.com/trending github搜索榜单:https://github.com/search ...

  8. 凡客副总裁崔晓琦离职 曾负责旗下V+商城项目_科技_腾讯网

    凡客副总裁崔晓琦离职 曾负责旗下V+商城项目_科技_腾讯网 凡客副总裁崔晓琦离职 曾负责旗下V+商城项目 腾讯科技[微博]乐天2013年09月18日12:44 分享 微博 空间 微信 新浪微博 邮箱 ...

  9. 商城项目实战 | 1.1 Android 仿京东商城底部布局的选择效果 —— Selector 选择器的实现

    前言 本文为菜鸟窝作者刘婷的连载."商城项目实战"系列来聊聊仿"京东淘宝的购物商城"如何实现. 京东商城的底部布局的选择效果看上去很复杂,其实很简单,这主要是要 ...

随机推荐

  1. mysql被收购 用mariadb

    ~]# systemctl start mysql.service 要启动MySQL数据库是却是这样的提示 Failed to start mysqld.service: Unit not found ...

  2. BZOJ1005--[HNOI2008]明明的烦恼(树的prufer编码)

    1005: [HNOI2008]明明的烦恼 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 5768  Solved: 2253[Submit][Stat ...

  3. Hdu 5884

    hdu 5884 Sort 题意: n个有序序列的归并排序.每次可以选择不超过k个序列进行合并,合并代价为这些序列的长度和,总的合并代价不能超过T, 问k最小是多少. 解法: 1:首先想到的是二分这个 ...

  4. Android学习_注意事项

    一. Fragment中加载ListView public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle ...

  5. 在windows下安装lxml 报错error: Unable to find vcvarsall.bat

    刚开始安装 ,我是使用命令pip install lxml直接进行安装,不过出错了 error: Unable to find vcvarsall.bat 解决方案: 1.首先安装wheel,pip ...

  6. django 快速实现登陆,接着注册的项目写(五)

    1.改项目的urls.py from django.conf.urls import url,include from django.contrib import admin admin.autodi ...

  7. Qt应用Redis实现消息队列

      版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/liulihuo_gyh/article/details/78425763 类似BS模式,客户端发 ...

  8. rc-form 在 typescript 中的报错处理

    1.创建 声明模块 index.d.ts import { Component, ClassicComponentClass, ClassType, ComponentClass, Component ...

  9. CORS和jsonp实现跨域请求

    同源策略:所谓同源是指,域名,协议,端口相同,它是由Netscape提出的一个著名的安全策略,现在所有支持JavaScript 的浏览器都会使用这个策略.当浏览器同时打开两个tab页面(两个不同服务器 ...

  10. [MyBatis] 如何让MyBatis支持代码级事务处理

    MyBatis提供的sqlSession对象是可以用来帮助我们实现事务处理的,方式和JDBC的类似,具体请见代码: import java.sql.Connection; import java.sq ...