Java项目:微信小程序商城+后台管理系统
作者主页:夜未央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项目:微信小程序商城+后台管理系统相关推荐
- Java项目:微信小程序商城+后台管理系统(java+SSH+JSP+jQuery+Mysql)
源码获取:俺的博客首页 "资源" 里下载! 项目介绍 本项目为小程序商城系统前后台,前台为普通会员用户登录,后台为管理员登录: 程序功能: 1.小程序前台:用户注册登录.首页.轮播 ...
- 王炸!一个开源微信小程序+商城后台管理系统
▲ 源码下载 开源版源码下载地址:http://www.laiketui.com/download github下载地址: https://github.com/bettershop/LaikeTui ...
- 基于java springboot的小说阅读微信小程序含后台管理系统源码
系统运行环境 开发工具 eclipse(idea),mysql5.7(大于5.5),navicat,小程序开发工具 硬件要求 windows操作系统 cpu:2.4GHz 内存:4G 硬盘:100G ...
- 微信小程序记事本+后台管理系统
<微信小程序记事本+后台管理系统>该项目含有源码.论文等资料.配套开发软件.软件安装教程.项目发布教程等 本系统包含微信小程序做的记事本前台和Java做的后台管理系统: 微信小程序--记事 ...
- 微信小程序菜谱+后台管理系统
<微信小程序菜谱+后台管理系统>该项目含有源码.论文等资料.配套开发软件.软件安装教程.项目发布教程等 本系统包含微信小程序做的菜谱前台和Java做的后台管理系统: 微信小程序--菜谱前台 ...
- 微信小程序商城 (后台JAVA)
微信小程序商城(Java版) 技术选型 1 后端使用技术 1.1 springframework4.3.7.RELEASE 1.2 mybatis3.4.1 1.3 shiro1.3.2 1.4 se ...
- 【毕业设计】Java 基于微信小程序的药店管理系统
一.前言 现在药品的种类和厂开始越来越多,而且不同厂的相同类别的药品价格也不样,这对于销售工作人员来说,肯定就会造成定的压力,如果能够借助计算机相关技术实现一个便捷易用的药店管理系统,不仅可以保证各种 ...
- 小程序 实名信息_微信小程序+商城信息管理系统
下载地址长期有效 微信商城信息管理系统(java后台+小程序) 使用方法 >温馨提示 java后台信息管理系统 微信商城小程序 >使用方法 加小编微信进行咨询 >实现功能 一:会员管 ...
- CRMEB全开源Java版微信小程序商城,附源码
CRMEB-JAVA版简介 CRMEB商城JAVA版,SpringBoot + Maven + Swagger + Mybatis Plus + Redis + Uniapp +Vue 包含移动端.小 ...
最新文章
- web前端培训:CSS中单行文本溢出显示省略号的方法
- CCS中给工程加入C66x CSL库和头文件
- 您准备好观看GraphQL了吗?
- 使用WildFly 8在Java EE7中自举Apache Camel
- 一张图看懂阿里云智能媒体管理产品
- The import org.junit.jupiter cannot be resolved 报错
- Gateway源码分析
- python类型转换astype时间_Pandas数据类型转换的几个小技巧
- android之专栏目录
- Machine Learning for Communication Networks
- Nacos集群(一)节点启动初始化源码解析
- Conficker蠕虫病毒只是愚人节玩笑吗
- 无法打开包括文件: “SDKDDKVer.h”问题解决办法
- Pdman数据库建模工具——使用教程
- special effects - 樱花飘落背景特效
- sqlserver 无法远程连接到服务器,解决SQLServer远程连接失败的问题
- 微信开放平台、公众平台的区别
- android测试内存的软件下载,AndroBench p10内存门app下载
- ps滚动字教程:为图像画面添加滚动字幕
- 13.不抱怨的世界--美,威尔.鲍温,陈敬旻译,2017-12-10