
大数据毕业设计:基于python二手商品交易网站 二手商品交易系统 计算机毕业设计(附源码)✅
大数据毕业设计:基于python二手商品交易网站 二手商品交易系统 计算机毕业设计(附源码)✅
毕业设计:2023-2024年计算机专业毕业设计选题汇总(建议收藏)
毕业设计:2023-2024年最新最全计算机专业毕设选题推荐汇总
🍅感兴趣的可以先收藏起来,点赞、关注不迷路,大家在毕设选题,项目以及论文编写等相关问题都可以给我留言咨询,希望帮助同学们顺利毕业 。🍅
1、项目介绍
技术栈:
Python语言、Django框架、MySQL数据库、HTML、基于python的二手交易市场网站
主要功能模块,包括以下功能:
1、用户(买家/卖家)功能模块
(1)商品浏览:包括首页宣传图、广告、分类目录;分类商品依次排列,包括售价,种类,卖家、简介以及库存等信息。
(2)商品评论:用户在购买了商品后会出现商品评论功能。
(3)全文检索:支持对商品种类以及商品名称,简介的关键字检索。
(4)登录注册:用户的登录与注册功能。
(5)网站使用协议:协议签属才能使用。
(6)用户中心:支持用户个人信息,发布商品,修改密码,修改个人信息,查看全部订单,修改收货地址等功能。
(7)购物车:商品加入购物车,选择商品及数量,结算后生成订单。
(8)消息中心:支持卖家和买家爱的沟通。
2、项目界面
(2)系统首页—商品分类
(2)商品分类
(3)商品详情页和购物车功能
(4)购物车和订单功能
(5)个人信息页面
(6)后台数据管理
3、项目说明
主要功能模块,包括以下功能:
1、用户(买家/卖家)功能模块
(1)商品浏览:包括首页宣传图、广告、分类目录;分类商品依次排列,包括售价,种类,卖家、简介以及库存等信息。
(2)商品评论:用户在购买了商品后会出现商品评论功能。
(3)全文检索:支持对商品种类以及商品名称,简介的关键字检索。
(4)登录注册:用户的登录与注册功能。
(5)网站使用协议:协议签属才能使用。
(6)用户中心:支持用户个人信息,发布商品,修改密码,修改个人信息,查看全部订单,修改收货地址等功能。
(7)购物车:商品加入购物车,选择商品及数量,结算后生成订单。
(8)消息中心:支持卖家和买家爱的沟通。
(9)卖家中心:在商品详细信息中通过”联系卖家“或则在评论区通过用户头像进入,可以查询卖家资料,出售记录,上架商品等信息,发送消息联系卖家。
(10)商品下单:包括选择收货地址和支付方式可完成商品的下单功能,按照原子事务处理,下单异常则终止此次下单过程。
2、后台管理员模块
后台管理:支持后台管理功能,包括快捷操作、最近动作显示,商品数据库,用户数据库,订单数据库,购物车数据库的展示,搜索,修改等功能日志。
4、核心代码
def load_data_set(user):
"""
get_user_order
:param user:
:return: 返回用户的订单列表,列表中为商品的主键id
for example [['1', '2'], ['2', '34']]:表示购买进行过两次采购,一次购买1和2号商品,二次购买2号和34号商品
"""
user_order_list = []
for big_order in user.orderinfo_set.all():
user_little_order_list = [str(good.goods.id) for good in big_order.orderdetailinfo_set.all()]
user_order_list.append(user_little_order_list)
data_set = user_order_list
return data_set
from django.db import transaction
from django.http import JsonResponse
from django.shortcuts import render, HttpResponse
from datetime import datetime
from decimal import Decimal
from .models import OrderInfo, OrderDetailInfo
from df_cart.models import CartInfo
from df_user.models import UserInfo
from df_user import user_decorator
@user_decorator.login
def order(request):
uid = request.session['user_id']
user = UserInfo.objects.get(id=uid)
cart_ids = request.GET.getlist('cart_id')
carts = []
total_price = 0
for goods_id in cart_ids:
cart = CartInfo.objects.get(id=goods_id)
carts.append(cart)
total_price = total_price + float(cart.count) * float(cart.goods.gprice)
total_price = float('%0.2f' % total_price)
trans_cost = 10 # 运费
total_trans_price = trans_cost + total_price
context = {
'title': '提交订单',
'page_name': 1,
'user': user,
'carts': carts,
'total_price': float('%0.2f' % total_price),
'trans_cost': trans_cost,
'total_trans_price': total_trans_price,
# 'value':value
}
return render(request, 'df_order/place_order.html', context)
'''
事务提交:
这些步骤中,任何一环节一旦出错则全部退回1
1. 创建订单对象
2. 判断商品库存是否充足
3. 创建 订单 详情 ,多个
4,修改商品库存
5. 删除购物车
'''
@user_decorator.login
@transaction.atomic() # 事务
def order_handle(request):
uid = request.session['user_id']
user = UserInfo.objects.get(id=uid)
tran_id = transaction.savepoint() # 保存事务发生点
cart_ids = request.POST.get('cart_ids') # 用户提交的订单购物车,此时cart_ids为字符串,例如'1,2,3,'
user_id = request.session['user_id'] # 获取当前用户的id
data = {}
try:
order_info = OrderInfo() # 创建一个订单对象
now = datetime.now()
order_info.oid = '%s%d' % (now.strftime('%Y%m%d%H%M%S'), user_id) # 订单号为订单提交时间和用户id的拼接
order_info.odate = now # 订单时间
order_info.user_id = int(user_id) # 订单的用户id
order_info.ototal = Decimal(request.POST.get('total')) # 从前端获取的订单总价
order_info.oaddress = user.uaddress
order_info.save() # 保存订单
for cart_id in cart_ids.split(','): # 逐个对用户提交订单中的每类商品即每一个小购物车
cart = CartInfo.objects.get(pk=cart_id) # 从CartInfo表中获取小购物车对象
order_detail = OrderDetailInfo() # 大订单中的每一个小商品订单
order_detail.order = order_info # 外键关联,小订单与大订单绑定
goods = cart.goods # 具体商品
if cart.count <= goods.gkucun: # 判断库存是否满足订单,如果满足,修改数据库
goods.gkucun = goods.gkucun - cart.count
goods.save()
order_detail.goods = goods
order_detail.price = goods.gprice
order_detail.count = cart.count
order_detail.username=user.uname
order_detail.shopername = goods.gunit
order_detail.save()
cart.delete() # 并删除当前购物车
else: # 否则,则事务回滚,订单取消
transaction.savepoint_rollback(tran_id)
return HttpResponse('库存不足')
data['ok'] = 1
transaction.savepoint_commit(tran_id)
except Exception as e:
print("%s" % e)
print('未完成订单提交')
transaction.savepoint_rollback(tran_id) # 事务任何一个环节出错,则事务全部取消
return JsonResponse(data)
@user_decorator.login
def pay(request):
pass
5、源码获取方式
🍅由于篇幅限制,获取完整文章或源码、代做项目的,查看我的【用户名】、【专栏名称】、【顶部选题链接】就可以找到我啦🍅
感兴趣的可以先收藏起来,点赞、关注不迷路,下方查看👇🏻获取联系方式👇🏻
更多推荐
所有评论(0)