基于SSM的“网约车用户服务平台”的设计与实现(源码+数据库+文档)

基于SSM的"网约车用户服务平台"的设计与实现(源码+数据库+文档)

  • 开发语言:Java

  • 数据库:MySQL

  • 技术:SSM

  • 工具:IDEA/Ecilpse、Navicat、Maven

系统展示

系统功能

首页

站内新闻浏览

打车信息查询功能

在线打车功能

司机接单管理

后台管理员管理功能

摘要

本文讲述了使用JSP语言及HTML5语言及MySql数据库技术开发的网约车服务平台的设计与实现。本文所讲的网约车服务平台是通过所学的知识创办一个类似于滴滴打车或者高德打车性质的网站平台,使所有需要打车出行的用户以及网约车的司机都可以体验到专业的打车及接单服务,用户只需要在我们网站上注册为会员用户,通过个人后台的打车功能就可以进行打车了,除此之外还可以在上面进行历史订单的查看从而查看自己近期的打车记录,也可以写评价将自己满意或不满意的打车体验呈现给其他用户。在人们日常的生活中,如果想通过打车的形式出行,就要在路边等候出租车,但有时候等很久都不会有出租车来,特别是在偏远的地方。JSP网约车服务平台的开发不管是对想打车出行的用户们还是通过开网约车赚外快的司机来说,都提高了效率。

课题背景及意义

当今网络发展的十分迅猛,人们的生活节奏变化的也非常的快。在我们日常的生活中有很多非常智能的软件,除此之外新兴的智能软件也如雨后春笋般的出现,人们的生活方式也一点一点的被潜移默化的改变着,当今社会的这种生活方式也是一种更人性化的"懒人"模式,比如人们在出行的时候可以提前预定机票、火车票等票据,也可以在到达目的地之前提前预定要下榻的酒店,甚至饿了可以随时通过手机进行点餐。

各种打车软件现在已经成了生活中不可缺少的调味品,比如比较全面的滴滴打车,还有汇聚了很多歌打车软件的高德打车。拥有一个功能丰富、操作方便的网约车服务平台,可以汇聚广大网民,吸引流量。网约车服务平台的建立,从广大用户的角度来说,给他们创建了一个可以进行线上打车的平台,而且无须排队等候就可以享受打车服务。拥有一个如此专业的网约车服务平台,可以使所有的用户都能更方便的出行,把等车的时间更好地利用在生活和工作中。

国内外研究现状

国内外研究现状

当今社会发展趋势越来越迅猛,传统打车方式的没落,我认为这并不是不能避免的,很多都在改变,人们的出行不希望再等待。电子产品的普及,使大家的生活都充满了新的活力,不管是什么职业、什么身份的人都越来越依靠我们的互联网,所以互联网时代也就迅速发展了起来。因此,国家大力推动,推动其向全国推广,但是由于越来越多得人选择线上打车,使得出租车行业越来越无人问津。事实上很多人也不想让出租车行业没落,但是仅依靠少数人的努力是无法改变现状的,将来出租车公司的发展情况是难以预测的。所以,本文借助实现网约车服务平台的这个契机,把我们所学到的只是结合起来,让所有打车的用户和网约车司机建立联系,这可以帮助用户更好的进行打车服务。

研究思路

研究思路

首先在开发这个系统之前需要对整个项目进行立项及可行性分析,画出本系统的原型图及编写出可行性研究报告,通过这一系列分析才决定这个项目到底可不可行,能否进行开发。

第二步是进行项目计划的制定,比如在某个时间区间内要完成哪一个模块的功能,完成的时间如果提前或者滞后该怎样解决等。

第三步是进行需求分析,需求分析可以说是在项目进行编码之前最重要的一步,需求分析主要是对系统的功能模块做一个详细的设计,模块与模块之间的联系,功能与功能之间的优先级、难易度都是需要在这个阶段进行分析的

第四步是进行系统设计,系统设计主要包含数据库的详细设计、系统中页面的规划与区分、系统中的文件命名等内容,做好这一步在编码部分会更加得心应手,编码变的更有效率。

第五步是代码编写阶段,按照严格的命名规范和编程习惯进行功能的实现。

第六步是对已经编码完成的系统模块进行测试,这个地方要注意的是不能等所有的功能都完成之后再去测试,而应该编码与测试同步进行,这样可以缩短整个的项目周期。

部分源码

java 复制代码
@Controller
public class LiuyanbanController {
	@Resource
	private LiuyanbanServer liuyanbanService;


//	
   @RequestMapping("showLiuyanban.do")
   public String showLiuyanban(int id,ModelMap map,HttpSession session){
	 /*  Map<String,Object> bmap=new HashMap<String,Object>();
	   bmap.put("uid", id);*/
	  // map.put("blist", liuyanbanService.getAll(bmap));
	   map.put("liuyanban", liuyanbanService.getById(id));
	   return "read";
   }
   
	@RequestMapping("addLiuyanban.do")
	public String addLiuyanban(HttpServletRequest request,Liuyanban liuyanban,HttpSession session){
		Timestamp time=new Timestamp(System.currentTimeMillis());
		//Users u=(Users)session.getAttribute("user");
		/*if(u==null||u.equals("")){
			return "redirect:showIndex.do";
		}else{*/
			
		    liuyanban.setAddtime(time.toString().substring(0, 19));
			liuyanbanService.add(liuyanban);
			session.setAttribute("backxx", "添加成功");
			session.setAttribute("backurl", "lybList.do");
			return "redirect:postback.jsp";
			//return "redirect:liuyanbanList.do";
		/*}*/
		
		
	}
 
//	处理编辑
	@RequestMapping("doUpdateLiuyanban.do")
	public String doUpdateLiuyanban(int id,ModelMap map,Liuyanban liuyanban){
		liuyanban=liuyanbanService.getById(id);
		map.put("liuyanban", liuyanban);
		return "liuyanban_updt";
	}
	
	
	
	@RequestMapping("doUpdateLiuyanbanlb.do")
	public String doUpdateLiuyanbanlb(int id,ModelMap map,Liuyanban liuyanban){
		liuyanban=liuyanbanService.getById(id);
		map.put("liuyanban", liuyanban);
		return "liuyanban_updtlb";
	}
	
@RequestMapping("updateLiuyanbanlb.do")
	public String updateLiuyanbanlb(int id,ModelMap map,Liuyanban liuyanban){
		liuyanbanService.updatelb(liuyanban);
		return "redirect:liuyanbanList.do";
	}
	
//	后台详细
	@RequestMapping("LiuyanbanDetail.do")
	public String LiuyanbanDetail(int id,ModelMap map,Liuyanban liuyanban){
		liuyanban=liuyanbanService.getById(id);
		map.put("liuyanban", liuyanban);
		return "liuyanban_detail";
	}
//	前台详细
	@RequestMapping("lybDetail.do")
	public String lybDetail(int id,ModelMap map,Liuyanban liuyanban){
		liuyanban=liuyanbanService.getById(id);
		map.put("liuyanban", liuyanban);
		return "liuyanbandetail";
	}
//	
	@RequestMapping("updateLiuyanban.do")
	public String updateLiuyanban(int id,ModelMap map,Liuyanban liuyanban){
		liuyanbanService.update(liuyanban);
		return "redirect:liuyanbanList.do";
	}

//	分页查询
	@RequestMapping("liuyanbanList.do")
	public String liuyanbanList(@RequestParam(value="page",required=false)String page,
			ModelMap map,HttpSession session,Liuyanban liuyanban, String cheng, String xingbie, String QQ, String youxiang, String shouji, String neirong, String huifuneirong){
		/*if(session.getAttribute("user")==null){
			return "login";
		}*/
		if(page==null||page.equals("")){
			page="1";
		}
		PageBean pageBean=new PageBean(Integer.parseInt(page), 15);
		Map<String, Object> pmap=new HashMap<String,Object>();
		pmap.put("pageno", pageBean.getStart());
		pmap.put("pageSize", 15);
		
		
		if(cheng==null||cheng.equals("")){pmap.put("cheng", null);}else{pmap.put("cheng", cheng);}
		if(xingbie==null||xingbie.equals("")){pmap.put("xingbie", null);}else{pmap.put("xingbie", xingbie);}
		if(QQ==null||QQ.equals("")){pmap.put("QQ", null);}else{pmap.put("QQ", QQ);}
		if(youxiang==null||youxiang.equals("")){pmap.put("youxiang", null);}else{pmap.put("youxiang", youxiang);}
		if(shouji==null||shouji.equals("")){pmap.put("shouji", null);}else{pmap.put("shouji", shouji);}
		if(neirong==null||neirong.equals("")){pmap.put("neirong", null);}else{pmap.put("neirong", neirong);}
		if(huifuneirong==null||huifuneirong.equals("")){pmap.put("huifuneirong", null);}else{pmap.put("huifuneirong", huifuneirong);}
		
		int total=liuyanbanService.getCount(pmap);
		pageBean.setTotal(total);
		List<Liuyanban> list=liuyanbanService.getByPage(pmap);
		map.put("page", pageBean);
		map.put("list", list);
		session.setAttribute("p", 1);
		return "liuyanban_list";
	}
	
	
	
	@RequestMapping("lybList.do")
	public String lybList(@RequestParam(value="page",required=false)String page,
			ModelMap map,HttpSession session,Liuyanban liuyanban, String cheng, String xingbie, String QQ, String youxiang, String shouji, String neirong, String huifuneirong){
		/*if(session.getAttribute("user")==null){
			return "login";
		}*/
		if(page==null||page.equals("")){
			page="1";
		}
		PageBean pageBean=new PageBean(Integer.parseInt(page), 15);
		Map<String, Object> pmap=new HashMap<String,Object>();
		pmap.put("pageno", pageBean.getStart());
		pmap.put("pageSize", 15);
		
		
		if(cheng==null||cheng.equals("")){pmap.put("cheng", null);}else{pmap.put("cheng", cheng);}
		if(xingbie==null||xingbie.equals("")){pmap.put("xingbie", null);}else{pmap.put("xingbie", xingbie);}
		if(QQ==null||QQ.equals("")){pmap.put("QQ", null);}else{pmap.put("QQ", QQ);}
		if(youxiang==null||youxiang.equals("")){pmap.put("youxiang", null);}else{pmap.put("youxiang", youxiang);}
		if(shouji==null||shouji.equals("")){pmap.put("shouji", null);}else{pmap.put("shouji", shouji);}
		if(neirong==null||neirong.equals("")){pmap.put("neirong", null);}else{pmap.put("neirong", neirong);}
		if(huifuneirong==null||huifuneirong.equals("")){pmap.put("huifuneirong", null);}else{pmap.put("huifuneirong", huifuneirong);}
		
		int total=liuyanbanService.getCount(pmap);
		pageBean.setTotal(total);
		List<Liuyanban> list=liuyanbanService.getByPage(pmap);
		map.put("page", pageBean);
		map.put("list", list);
		session.setAttribute("p", 1);
		return "lyblist";
	}
	
	@RequestMapping("deleteLiuyanban.do")
	public String deleteLiuyanban(int id,HttpServletRequest request){
		liuyanbanService.delete(id);
		String url = request.getHeader("Referer");
		return "redirect:"+url;
		//return "redirect:liuyanbanList.do";
	}
	
}

结论

基于JSP的网约车服务平台使用的编程技术为JSP+HTML5+MySql数据库的开发模式,是如今普遍率最高最便捷的一种。网站的功能完全按照自己在需求分析阶段所制定的详细功能图,并且在数据的查询操作方面进行了优化,使用存储过程、索引等数据库对象进行数据的操作,极大程度的提高数据的查询效率。除此之外还对前台页面进行了优化,使用了最新的HTML5技术,使所有设备都能完美的运行本网站。

这次网约车服务平台的开发,感受最深的除了是对各种编程技术的运用,就是对软件测试的了解更加深入了,测试真的很重要,开发者站在用户以及商户的角度,各个方面进行测试考虑到所有出错的可能性。从而最大程度的减小程序的出错。

相关推荐
夜半被帅醒18 分钟前
MySQL 数据库优化详解【Java数据库调优】
java·数据库·mysql
不爱学习的啊Biao31 分钟前
【13】MySQL如何选择合适的索引?
android·数据库·mysql
破 风42 分钟前
SpringBoot 集成 MongoDB
数据库·mongodb
Rverdoser1 小时前
MySQL-MVCC(多版本并发控制)
数据库·mysql
m0_748233641 小时前
SQL数组常用函数记录(Map篇)
java·数据库·sql
dowhileprogramming1 小时前
Python 中的迭代器
linux·数据库·python
0zxm2 小时前
08 Django - Django媒体文件&静态文件&文件上传
数据库·后端·python·django·sqlite
Minxinbb7 小时前
MySQL中Performance Schema库的详解(上)
数据库·mysql·dba
mmsx7 小时前
android sqlite 数据库简单封装示例(java)
android·java·数据库
zpjing~.~9 小时前
Mongo 分页判断是否有下一页
数据库