作者主页:夜未央5788

简介:Java领域优质创作者、Java项目、学习资料、技术互助

文末获取源码

项目介绍

本项目为小程序商城系统前后台,前台为普通会员用户登录,后台为管理员登录;
程序功能:
1.小程序前台:用户注册登录、首页、轮播图、新品推荐、分类、购物车、我的订单。

2.网站后台:管理员登录、用户管理、商品类别管理、商品管理、订单管理、公告管理;

环境需要

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.数据库:MySql 5.7版本;

6.是否Maven项目: 否;

技术栈

1. 后端:spring+struts+hibernate

2. 前端:JSP+css+javascript+jquery

使用说明

后台运行:
1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;
若为maven项目,导入成功后请执行maven clean;maven install命令,然后运行;
3. 将项目中config/jdbc.properties配置文件中的数据库配置改为自己的配置;
4. 运行项目,在浏览器中输入http://localhost:8080/shop
管理员:admin/111111

前台小程序运行:
1.使用微信开发者工具导入项目;
2.导入成功后编译运行;
3.运行成功后登录账号;

普通用户:ceshi/111111

运行截图

前台小程序

后管页面

相关代码

信息管理控制器

@Controller
@RequestMapping("/message")
public class MessageController extends BaseController {/*** 依赖注入 start dao/service/===*/@Autowiredprivate MessageService messageService;// --------------------------------------- 华丽分割线 ------------------------------/*********************************查询列表【不分页】***********************************************//*** 【不分页 => 查询列表 => 无条件】* @Title: listAll * @Description: TODO(这里用一句话描述这个方法的作用) * @param @return 设定文件 * @author* @return String 返回类型 * @throws*/@RequestMapping(value = "/listAll")public String listAll(Message message, Model model, HttpServletRequest request, HttpServletResponse response){List<Message> listAll = messageService.listAll();model.addAttribute("list", listAll);return "message/message";}/***  【不分页=》查询列表=>有条件】* @Title: listByEntity * @Description: TODO(这里用一句话描述这个方法的作用) * @param @return 设定文件 * @author* @return String 返回类型 * @throws*/@RequestMapping(value = "/listByEntity")public String listByEntity(Message message, Model model, HttpServletRequest request, HttpServletResponse response){List<Message> listAll = messageService.listAllByEntity(message);model.addAttribute("list", listAll);return "message/message";}/***  【不分页=》查询列表=>有条件】* @Title: listByMap * @Description: TODO(这里用一句话描述这个方法的作用) * @param @return 设定文件 * @author * @return String 返回类型 * @throws*/@RequestMapping(value = "/listByMap")public String listByMap(Message message, Model model, HttpServletRequest request, HttpServletResponse response){//通过map查询Map<String,Object> params = new HashMap<String,Object>();if(!isEmpty(message.getName())){params.put("name", message.getName());}if(!isEmpty(message.getPhone())){params.put("phone", message.getPhone());}if(!isEmpty(message.getContent())){params.put("content", message.getContent());}List<Message> listAll = messageService.listByMap(params);model.addAttribute("list", listAll);return "message/message";}/*********************************查询列表【分页】***********************************************//*** 分页查询 返回list对象(通过对象)* * @param request* @param response* @return*/@RequestMapping(value = "/findByObj")public String findByObj(Message message, Model model, HttpServletRequest request, HttpServletResponse response) {//分页查询Pager<Message> pagers = messageService.findByEntity(message);model.addAttribute("pagers", pagers);//存储查询条件model.addAttribute("obj", message);return "message/message";}/*** 分页查询 返回list对象(通过Map)* * @param request* @param response* @return*/@RequestMapping(value = "/findByMap")public String findByMap(Message message, Model model, HttpServletRequest request, HttpServletResponse response) {//通过map查询Map<String,Object> params = new HashMap<String,Object>();if(!isEmpty(message.getName())){params.put("name", message.getName());}if(!isEmpty(message.getPhone())){params.put("phone", message.getPhone());}if(!isEmpty(message.getContent())){params.put("content", message.getContent());}//分页查询Pager<Message> pagers = messageService.findByMap(params);model.addAttribute("pagers", pagers);//存储查询条件model.addAttribute("obj", message);return "message/message";}/**********************************【增删改】******************************************************//*** 跳至添加页面* @return*/@RequestMapping(value = "/add")public String add() {return "message/add";}/*** ajax 添加* @param * @return*/@RequestMapping(value = "/exAdd", method = RequestMethod.POST)@ResponseBodypublic String exAdd(Message message, Model model, HttpServletRequest request, HttpServletResponse response) {messageService.insert(message);JSONObject jsonObject = new JSONObject();jsonObject.put("message", "添加成功");return jsonObject.toString();}/*** 跳至修改页面* @return*/@RequestMapping(value = "/update")public String update(Integer id,Model model) {Message obj = messageService.load(id);model.addAttribute("obj",obj);return "message/update";}/*** 添加修改* @return*/@RequestMapping(value = "/exUpdate")public String exUpdate(Message message, Model model, HttpServletRequest request, HttpServletResponse response) {//1.通过实体类修改,可以多传修改条件messageService.update(message);//2.通过主键id修改//messageService.updateById(message);return "redirect:/message/findByObj";}/*** 删除通过主键* @return*/@RequestMapping(value = "/delete")public String delete(Integer id, Model model, HttpServletRequest request, HttpServletResponse response) {///1.通过主键删除messageService.deleteById(id);/*以下是多种删除方式*/
//      //2.通过实体条件删除
//      messageService.deleteByEntity(message);
//      //3.通过参数删除
//     //通过map查询
//      Map<String,Object> params = new HashMap<String,Object>();
//
//        if(!isEmpty(message.getName())){
//          params.put("name", message.getName());
//      }
//
//        if(!isEmpty(message.getPhone())){
//          params.put("phone", message.getPhone());
//      }
//
//        if(!isEmpty(message.getContent())){
//          params.put("content", message.getContent());
//      }
//
//      messageService.deleteByMap(params);
//      //4.状态删除
//      Message load = messageService.getById(message.getId())
//      load.setIsDelete(1);
//      messageService.update(load);//5.状态删除//Message load = messageService.load(id);//load.setIsDelete(1);//messageService.update(load);return "redirect:/message/findByObj";}// --------------------------------------- 华丽分割线 ------------------------------// --------------------------------------- 【下面是ajax操作的方法。】 ------------------------------/*********************************查询列表【不分页】***********************************************//*** 【不分页 => 查询列表 => 无条件】* @Title: listAll * @Description: TODO(这里用一句话描述这个方法的作用) * @param @return 设定文件 * @author* @return String 返回类型 * @throws*/@RequestMapping(value = "/listAllJson", method = RequestMethod.POST)@ResponseBodypublic String listAllJson(Message message, HttpServletRequest request, HttpServletResponse response){List<Message> listAll = messageService.listAll();JSONObject jsonObject = new JSONObject();jsonObject.put("list", listAll);jsonObject.put("obj", message);return jsonObject.toString();}/***  【不分页=》查询列表=>有条件】* @Title: listByEntity * @Description: TODO(这里用一句话描述这个方法的作用) * @param @return 设定文件 * @author* @return String 返回类型 * @throws*/@RequestMapping(value = "/listByEntityJson", method = RequestMethod.POST)@ResponseBodypublic String listByEntityJson(Message message,  HttpServletRequest request, HttpServletResponse response){List<Message> listAll = messageService.listAllByEntity(message);JSONObject jsonObject = new JSONObject();jsonObject.put("list", listAll);jsonObject.put("obj", message);return jsonObject.toString();}/***  【不分页=》查询列表=>有条件】* @Title: listByMap * @Description: TODO(这里用一句话描述这个方法的作用) * @param @return 设定文件 * @author * @return String 返回类型 * @throws*/@RequestMapping(value = "/listByMapJson", method = RequestMethod.POST)@ResponseBodypublic String listByMapJson(Message message,HttpServletRequest request, HttpServletResponse response){//通过map查询Map<String,Object> params = new HashMap<String,Object>();if(!isEmpty(message.getName())){params.put("name", message.getName());}if(!isEmpty(message.getPhone())){params.put("phone", message.getPhone());}if(!isEmpty(message.getContent())){params.put("content", message.getContent());}List<Message> listAll = messageService.listByMap(params);JSONObject jsonObject = new JSONObject();jsonObject.put("list", listAll);jsonObject.put("obj", message);return jsonObject.toString();}/*** 分页查询 返回list json(通过对象)* * @param request* @param response* @return*/@RequestMapping(value = "/findByObjJson", method = RequestMethod.POST)@ResponseBodypublic String findByObjByEntityJson(Message message, HttpServletRequest request, HttpServletResponse response) {//分页查询Pager<Message> pagers = messageService.findByEntity(message);JSONObject jsonObject = new JSONObject();jsonObject.put("pagers", pagers);jsonObject.put("obj", message);return jsonObject.toString();}/*** 分页查询 返回list json(通过Map)* * @param request* @param response* @return*/@RequestMapping(value = "/findByMapJson",  method = RequestMethod.POST)@ResponseBodypublic String findByMapJson(Message message,HttpServletRequest request, HttpServletResponse response) {//通过map查询Map<String,Object> params = new HashMap<String,Object>();if(!isEmpty(message.getName())){params.put("name", message.getName());}if(!isEmpty(message.getPhone())){params.put("phone", message.getPhone());}if(!isEmpty(message.getContent())){params.put("content", message.getContent());}//分页查询Pager<Message> pagers = messageService.findByMap(params);JSONObject jsonObject = new JSONObject();jsonObject.put("pagers", pagers);jsonObject.put("obj", message);return jsonObject.toString();}/*** ajax 添加* @param * @return*/@RequestMapping(value = "/exAddJson", method = RequestMethod.POST)@ResponseBodypublic String exAddJson(Message message, Model model, HttpServletRequest request, HttpServletResponse response) {messageService.insert(message);JSONObject jsonObject = new JSONObject();jsonObject.put("message", "添加成功");return jsonObject.toString();}/*** ajax 修改* @param * @return*/@RequestMapping(value = "/exUpdate.json", method = RequestMethod.POST)@ResponseBodypublic String exUpdateJson(Message message, Model model, HttpServletRequest request, HttpServletResponse response) {//1.通过实体类修改,可以多传修改条件messageService.update(message);//2.通过主键id修改//messageService.updateById(message);JSONObject jsonObject = new JSONObject();jsonObject.put("message", "修改成功");return jsonObject.toString();}/*** ajax 删除* @return*/@RequestMapping(value = "/delete.json", method = RequestMethod.POST)@ResponseBodypublic String exDeleteJson(Integer id, Model model, HttpServletRequest request, HttpServletResponse response) {///1.通过主键删除messageService.deleteById(id);/*以下是多种删除方式*/
//      //2.通过实体条件删除
//      messageService.deleteByEntity(message);
//      //3.通过参数删除
//        //通过map查询
//      Map<String,Object> params = new HashMap<String,Object>();
//
//        if(!isEmpty(message.getName())){
//          params.put("name", message.getName());
//      }
//
//        if(!isEmpty(message.getPhone())){
//          params.put("phone", message.getPhone());
//      }
//
//        if(!isEmpty(message.getContent())){
//          params.put("content", message.getContent());
//      }
//
//      messageService.deleteByMap(params);
//      //4.状态删除
//      Message load = messageService.getById(message.getId())
//      load.setIsDelete(1);
//      messageService.update(load);//5.状态删除//Message load = messageService.load(id);//load.setIsDelete(1);//messageService.update(load);JSONObject jsonObject = new JSONObject();jsonObject.put("message", "删除成功");return jsonObject.toString();}/*** 单文件上传* @param file* @param request* @param model* @return*/@RequestMapping(value = "/saveFile")  public String saveFile(@RequestParam(value = "file", required = false) MultipartFile file, HttpServletRequest request, Model model) {  System.out.println("开始");  String path = request.getSession().getServletContext().getRealPath("/upload");  String fileName = file.getOriginalFilename();  System.out.println(path);  File targetFile = new File(path, fileName);  if(!targetFile.exists()){  targetFile.mkdirs();  }  //保存  try {  file.transferTo(targetFile);  } catch (Exception e) {  e.printStackTrace();  }  return "";  }  /*** springMvc多文件上传* @param files* @param id* @return*/@RequestMapping(value = "/saveFiles")public String saveFiles(@RequestParam("file") CommonsMultipartFile[] files,Integer id,HttpServletRequest request){for(int i = 0;i<files.length;i++){System.out.println("fileName---------->" + files[i].getOriginalFilename());if(!files[i].isEmpty()){int pre = (int) System.currentTimeMillis();try {//拿到输出流,同时重命名上传的文件String filePath = request.getRealPath("/upload");File f=new File(filePath);if(!f.exists()){f.mkdirs();}String fileNmae=new Date().getTime() + files[i].getOriginalFilename();File file=new File(filePath+"/"+pre + files[i].getOriginalFilename());if(!file.exists()){file.createNewFile();}files[i].transferTo(file);} catch (Exception e) {e.printStackTrace();System.out.println("上传出错");}}}return "";}// --------------------------------------- 华丽分割线 ------------------------------}

信息管理控制器

@Controller
@RequestMapping("/news")
public class NewsController extends BaseController {/*** 依赖注入 start dao/service/===*/@Autowiredprivate NewsService newsService;// --------------------------------------- 华丽分割线 ------------------------------/*********************************查询列表【不分页】***********************************************//*** 【不分页 => 查询列表 => 无条件】* @Title: listAll * @Description: TODO(这里用一句话描述这个方法的作用) * @param @return 设定文件 * @author* @return String 返回类型 * @throws*/@RequestMapping(value = "/listAll")public String listAll(News news, Model model, HttpServletRequest request, HttpServletResponse response){List<News> listAll = newsService.listAll();model.addAttribute("list", listAll);return "news/news";}/***  【不分页=》查询列表=>有条件】* @Title: listByEntity * @Description: TODO(这里用一句话描述这个方法的作用) * @param @return 设定文件 * @author* @return String 返回类型 * @throws*/@RequestMapping(value = "/listByEntity")public String listByEntity(News news, Model model, HttpServletRequest request, HttpServletResponse response){List<News> listAll = newsService.listAllByEntity(news);model.addAttribute("list", listAll);return "news/news";}/***  【不分页=》查询列表=>有条件】* @Title: listByMap * @Description: TODO(这里用一句话描述这个方法的作用) * @param @return 设定文件 * @author * @return String 返回类型 * @throws*/@RequestMapping(value = "/listByMap")public String listByMap(News news, Model model, HttpServletRequest request, HttpServletResponse response){//通过map查询Map<String,Object> params = new HashMap<String,Object>();if(!isEmpty(news.getName())){params.put("name", news.getName());}if(!isEmpty(news.getContent())){params.put("content", news.getContent());}if(!isEmpty(news.getAddTime())){params.put("addTime", news.getAddTime());}List<News> listAll = newsService.listByMap(params);model.addAttribute("list", listAll);return "news/news";}/*********************************查询列表【分页】***********************************************//*** 分页查询 返回list对象(通过对象)* * @param request* @param response* @return*/@RequestMapping(value = "/findByObj")public String findByObj(News news, Model model, HttpServletRequest request, HttpServletResponse response) {//分页查询Pager<News> pagers = newsService.findByEntity(news);model.addAttribute("pagers", pagers);//存储查询条件model.addAttribute("obj", news);return "news/news";}@RequestMapping(value = "/list")public String list(News news, Model model, HttpServletRequest request, HttpServletResponse response) {//分页查询Pager<News> pagers = newsService.findByEntity(news);model.addAttribute("pagers", pagers);//存储查询条件model.addAttribute("obj", news);return "news/list";}/*** 分页查询 返回list对象(通过Map)* * @param request* @param response* @return*/@RequestMapping(value = "/findByMap")public String findByMap(News news, Model model, HttpServletRequest request, HttpServletResponse response) {//通过map查询Map<String,Object> params = new HashMap<String,Object>();if(!isEmpty(news.getName())){params.put("name", news.getName());}if(!isEmpty(news.getContent())){params.put("content", news.getContent());}if(!isEmpty(news.getAddTime())){params.put("addTime", news.getAddTime());}//分页查询Pager<News> pagers = newsService.findByMap(params);model.addAttribute("pagers", pagers);//存储查询条件model.addAttribute("obj", news);return "news/news";}/**********************************【增删改】******************************************************//*** 跳至添加页面* @return*/@RequestMapping(value = "/add")public String add() {return "news/add";}/*** 添加执行* @return*/@RequestMapping(value = "/exAdd")public String exAdd(News news, Model model, HttpServletRequest request, HttpServletResponse response) {news.setAddTime(new Date());newsService.insert(news);return "redirect:/news/findByObj";}/*** 跳至修改页面* @return*/@RequestMapping(value = "/update")public String update(Integer id,Model model) {News obj = newsService.load(id);model.addAttribute("obj",obj);return "news/update";}/*** 跳至修改页面* @return*/@RequestMapping(value = "/view")public String view(Integer id,Model model) {News obj = newsService.load(id);model.addAttribute("obj",obj);return "news/view";}/*** 添加修改* @return*/@RequestMapping(value = "/exUpdate")public String exUpdate(News news, Model model, HttpServletRequest request, HttpServletResponse response) {//1.通过实体类修改,可以多传修改条件newsService.updateById(news);//2.通过主键id修改//newsService.updateById(news);return "redirect:/news/findByObj";}/*** 删除通过主键* @return*/@RequestMapping(value = "/delete")public String delete(Integer id, Model model, HttpServletRequest request, HttpServletResponse response) {///1.通过主键删除newsService.deleteById(id);/*以下是多种删除方式*/
//      //2.通过实体条件删除
//      newsService.deleteByEntity(news);
//      //3.通过参数删除
//     //通过map查询
//      Map<String,Object> params = new HashMap<String,Object>();
//
//        if(!isEmpty(news.getName())){
//          params.put("name", news.getName());
//      }
//
//        if(!isEmpty(news.getContent())){
//          params.put("content", news.getContent());
//      }
//
//        if(!isEmpty(news.getAddTime())){
//          params.put("addTime", news.getAddTime());
//      }
//
//      newsService.deleteByMap(params);
//      //4.状态删除
//      News load = newsService.getById(news.getId())
//      load.setIsDelete(1);
//      newsService.update(load);//5.状态删除//News load = newsService.load(id);//load.setIsDelete(1);//newsService.update(load);return "redirect:/news/findByObj";}// --------------------------------------- 华丽分割线 ------------------------------// --------------------------------------- 【下面是ajax操作的方法。】 ------------------------------/*********************************查询列表【不分页】***********************************************//*** 【不分页 => 查询列表 => 无条件】* @Title: listAll * @Description: TODO(这里用一句话描述这个方法的作用) * @param @return 设定文件 * @author* @return String 返回类型 * @throws*/@RequestMapping(value = "/listAllJson", method = RequestMethod.POST)@ResponseBodypublic String listAllJson(News news, HttpServletRequest request, HttpServletResponse response){List<News> listAll = newsService.listAll();JSONObject jsonObject = new JSONObject();jsonObject.put("list", listAll);jsonObject.put("obj", news);return jsonObject.toString();}/***  【不分页=》查询列表=>有条件】* @Title: listByEntity * @Description: TODO(这里用一句话描述这个方法的作用) * @param @return 设定文件 * @author* @return String 返回类型 * @throws*/@RequestMapping(value = "/listByEntityJson", method = RequestMethod.POST)@ResponseBodypublic String listByEntityJson(News news,  HttpServletRequest request, HttpServletResponse response){List<News> listAll = newsService.listAllByEntity(news);JSONObject jsonObject = new JSONObject();jsonObject.put("list", listAll);jsonObject.put("obj", news);return jsonObject.toString();}/***  【不分页=》查询列表=>有条件】* @Title: listByMap * @Description: TODO(这里用一句话描述这个方法的作用) * @param @return 设定文件 * @author * @return String 返回类型 * @throws*/@RequestMapping(value = "/listByMapJson", method = RequestMethod.POST)@ResponseBodypublic String listByMapJson(News news,HttpServletRequest request, HttpServletResponse response){//通过map查询Map<String,Object> params = new HashMap<String,Object>();if(!isEmpty(news.getName())){params.put("name", news.getName());}if(!isEmpty(news.getContent())){params.put("content", news.getContent());}if(!isEmpty(news.getAddTime())){params.put("addTime", news.getAddTime());}List<News> listAll = newsService.listByMap(params);JSONObject jsonObject = new JSONObject();jsonObject.put("list", listAll);jsonObject.put("obj", news);return jsonObject.toString();}/*** 分页查询 返回list json(通过对象)* * @param request* @param response* @return*/@RequestMapping(value = "/findByObjJson", method = RequestMethod.POST)@ResponseBodypublic String findByObjByEntityJson(News news, HttpServletRequest request, HttpServletResponse response) {//分页查询Pager<News> pagers = newsService.findByEntity(news);JSONObject jsonObject = new JSONObject();jsonObject.put("pagers", pagers);jsonObject.put("obj", news);return jsonObject.toString();}/*** 分页查询 返回list json(通过Map)* * @param request* @param response* @return*/@RequestMapping(value = "/findByMapJson",  method = RequestMethod.POST)@ResponseBodypublic String findByMapJson(News news,HttpServletRequest request, HttpServletResponse response) {//通过map查询Map<String,Object> params = new HashMap<String,Object>();if(!isEmpty(news.getName())){params.put("name", news.getName());}if(!isEmpty(news.getContent())){params.put("content", news.getContent());}if(!isEmpty(news.getAddTime())){params.put("addTime", news.getAddTime());}//分页查询Pager<News> pagers = newsService.findByMap(params);JSONObject jsonObject = new JSONObject();jsonObject.put("pagers", pagers);jsonObject.put("obj", news);return jsonObject.toString();}/*** ajax 添加* @param * @return*/@RequestMapping(value = "/exAddJson", method = RequestMethod.POST)@ResponseBodypublic String exAddJson(News news, Model model, HttpServletRequest request, HttpServletResponse response) {newsService.insert(news);JSONObject jsonObject = new JSONObject();jsonObject.put("message", "添加成功");return jsonObject.toString();}/*** ajax 修改* @param * @return*/@RequestMapping(value = "/exUpdate.json", method = RequestMethod.POST)@ResponseBodypublic String exUpdateJson(News news, Model model, HttpServletRequest request, HttpServletResponse response) {//1.通过实体类修改,可以多传修改条件newsService.update(news);//2.通过主键id修改//newsService.updateById(news);JSONObject jsonObject = new JSONObject();jsonObject.put("message", "修改成功");return jsonObject.toString();}/*** ajax 删除* @return*/@RequestMapping(value = "/delete.json", method = RequestMethod.POST)@ResponseBodypublic String exDeleteJson(Integer id, Model model, HttpServletRequest request, HttpServletResponse response) {///1.通过主键删除newsService.deleteById(id);/*以下是多种删除方式*/
//      //2.通过实体条件删除
//      newsService.deleteByEntity(news);
//      //3.通过参数删除
//        //通过map查询
//      Map<String,Object> params = new HashMap<String,Object>();
//
//        if(!isEmpty(news.getName())){
//          params.put("name", news.getName());
//      }
//
//        if(!isEmpty(news.getContent())){
//          params.put("content", news.getContent());
//      }
//
//        if(!isEmpty(news.getAddTime())){
//          params.put("addTime", news.getAddTime());
//      }
//
//      newsService.deleteByMap(params);
//      //4.状态删除
//      News load = newsService.getById(news.getId())
//      load.setIsDelete(1);
//      newsService.update(load);//5.状态删除//News load = newsService.load(id);//load.setIsDelete(1);//newsService.update(load);JSONObject jsonObject = new JSONObject();jsonObject.put("message", "删除成功");return jsonObject.toString();}/*** 单文件上传* @param file* @param request* @param model* @return*/@RequestMapping(value = "/saveFile")  public String saveFile(@RequestParam(value = "file", required = false) MultipartFile file, HttpServletRequest request, Model model) {  System.out.println("开始");  String path = request.getSession().getServletContext().getRealPath("/upload");  String fileName = file.getOriginalFilename();  System.out.println(path);  File targetFile = new File(path, fileName);  if(!targetFile.exists()){  targetFile.mkdirs();  }  //保存  try {  file.transferTo(targetFile);  } catch (Exception e) {  e.printStackTrace();  }  return "";  }  /*** springMvc多文件上传* @param files* @param id* @return*/@RequestMapping(value = "/saveFiles")public String saveFiles(@RequestParam("file") CommonsMultipartFile[] files,Integer id,HttpServletRequest request){for(int i = 0;i<files.length;i++){System.out.println("fileName---------->" + files[i].getOriginalFilename());if(!files[i].isEmpty()){int pre = (int) System.currentTimeMillis();try {//拿到输出流,同时重命名上传的文件String filePath = request.getRealPath("/upload");File f=new File(filePath);if(!f.exists()){f.mkdirs();}String fileNmae=new Date().getTime() + files[i].getOriginalFilename();File file=new File(filePath+"/"+pre + files[i].getOriginalFilename());if(!file.exists()){file.createNewFile();}files[i].transferTo(file);} catch (Exception e) {e.printStackTrace();System.out.println("上传出错");}}}return "";}// --------------------------------------- 华丽分割线 ------------------------------}

如果也想学习本系统,下面领取。关注并回复:001小程序

Java项目:微信小程序商城+后台管理系统相关推荐

  1. Java项目:微信小程序商城+后台管理系统(java+SSH+JSP+jQuery+Mysql)

    源码获取:俺的博客首页 "资源" 里下载! 项目介绍 本项目为小程序商城系统前后台,前台为普通会员用户登录,后台为管理员登录: 程序功能: 1.小程序前台:用户注册登录.首页.轮播 ...

  2. 王炸!一个开源微信小程序+商城后台管理系统

    ▲ 源码下载 开源版源码下载地址:http://www.laiketui.com/download github下载地址: https://github.com/bettershop/LaikeTui ...

  3. 基于java springboot的小说阅读微信小程序含后台管理系统源码

    系统运行环境 开发工具 eclipse(idea),mysql5.7(大于5.5),navicat,小程序开发工具 硬件要求 windows操作系统 cpu:2.4GHz 内存:4G 硬盘:100G ...

  4. 微信小程序记事本+后台管理系统

    <微信小程序记事本+后台管理系统>该项目含有源码.论文等资料.配套开发软件.软件安装教程.项目发布教程等 本系统包含微信小程序做的记事本前台和Java做的后台管理系统: 微信小程序--记事 ...

  5. 微信小程序菜谱+后台管理系统

    <微信小程序菜谱+后台管理系统>该项目含有源码.论文等资料.配套开发软件.软件安装教程.项目发布教程等 本系统包含微信小程序做的菜谱前台和Java做的后台管理系统: 微信小程序--菜谱前台 ...

  6. 微信小程序商城 (后台JAVA)

    微信小程序商城(Java版) 技术选型 1 后端使用技术 1.1 springframework4.3.7.RELEASE 1.2 mybatis3.4.1 1.3 shiro1.3.2 1.4 se ...

  7. 【毕业设计】Java 基于微信小程序的药店管理系统

    一.前言 现在药品的种类和厂开始越来越多,而且不同厂的相同类别的药品价格也不样,这对于销售工作人员来说,肯定就会造成定的压力,如果能够借助计算机相关技术实现一个便捷易用的药店管理系统,不仅可以保证各种 ...

  8. 小程序 实名信息_微信小程序+商城信息管理系统

    下载地址长期有效 微信商城信息管理系统(java后台+小程序) 使用方法 >温馨提示 java后台信息管理系统 微信商城小程序 >使用方法 加小编微信进行咨询 >实现功能 一:会员管 ...

  9. CRMEB全开源Java版微信小程序商城,附源码

    CRMEB-JAVA版简介 CRMEB商城JAVA版,SpringBoot + Maven + Swagger + Mybatis Plus + Redis + Uniapp +Vue 包含移动端.小 ...

最新文章

  1. web前端培训:CSS中单行文本溢出显示省略号的方法
  2. CCS中给工程加入C66x CSL库和头文件
  3. 您准备好观看GraphQL了吗?
  4. 使用WildFly 8在Java EE7中自举Apache Camel
  5. 一张图看懂阿里云智能媒体管理产品
  6. The import org.junit.jupiter cannot be resolved 报错
  7. Gateway源码分析
  8. python类型转换astype时间_Pandas数据类型转换的几个小技巧
  9. android之专栏目录
  10. Machine Learning for Communication Networks
  11. Nacos集群(一)节点启动初始化源码解析
  12. Conficker蠕虫病毒只是愚人节玩笑吗
  13. 无法打开包括文件: “SDKDDKVer.h”问题解决办法
  14. Pdman数据库建模工具——使用教程
  15. special effects - 樱花飘落背景特效
  16. sqlserver 无法远程连接到服务器,解决SQLServer远程连接失败的问题
  17. 微信开放平台、公众平台的区别
  18. android测试内存的软件下载,AndroBench p10内存门app下载
  19. ps滚动字教程:为图像画面添加滚动字幕
  20. 13.不抱怨的世界--美,威尔.鲍温,陈敬旻译,2017-12-10

热门文章

  1. 国产凝思LINX操作系统——常见问题处理
  2. 【求解器】超级强大的数学规划模型求解器Cplex,导入idea+java代码简单案例详解
  3. php 下载小说到txt
  4. Power BI十大视觉效果,知多少?
  5. setInterval函数的用法
  6. 电脑数据恢复软件有哪些,电脑数据恢复软件怎么用
  7. matlab自动色阶,自动色阶算法实现
  8. flutter 关于国际化l10n失效问题
  9. 12.React Native文件创建、查看、下载、上传-react-native-fs
  10. Word Ladder系列