汽车销售管理系统完成企业对汽车各种销售信息的管理及维护操作,根据系统的功能和模块划分的原则,主要包括汽车厂家信息的管理,客户信息的管理,汽车信息的管理,采购入库的管理,汽车销售的管理,出入库统计管理等。汽车销售系统的的功能结图如图3-1所示:

代码已经上传github,下载地址:https://github.com/21503882/car-sale

今天和一个朋友共同完成了一个汽车零件销售管理系统项目,我们在开发时选用的框架是框架。我这个朋友知识有限,只会这个框架,哈哈,都是为了方便他。和往常一样选用简单又便捷的MYECLIPSE作为开发工具,这是一个 后台项目。这个系统的介绍是这样的:车配件销售管理最重要的部分是数据的管理、分析及网络推广(包括市场需求)。所以系统应该能够为用户提供精确数据和快速的分析功能,但一直以来人们使用传统人工的方式管理文件档案以及使用简单的、面向部分功能的管理软件,这些软件大都是单机管理、功能较小、效率低、保密性差、且重在内部管理,不能充分体现管理者的管理策略和管理理念。所以一套面向系统、功能全面、简单易用并充分利用Internet网络资源的管理系统必将对汽车配件销售业的销售和管理观念产生重大影响。客户自主地选择自己需要的部件、数量及付款方式向传统的管理软件提出了新的挑战。,一个汽车零件销售管理系统应包含用户角色有管理员、用户。为了能让用户顺利登陆系统完成相关操作,需要为每种登陆角色设置账户和密码字段。
在系统的功能中,订单是一个重要的表。这个表使得商品关联了起来。在订单表中订单的联系方式与商品的mingcheng字段对应
,他们拥有关联关系。

总结得出该系统所有数据为:管理员(admin)、用户(yonghu)、商品(shangpin)、订单(dingdan) 等等

管理员表

字段名 | 类型 | 属性 | 描述
id | INT(11) | PRIMARY KEY | 管理员id
username | VARCHAR(255) | | 账号
password | VARCHAR(255) | | 密码

 

用户表

 

字段名 | 类型 | 属性 | 描述
id | INT(11) | PRIMARY KEY | 用户id
xingming | VARCHAR(255) | | 姓名
nianling | VARCHAR(255) | | 年龄
xingbie | VARCHAR(255) | | 性别
zhiye | VARCHAR(255) | | 职业
quanxian | VARCHAR(255) | | 权限
username | VARCHAR(255) | | 账号
password | VARCHAR(255) | | 密码

商品表

 

字段名 | 类型 | 属性 | 描述
id | INT(11) | PRIMARY KEY | 商品id
mingcheng | VARCHAR(255) | | 名称
zhonglei | VARCHAR(255) | | 种类
leixing | VARCHAR(255) | | 类型
jiage | VARCHAR(255) | | 价格
shuliang | VARCHAR(255) | | 数量

 

 

订单表

 

字段名 | 类型 | 属性 | 描述
id | INT(11) | PRIMARY KEY | 订单id
xingming | VARCHAR(255) | | 姓名
lianxifangshi | VARCHAR(255) | | 联系方式
mingcheng | VARCHAR(255) | | 名称
shuliang | VARCHAR(255) | | 数量
zhonglei | VARCHAR(255) | | 种类
leixing | VARCHAR(255) | | 类型
jiage | VARCHAR(255) | | 价格
shouhuodizhi | VARCHAR(255) | | 收货地址

 

登录页面

JAVAWeb汽车销售管理系统
系统主页面

JAVAWeb汽车销售管理系统

JAVAWeb汽车销售管理系统

汽车厂家管理模块

JAVAWeb汽车销售管理系统

新增客户管理页面

JAVAWeb汽车销售管理系统
客户信息管理模块

新增汽车信息模块

JAVAWeb汽车销售管理系统

汽车信息管理模块页面

JAVAWeb汽车销售管理系统

汽车采购入库模块

JAVAWeb汽车销售管理系统
汽车销售出库模块(一)

JAVAWeb汽车销售管理系统

汽车销售出库模块(二)

汽车库存管理模块

JAVAWeb汽车销售管理系统

汽车入库统计页面

JAVAWeb汽车销售管理系统

汽车出库统计页面

JAVAWeb汽车销售管理系统

package com.lyh.flowers.controller;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;
import java.util.Random;

import javax.annotation.Resource;
import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import javax.validation.Valid;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.ui.ModelMap;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;

import com.lyh.flowers.pojo.User;
import com.lyh.flowers.service.IUserService;
import com.lyh.flowers.util.Md5;
import com.lyh.flowers.util.tools;
import com.taobao.api.ApiException;
import com.taobao.api.DefaultTaobaoClient;
import com.taobao.api.TaobaoClient;
import com.taobao.api.request.AlibabaAliqinFcSmsNumSendRequest;
import com.taobao.api.response.AlibabaAliqinFcSmsNumSendResponse;

@Controller
@RequestMapping("/user")
public class UserController {
 @Resource
 private IUserService userService;

 /*
  * 随机生成颜色
  */
 Color getRandColor(int fc, int bc) {
  Random random = new Random();
  if (fc > 255)
   fc = 255;
  if (bc > 255)
   bc = 255;
  int r = fc + random.nextInt(bc - fc);
  int g = fc + random.nextInt(bc - fc);
  int b = fc + random.nextInt(bc - fc);

  return new Color(r, g, b);

 }

 /**
  * 产生验证码
  */
 @RequestMapping(value = "/getVerifyCode")
 public void getVerifyCode(HttpServletRequest request,
   HttpServletResponse response, Model model, HttpSession httpSession)
   throws IOException {
  int width = 100;
  int height = 50;
  Random random = new Random();

  response.setHeader("Pragma", "No-cache");
  response.setHeader("Cache-Control", "no-cache");
  response.setDateHeader("Expires", 0);

  // 生成缓冲区imag类
  BufferedImage image = new BufferedImage(width, height, 1);
  Graphics g = image.getGraphics(); // 产生imag类的Graphics用于绘制操作

  g.setColor(this.getRandColor(200, 250));
  g.setFont(new Font("Times New Roman", 0, 28));
  g.fillRect(0, 0, width, height);
  // 绘制干扰线
  for (int i = 0; i < 40; i++) {
   g.setColor(this.getRandColor(130, 200));
   int x = random.nextInt(width);
   int y = random.nextInt(height);
   int x1 = random.nextInt(12);
   int y1 = random.nextInt(12);
   g.drawLine(x, y, x + x1, y + y1);
  }
  // 绘制字符
  String strCode = "";
  for (int i = 0; i < 4; i++) {
   String rand = String.valueOf(random.nextInt(10));
   strCode = strCode + rand;
   g.setColor(new Color(20 + random.nextInt(110), 20 + random
     .nextInt(110), 20 + random.nextInt(110)));
   g.drawString(rand, 13 * i + 6, 28);
  }
  // model.addAttribute("verifyCode", strCode);
  httpSession.setAttribute("strCode", strCode);
  g.dispose();
  ImageIO.write(image, "JPEG", response.getOutputStream());
  response.getOutputStream().flush();
 }

 @RequestMapping(value = "/login", method = { RequestMethod.GET })
 public String login(HttpServletRequest request, Model model) {
  return "user/login";
 }

 @RequestMapping(value = "/login", method = { RequestMethod.POST })
 public String dologin(HttpServletRequest request,
   HttpServletResponse response, Model model, HttpSession httpSession)
   throws UnsupportedEncodingException {
  String loginname = request.getParameter("loginname");
  String loginpass = request.getParameter("loginpass");

  User loginUser = userService.loginCheck(loginname, loginpass);

  if (loginUser == null) {
   model.addAttribute("loginname", loginname);
   model.addAttribute("loginpass", loginpass);
   model.addAttribute("msg", "用户名或密码错误");
   return "user/login";
  } else {
   if (0 == loginUser.getStatus()) {
    model.addAttribute("loginname", loginname);
    model.addAttribute("loginpass", loginpass);
    model.addAttribute("msg", "您还没有**");
    return "user/login";
   } else {
    httpSession.setAttribute("sessionUser", loginUser);
    httpSession.setAttribute("userName", loginUser.getLoginname());
    loginname = URLEncoder.encode(loginname, "utf-8");
    Cookie cookie = new Cookie("loginname", loginname);
    cookie.setMaxAge(60 * 60 * 24 * 10);// 保存10天
    response.addCookie(cookie);
    return "redirect:/index.jsp";
   }
  }
 }

 @RequestMapping(value = "/registCheck", method = { RequestMethod.POST })
 @ResponseBody
 public String registCheck(HttpServletResponse response,
   HttpServletRequest request, Model model, HttpSession httpSession) {
  User user = null;
  String email = request.getParameter("email");
  String loginname = request.getParameter("loginname");

  if (email != null) {
   user = userService.findByEmail(email);
   if (user != null) {
    return "已存";
   } else {
    return "未存";
   }
  }

  if (loginname != null) {
   user = userService.findByUserName(loginname);
   if (user != null) {
    return "已存";
   } else {
    return "未存";
   }
  }
  return "未存";
 }

 @RequestMapping(value = "/vCodeCheck", method = { RequestMethod.POST })
 @ResponseBody
 public String vCodeCheck(HttpServletResponse response,
   HttpServletRequest request, Model model, HttpSession httpSession) {
  String vCodeInput = request.getParameter("verifyCode");
  String vCodeSession = (String) httpSession.getAttribute("strCode");

  if (vCodeInput != null) { // 校验验证码
   boolean b = vCodeInput.equals(vCodeSession);
   if (b) {
    return "正确";
   } else {
    return "错误";
   }
  }
  return "正确";
 }

 @RequestMapping("/regist")
 public String regist(HttpServletRequest request, ModelMap model) {
  User user = new User();
  model.addAttribute("user", user);
  return "user/regist";
 }

 @RequestMapping(value = { "/regist" }, method = RequestMethod.POST)
 public String doregist(@Valid User user, BindingResult result,
   ModelMap model) {
  userService.insert(user);
  
//  model.addAttribute("code", "success");
//  model.addAttribute("msg", "恭喜您注册成功,请马上到邮箱**,或点击下方使用电话号码**");
//  return "user/phoneValtion";
  return "mainFrame/msg";
 }

 /**
  * **功能
  */
 @RequestMapping("/activation/{activationCode}")
 public String activation(@PathVariable String activationCode,
   HttpServletRequest requset, ModelMap model)
   throws ServletException, IOException {

  // System.out.println("activationCode:"+activationCode);
  boolean b = userService.activation(activationCode);
  if (b) {
   requset.setAttribute("code", "success");// 通知msg.jsp显示对号
   requset.setAttribute("msg", "恭喜,**成功,请马上登录!");

  } else {
   requset.setAttribute("code", "error");// 通知msg.jsp显示对号
   requset.setAttribute("msg", "**失败!");
  }
  return "mainFrame/msg";
 }

 @RequestMapping(value = "/changePwd", method = { RequestMethod.POST })
 public String dochangePwd(HttpServletRequest request, Model model) {
  String loginpass = request.getParameter("loginpass");
  String newpass = request.getParameter("newpass");
  String reloginpass = request.getParameter("reloginpass");

  User user = (User) request.getSession().getAttribute("sessionUser");

  if (user == null) {
   model.addAttribute("msg", "您还没有登录");
   return "user/login";
  }
  boolean bool = userService.findByUidAndPassword(user.getUid(),
    loginpass);
  if (bool) {
   userService.updatePassWord(user.getUid(), newpass);
   model.addAttribute("msg", "密码修改成功");
   model.addAttribute("code", "success");
   return "mainFrame/msg";
  } else {
   model.addAttribute("msg", "您输入的密码不正确");
   model.addAttribute("loginpass", loginpass);
   model.addAttribute("newpass", newpass);
   model.addAttribute("reloginpass", reloginpass);
   return "user/changePwd";
  }
 }

 @RequestMapping(value = "/changePwd", method = { RequestMethod.GET })
 public String changePwd(HttpServletRequest request, Model model) {
  return "user/changePwd";
 }

 @RequestMapping("/quit")
 public String quit(HttpServletRequest request, Model model) {
  request.getSession().invalidate();
  return "redirect:/index.jsp";
 }

 @RequestMapping(value = "/emailSendCode", method = { RequestMethod.POST })
 @ResponseBody
 public void emailSendCode(HttpServletResponse response,
   HttpServletRequest request, Model model, HttpSession httpSession) {
  String email = request.getParameter("email");

  userService.emailSendCode(email);

 }

 @RequestMapping("/forgotPassword")
 public String forgetPassword(HttpServletRequest request, Model model) {
  return "user/forgetPwd";
 }

 @RequestMapping(value = "/forgotPassword", method = { RequestMethod.POST })
 public String doforgetPassword(HttpServletRequest request, Model model) {
  User user = null;
  String loginname = request.getParameter("loginname");
  user = userService.findByUserName(loginname);
  if (null == user) {
   model.addAttribute("errorMsg", "该用户不存在!");
   return "user/forgetPwd";
  }
  model.addAttribute("email", user.getEmail());
  return "user/forgetPwd2";
 }
 
 @RequestMapping("/forgotPassword3")
 public String forgetPassword3(HttpServletRequest request, Model model) {
  String sid = request.getParameter("sid");
  String uid = request.getParameter("uid");
  System.out.println("sid:" + sid + " uname:" + uid);
  if (sid.equals("") || uid.equals("")) {
   model.addAttribute("msg", "链接不完整,请重新生成");
   model.addAttribute("code", "error");
   return "mainFrame/msg";
  }
  User user = userService.findByUid(uid);

  if (user != null) {
   // 获取当前用户申请找回密码的过期时间
   // 找回密码链接已经过期
   if ((user.getOutDate().getTime()) < (System.currentTimeMillis())) {
    System.out.println("链接已经过期");
    model.addAttribute("msg", "链接已经过期,请重新生成");
    model.addAttribute("code", "error");
    return "mainFrame/msg";
   }
   // 获取当前登陆人的加密码
   String key = user.getUid() + "$" + user.getOutDate() + "$"
     + user.getValidataCode();
   String digitalSignature = Md5.md5(key);// 数字签名
//   System.out.println("digitalSignature:" + digitalSignature);
   if (!digitalSignature.equals(sid)) {
    System.out.println("链接加密密码不正确");
    model.addAttribute("msg", "链接加密密码不正确");
    model.addAttribute("code", "error");
    return "mainFrame/msg";
   } else {
    // 验证成功,跳入到修改密码界面
    model.addAttribute("uid", uid);
    return "user/forgetPwd3";
   }

  } else {
   model.addAttribute("msg", "用户信息不存在");
   model.addAttribute("code", "error");
   return "mainFrame/msg";
  }
 }

 @RequestMapping(value = "/codeCheck", method = { RequestMethod.POST })
 public String verifyCodeCheck(HttpServletRequest request,HttpSession httpSession, Model model) {
  String codeSession = (String) httpSession.getAttribute("vcode");
  String verifyCode=request.getParameter("verifyCode");
//  System.out.println("codeSession:"+codeSession+"verifyCode:"+verifyCode);
  
  if(codeSession.equals(verifyCode)){
   return "user/forgetPwd3";
  }
  else{
   model.addAttribute("errorMsg", "输入的验证码有误");
   model.addAttribute("verifyCode", verifyCode);
   return "user/forgetPwd2";
  }
  
 }
 
 @RequestMapping(value = "/forgotPassword4", method = { RequestMethod.POST })
 public String forgetPassword4(HttpServletRequest request, Model model) {
  String newpass = request.getParameter("loginpass");
  String reloginpass = request.getParameter("reloginpass");
  System.out.println("newpass:" + newpass + "repass" + reloginpass);
  String uid = request.getParameter("uid");
  if (!newpass.equals(reloginpass)) {
   model.addAttribute("msg", "两次输入的密码不一致");
   model.addAttribute("newpass", newpass);
   model.addAttribute("reloginpass", reloginpass);
   return "user/forgetPwd3";
  }
  boolean bool = userService.updatePassWord(uid, newpass);
//  System.out.println("uid:" + uid + "bool:" + bool);
  if (bool) {
   return "user/forgetPwd4";
  } else {
   model.addAttribute("msg", "修改密码不成功");
   model.addAttribute("code", "error");
   return "mainFrame/msg";
  }
 }
 
 /**
  * 获取短信验证码
  */
  @RequestMapping(value ="/getVcode",method = RequestMethod.POST)
  @ResponseBody
  public String getVcode(HttpServletRequest request, HttpSession session) throws ApiException {
   
   String phone = request.getParameter("phone");
   String url = "http://gw.api.taobao.com/router/rest";
   TaobaoClient client = new DefaultTaobaoClient(url,"23762833",
     "0e956ca18685b8a177764a5dc7627835");
   
    AlibabaAliqinFcSmsNumSendRequest req = new AlibabaAliqinFcSmsNumSendRequest();
    req.setExtend("1");
   
    req.setSmsType("normal");
   
    req.setSmsFreeSignName("玫瑰之约网上商城");
    //生成验证码数字
    String vcode = tools.getVcode();
    //存到session域中
    session.setAttribute("vcode",vcode);
//    System.out.println("验证码:"+vcode);
    req.setSmsParamString("{number:'"+vcode+"'}");
   
    req.setRecNum(phone);
    req.setSmsTemplateCode("SMS_62750038");
    AlibabaAliqinFcSmsNumSendResponse rsp = client.execute(req);
    System.out.println(rsp.getBody());
    return "ok";
  }
 
  @RequestMapping(value = "/phoneValtion", method = { RequestMethod.GET })
 public String phoneValtion(HttpServletRequest request, Model model) {
  return "user/phonevaltion";
 }
}
代码已经上传github,下载地址:https://github.com/21503882/car-sale

分类:

技术点:

相关文章: