基于javaweb+mysql的ssm鲜花商城系统(java+ssm+jsp+jquery+mysql)
运行环境
Java≥8、MySQL≥5.7、Tomcat≥8
开发工具
eclipse/idea/myeclipse/sts等均可配置运行
适用
课程设计,大作业,毕业设计,项目练习,学习演示等
功能说明
基于javaweb+mysql的SSM鲜花商城系统(java+ssm+jsp+jquery+mysql)
项目介绍
本项目分为前后台,前台为普通用户角色,后台为管理员角色;
管理员角色包含以下功能:
会员信息管理,售后管理,库存管理,查看营业额统计,查看销售量,查询顾客活跃度,留言管理,管理关于我们,管理员登录,管理滚动图片,类别管理,订单管理,资讯管理,鲜花管理等功能。
用户角色包含以下功能:
修改个人资料,发表留言,提交订单,提交评论,查看售后申请,查看商品详情,查看我的收藏,查看我的订单,查看我的购物车,查看留言板,查看鲜花分类,用户登录,确认支付等功能。
环境需要
1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。
2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;
3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可
4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS;
5.是否Maven项目: 否;查看源码目录中是否包含pom.xml;若包含,则为maven项目,否则为非maven项目;
6.数据库:MySql 5.7、8.0等版本均可;
技术栈
-
后端:Spring+springmvc+mybatis
-
前端:JSP+css+javascript+jQuery
使用说明
- 使用Navicat或者其它工具,在mysql中创建对应sql文件名称的数据库,并导入项目的sql文件;
2.使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;
若为maven项目,导入成功后请执行maven clean;maven install命令,配置tomcat
-
将项目中db.properties配置文件中的数据库配置改为自己的配置;
-
运行项目,在浏览器中输入http://localhost:8080/ssm_zxxianhuashop/ 登录;
用户账号/密码: user/123456
管理员账号/密码:admin/admin
model.addAttribute("addrList", addrList);
return "userview/confirm_order";
订单管理控制层:
@Controller
@RequestMapping("/order")
public class OrderController {
@Autowired
private ICartService cartService;
@Autowired
private IGoodsService goodsService;
@Autowired
private IOrderService orderService;
private IAddressService addressService;
@Autowired
private IGuessService guessService;
@RequestMapping("takeOrder")
public String takeOrder(Integer[] goodslist,Integer addr,Model model,HttpServletRequest request){
List<Cart> cartList=new ArrayList<Cart>();
List<OrderDetail> detailList=new ArrayList<OrderDetail>();
Double totalPrice=0D;
for (Integer i : goodslist) {
Cart cart = cartService.findCartById(i);
Users user=(Users) session.getAttribute("user");
if(user!=null){
Guess guess = guessService.findGuessByUserId(user.getUserId(), goods.getGoodsId());
if(guess!=null){
guess.setGuessNum(guess.getGuessNum()+1);
guessService.updateGuess(guess);
}else{
Guess g=new Guess(goods, 1, -1, user);
guessService.addGuess(g);
return "userview/product_detail";
@RequestMapping("findHotGoods")
AlipayClient alipayClient = new DefaultAlipayClient(AlipayConfig.gatewayUrl, AlipayConfig.app_id, AlipayConfig.merchant_private_key, "json", AlipayConfig.charset, AlipayConfig.alipay_public_key, AlipayConfig.sign_type);
//设置请求参数
AlipayTradePagePayRequest alipayRequest = new AlipayTradePagePayRequest();
alipayRequest.setReturnUrl(AlipayConfig.return_url);
alipayRequest.setNotifyUrl(AlipayConfig.notify_url);
Order order = orderService.findOrderById(orderId);
//商户订单号,商户网站订单系统中唯一订单号,必填
String out_trade_no=null;
//付款金额,必填
String total_amount=null;
//订单名称,必填
String subject=null;
try {
HttpSession session = request.getSession();
Users user = (Users) session.getAttribute("user");
List<Order> orderList = orderService.findOrdersByUserIdAndState(user.getUserId(), 5);
return orderList;
@RequestMapping("receiveOrder")
@ResponseBody
public String receiveOrder(String orderId){
Integer rs = orderService.receiveOrder(orderId);
if(rs>0){
return "success";
}else{
return "fail";
Integer[] sheets=new Integer[6];
for(int i=0;i<list.size();i++){
month[i]=list.get(i).getOrderMonth();
total[i]=list.get(i).getTotalMoney();
sheets[i]=list.get(i).getSheets();
JSONObject obj=new JSONObject();
obj.put("month", month);
obj.put("total", total);
obj.put("sheets", sheets);
return obj;
@RequestMapping("findToDo")
@ResponseBody
public JSONObject findToDo(){
return "userview/product_detail";
@RequestMapping("findHotGoods")
@ResponseBody
public List<Goods> findHotGoods(){
return goodsService.findHotGoods(4);
@RequestMapping("search")
public ModelAndView searchGoodsByName(String keyWord){
ModelAndView mv=new ModelAndView();
List<Goods> list = goodsService.findGoodsLikeName(keyWord);
mv.addObject("searchList",list);
obj.put("code", 0);
obj.put("count", info.getTotal());
obj.put("data", info.getList());
return obj;
@RequestMapping("{goodsId}")
public String findAllGoods(@PathVariable("goodsId")Integer goodsId,Model model){
Goods goods = goodsService.findById(goodsId);
List<Evaluate> evaList = evaluateService.findEvaluateByGoodsId(goodsId);
model.addAttribute("goods", goods);
model.addAttribute("evaList", evaList);
return "detail";
@RequestMapping("preUpdate")
String trade_no = new String(request.getParameter("trade_no").getBytes("ISO-8859-1"),"UTF-8");
trade_status = new String(request.getParameter("trade_status").getBytes("ISO-8859-1"),"UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
if(trade_status.equals("TRADE_FINISHED")||trade_status.equals("TRADE_SUCCESS")){
//判断该笔订单是否在商户网站中已经做过处理
//如果没有做过处理,根据订单号(out_trade_no)在商户网站的订单系统中查到该笔订单的详细,并执行商户的业务程序
//如果有做过处理,不执行商户的业务程序
Integer rs = orderService.payForOrder(out_trade_no);
if(rs>0){
System.out.println("异步通知支付成功");
params.put(name, valueStr);
boolean signVerified=false;
try {
signVerified = AlipaySignature.rsaCheckV1(params, AlipayConfig.alipay_public_key, AlipayConfig.charset, AlipayConfig.sign_type);
} catch (AlipayApiException e1) {
e1.printStackTrace();
} //调用SDK验证签名
//——请在这里编写您的程序(以下代码仅作参考)——
/* 实际验证过程建议商户务必添加以下校验:
1、需要验证该通知数据中的out_trade_no是否为商户系统中创建的订单号,
2、判断total_amount是否确实为该订单的实际金额(即商户订单创建时的金额),
}else{
Goods goods = goodsService.findById(goodsId);
Cart c=new Cart(goods, num, goods.getGoodsPrice(), user);
cartService.addGoodsToCart(c);
return "success";
@RequestMapping("findCartByUser")
@ResponseBody
public List<Cart> findCartByUser(HttpServletRequest request){
HttpSession session = request.getSession();
Users user=(Users) session.getAttribute("user");
List<Cart> list = cartService.findCartByUserId(user.getUserId());
@RequestMapping("preOrder")
public String preOrder(Integer[] goodslist,Model model,HttpServletRequest request){
List<Cart> cartList=new ArrayList<Cart>();
for (Integer i : goodslist) {
Cart cart = cartService.findCartById(i);
cartList.add(cart);
model.addAttribute("cartList", cartList);
HttpSession session = request.getSession();
Users user = (Users) session.getAttribute("user");
List<Address> addrList = addressService.findAddressByUserId(user.getUserId());
model.addAttribute("addrList", addrList);
return "userview/confirm_order";
订单管理控制层:
cartList.add(cart);
model.addAttribute("cartList", cartList);
HttpSession session = request.getSession();
Users user = (Users) session.getAttribute("user");
List<Address> addrList = addressService.findAddressByUserId(user.getUserId());
model.addAttribute("addrList", addrList);
return "userview/confirm_order";
订单管理控制层:
@Controller
@RequestMapping("/order")
public class OrderController {
return "fail";
@RequestMapping("addCartNum")
@ResponseBody
public String addCartNum(Integer cartId){
Cart cart = cartService.findCartById(cartId);
cart.setCartNum(cart.getCartNum()+1);
Integer rs = cartService.updateCart(cart);
if(rs>0){
return "success";
}else{
Cart cart = cartService.findCartById(cartId);
cart.setCartNum(cart.getCartNum()-1);
Integer rs = cartService.updateCart(cart);
if(rs>0){
return "success";
}else{
return "fail";
@RequestMapping("addCartNum")
@ResponseBody
public String addCartNum(Integer cartId){
Cart cart = cartService.findCartById(cartId);
cart.setCartNum(cart.getCartNum()+1);
Users user=(Users) session.getAttribute("user");
if(user!=null){
Guess guess = guessService.findGuessByUserId(user.getUserId(), goods.getGoodsId());
if(guess!=null){
guess.setGuessNum(guess.getGuessNum()+1);
guessService.updateGuess(guess);
}else{
Guess g=new Guess(goods, 1, -1, user);
guessService.addGuess(g);
return "userview/product_detail";
@RequestMapping("findHotGoods")
@Autowired
private IEvaluateService evaluateService;
@RequestMapping("findAll")
public String findAllGoods(Model model){
List<Goods> list = goodsService.findAll();
model.addAttribute("goodsList", list);
return "list";
@RequestMapping("/findGoodsDiscounts")
@ResponseBody
public JSONObject findGoodsDiscounts(){
PageInfo<Goods> info = goodsService.findGoodsDiscounts();
JSONObject obj = new JSONObject();
obj.put("msg", "");
} catch (UnsupportedEncodingException e1) {
e1.printStackTrace();
//商品描述,可空
List<OrderDetail> detailList = order.getDetailList();
String body = null;
for (OrderDetail o : detailList) {
body=body+o.getDetailGoods().getGoodsName()+",";
body=body.substring(0, body.length()-1)+"等商品";
alipayRequest.setBizContent("{\"out_trade_no\":\""+ out_trade_no +"\","
+ "\"total_amount\":\""+ total_amount +"\","
+ "\"subject\":\""+ subject +"\","
+ "\"body\":\""+ body +"\","
+ "\"product_code\":\"FAST_INSTANT_TRADE_PAY\"}");