基于javaweb+mysql的jsp+servlet在线旅游路线商城系统(java+jsp+javascript+servlet+mysql)
私信源码获取及调试交流
运行环境
Java≥8、MySQL≥5.7、Tomcat≥8
开发工具
eclipse/idea/myeclipse/sts等均可配置运行
适用
课程设计,大作业,毕业设计,项目练习,学习演示等
功能说明
基于javaweb的JSP+Servlet在线旅游路线商城系统(java+jsp+javascript+servlet+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.数据库:MySql 5.7版本; 6.是否Maven项目:否;
技术栈
JSP+CSS+JavaScript+java+servlet+mysql
使用说明
- 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件; 2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven; 若为maven项目,导入成功后请执行maven clean;maven install命令,然后运行; 3. 将项目中src/com/hr/dao/Basedao.java配置文件中的数据库配置改为自己的配置; 4. 运行项目,输入http://localhost:8080/ 登录 管理员账号/密码:admin/admin 用户账号/密码:user/123456
String mobile=req.getParameter("mobile");
String address=req.getParameter("address");
String veryCode=req.getParameter("veryCode");
HttpSession session = req.getSession();
//获得系统生成的验证码
String sysCode = (String)session.getAttribute("syscode");
EASYBUY_USER u=new EASYBUY_USER(username, name, rePassWord, sex, year, null, email, mobile, address, 1);
int count=EASYBUY_USERDao.insert(u);
PrintWriter out=resp.getWriter();
if(sysCode.equals(veryCode)){
if(count>0){
resp.sendRedirect("reg-result.jsp");
}else{
out.write("<script>");
out.write("alert('register error');");
out.write("location.href='register.jsp'");
out.write("</script>");
out.close();
}
}
}
}
public class UserDoupdate extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
public class UserDoupdate extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
EncodeUtil.encode(req);
resp.setContentType("text/html;charset=utf-8");
String username=req.getParameter("userName");
String name=req.getParameter("name");
String pwd=req.getParameter("passWord");
String sex=req.getParameter("sex");
String birthday=req.getParameter("birthday");
String email=req.getParameter("email");
String mobile=req.getParameter("mobile");
String address=req.getParameter("address");
String userStatus=req.getParameter("userStatus");
int status = 1;
if(userStatus != null && !"".equals(userStatus)){
status = Integer.parseInt(userStatus);
}
EASYBUY_USER user=new EASYBUY_USER(username, name, pwd, sex, birthday, null, email, mobile, address, status);
int count=EASYBUY_USERDao.update(user);
if(count>0){
resp.sendRedirect("manage-result.jsp");
}else{
PrintWriter out=resp.getWriter();
out.print("<script>");
out.print("alert('修改失败');");
out.print("location.href='user'");
out.print("</script>");
out.close();
}
}
}
for(int i=0;i<EP_ID.length;i++){
int count5=ESDao.updateStock(Integer.parseInt(quantity[i]),Integer.parseInt(EP_ID[i]));
}
//旅游路线单个总价
int [] pprice=new int[EP_ID.length];
for(int i=0;i<EP_ID.length;i++){
pprice[i]=Integer.parseInt(quantity[i])*Integer.parseInt(sPPrice[i]);
}
/得到序列
//往订单表里添加数据
int count=ESDao.insertDD(id, name, address,Integer.parseInt(price));
int getSequenceId=ESDao.getSequenceId();
//循环往订单详情添加
for(int i=0;i<EP_ID.length;i++){
EASYBUY_ORDER_DETAIL eod=new EASYBUY_ORDER_DETAIL(1,getSequenceId,Integer.parseInt(EP_ID[i]),Integer.parseInt(quantity[i]),pprice[i]);
int count2=ESDao.eodInsert(eod);
}
// 开单后,修改购物车
String [] esID=arg0.getParameterValues("esID");
for(int i=0;i<esID.length;i++){
int count3 =ESDao.esdelete(Integer.parseInt(esID[i]));
}
/
if(count>0){
out.print("<script>");
out.print("alert('购物成功');");
out.print("location.href='shopping-result.jsp';");
out.print("</script>");
out.close();
}else{
out.print("<script>");
out.print("alert('购物失败,请重新选择旅游路线');");
out.print("location.href='ShopSelect';");
out.print("</script>");
out.close();
}
}
}
//把总页数传递给guestbook.jsp 使用
req.setAttribute("max_page", max_page);
//把当前页数传递给guestbook.jsp使用
req.setAttribute("page", page);
// 跳
req.getRequestDispatcher("guestbook.jsp").forward(req,resp);
}
}
}
public class SelectDD extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
req.setCharacterEncoding("UTF-8");
//查询分类数据
ArrayList<EASYBUY_PRODUCT_CATEGORY> flist = EASYBUY_PRODUCT_CATEGORYDao.selectFather();
ArrayList<Integer> ids = (ArrayList<Integer>)session.getAttribute("ids");
if(ids!=null){
ArrayList<EASYBUY_PRODUCT> lastlylist = EASYBUY_PRODUCTDao.selectById(ids);
req.setAttribute("lastlylist", lastlylist);
}
req.getRequestDispatcher("index.jsp").forward(req, resp);
}
}
public class UserNumServlet extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
int width=120;
int height=60;
BufferedImage img=new BufferedImage(width, height,BufferedImage.TYPE_INT_RGB);
Graphics2D g=img.createGraphics();
g.setColor(Color.LIGHT_GRAY);
g.fillRect(0, 0, width, height);
g.setColor(Color.YELLOW);
Random rand=new Random();
for (int i = 0; i < 15; i++) {
int x1=rand.nextInt(width);
int y1=rand.nextInt(width);
int x2=rand.nextInt(width);
int y2=rand.nextInt(width);
g.drawLine(x1, y1, x2, y2);
}
Font f=new Font("Times New Roman",Font.BOLD,50);
g.setFont(f);
int red=0,green=0,blue=0;
String code="";
public class UserDoupdate extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
EncodeUtil.encode(req);
resp.setContentType("text/html;charset=utf-8");
String username=req.getParameter("userName");
String name=req.getParameter("name");
String pwd=req.getParameter("passWord");
String sex=req.getParameter("sex");
String birthday=req.getParameter("birthday");
String email=req.getParameter("email");
String mobile=req.getParameter("mobile");
String address=req.getParameter("address");
String userStatus=req.getParameter("userStatus");
int status = 1;
if(userStatus != null && !"".equals(userStatus)){
status = Integer.parseInt(userStatus);
}
EASYBUY_USER user=new EASYBUY_USER(username, name, pwd, sex, birthday, null, email, mobile, address, status);
int count=EASYBUY_USERDao.update(user);
if(count>0){
resp.sendRedirect("manage-result.jsp");
}else{
PrintWriter out=resp.getWriter();
out.print("<script>");
out.print("alert('修改失败');");
out.print("location.href='user'");
out.print("</script>");
out.close();
}
}
}
resp.sendRedirect("indexSelect");
}
}else{
PrintWriter out = resp.getWriter();
out.print("<script>");
out.print("alert('用户名或密码错误');");
out.print("location.href='login.jsp';");
out.print("</script>");
out.close();
}
}else{
PrintWriter out = resp.getWriter();
out.print("<script>");
out.print("alert('验证码错误');");
out.print("location.href='login.jsp';");
out.print("</script>");
out.close();
}
}
}
public class IndexSelectServlet extends HttpServlet {
@SuppressWarnings("unchecked")
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
int width=120;
int height=60;
BufferedImage img=new BufferedImage(width, height,BufferedImage.TYPE_INT_RGB);
Graphics2D g=img.createGraphics();
g.setColor(Color.LIGHT_GRAY);
g.fillRect(0, 0, width, height);
g.setColor(Color.YELLOW);
Random rand=new Random();
for (int i = 0; i < 15; i++) {
int x1=rand.nextInt(width);
int y1=rand.nextInt(width);
int x2=rand.nextInt(width);
int y2=rand.nextInt(width);
g.drawLine(x1, y1, x2, y2);
}
Font f=new Font("Times New Roman",Font.BOLD,50);
g.setFont(f);
int red=0,green=0,blue=0;
String code="";
for (int i = 0; i < 4; i++) {
red=rand.nextInt(255);
green=rand.nextInt(255);
blue=rand.nextInt(255);
Color c=new Color(red,green,blue);
g.setColor(c);
int num=rand.nextInt(10);
code+=num;
g.drawString(num+"", i*20+20, 49);
}
HttpSession session=req.getSession();
session.setAttribute("syscode", code);
ServletOutputStream out=resp.getOutputStream();
ImageIO.write(img, "jpg", out);
}
}
int getSequenceId=ESDao.getSequenceId();
//循环往订单详情添加
for(int i=0;i<EP_ID.length;i++){
EASYBUY_ORDER_DETAIL eod=new EASYBUY_ORDER_DETAIL(1,getSequenceId,Integer.parseInt(EP_ID[i]),Integer.parseInt(quantity[i]),pprice[i]);
int count2=ESDao.eodInsert(eod);
}
// 开单后,修改购物车
String [] esID=arg0.getParameterValues("esID");
for(int i=0;i<esID.length;i++){
int count3 =ESDao.esdelete(Integer.parseInt(esID[i]));
}
/
if(count>0){
out.print("<script>");
out.print("alert('购物成功');");
out.print("location.href='shopping-result.jsp';");
out.print("</script>");
out.close();
}else{
out.print("<script>");
out.print("alert('购物失败,请重新选择旅游路线');");
out.print("location.href='ShopSelect';");
out.print("</script>");
out.close();
}
}
}
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
req.setCharacterEncoding("UTF-8");
String username=req.getParameter("userName");
String passWord=req.getParameter("passWord");
String veryCode=req.getParameter("veryCode");
resp.setContentType("text/html;charset=utf-8");
HttpSession session = req.getSession();
//获得系统生成的验证码
String sysCode = (String)session.getAttribute("syscode");
int count=EASYBUY_USERDao.selectByNM(username, passWord);
EASYBUY_USER user=EASYBUY_USERDao.selectAdmin(username, passWord);
if(sysCode.equals(veryCode)){
if(count>0){
session.setAttribute("name", user);
if(user.getEU_STATUS()==2){
//System.out.println(user.getEU_STATUS());
//resp.sendRedirect("manage/index.jsp");
resp.sendRedirect("manage/index.jsp");
}else{
resp.sendRedirect("indexSelect");
}
}else{
PrintWriter out = resp.getWriter();
out.print("<script>");
out.print("alert('用户名或密码错误');");
out.print("location.href='login.jsp';");
out.print("</script>");
out.close();
}
}else{
PrintWriter out = resp.getWriter();
out.print("<script>");
out.print("alert('验证码错误');");
out.print("location.href='login.jsp';");
out.print("</script>");
out.close();
}
}
}
public class LoginServlet extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
req.setCharacterEncoding("UTF-8");
String username=req.getParameter("userName");
String passWord=req.getParameter("passWord");
String veryCode=req.getParameter("veryCode");
resp.setContentType("text/html;charset=utf-8");
HttpSession session = req.getSession();
//获得系统生成的验证码
String sysCode = (String)session.getAttribute("syscode");
int count=EASYBUY_USERDao.selectByNM(username, passWord);
EASYBUY_USER user=EASYBUY_USERDao.selectAdmin(username, passWord);
if(sysCode.equals(veryCode)){
if(count>0){
session.setAttribute("name", user);
if(user.getEU_STATUS()==2){
//System.out.println(user.getEU_STATUS());
//resp.sendRedirect("manage/index.jsp");
resp.sendRedirect("manage/index.jsp");
}else{
resp.sendRedirect("indexSelect");
}
}else{
PrintWriter out = resp.getWriter();
out.print("<script>");
out.print("alert('用户名或密码错误');");
out.print("location.href='login.jsp';");
out.print("</script>");
out.close();
}
public class SelectDD extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
req.setCharacterEncoding("UTF-8");
//查询分类数据
ArrayList<EASYBUY_PRODUCT_CATEGORY> flist = EASYBUY_PRODUCT_CATEGORYDao.selectFather();
req.setAttribute("flist", flist);
ArrayList<EASYBUY_PRODUCT_CATEGORY> clist = EASYBUY_PRODUCT_CATEGORYDao.selectChild();
req.setAttribute("clist", clist);
ArrayList<EASYBUY_PRODUCT> tlist = EASYBUY_PRODUCTDao.selectAllByT();
req.setAttribute("tlist", tlist);
ArrayList<EASYBUY_PRODUCT> hlist = EASYBUY_PRODUCTDao.selectAllByHot();
req.setAttribute("hlist", hlist);
ArrayList<EASYBUY_NEWS> nlist = EASYBUY_NEWSDao.selectAll();
req.setAttribute("nlist", nlist);
HttpSession session = req.getSession();
//查询最近浏览的旅游路线
ArrayList<Integer> ids = (ArrayList<Integer>)session.getAttribute("ids");
if(ids!=null){
ArrayList<EASYBUY_PRODUCT> lastlylist = EASYBUY_PRODUCTDao.selectById(ids);
req.setAttribute("lastlylist", lastlylist);
}
EncodeUtil.encode(req);
EncodeUtil.encode(arg0);
HttpSession session=arg0.getSession();
EASYBUY_USER list=(EASYBUY_USER)session.getAttribute("name");
//用户id
String id=list.getEU_USER_ID();
//用户姓名
String name=list.getEU_USER_NAME();
//用户地址
String address=list.getEU_ADDRESS();
//总价钱
String price=arg0.getParameter("jstext");
//旅游路线id
String [] EP_ID=arg0.getParameterValues("spID");
//购买数量
String [] quantity=arg0.getParameterValues("number");
//旅游路线单价
String [] sPPrice=arg0.getParameterValues("sPPrice");
//购买后对旅游路线表的库存进行修改
for(int i=0;i<EP_ID.length;i++){
int count5=ESDao.updateStock(Integer.parseInt(quantity[i]),Integer.parseInt(EP_ID[i]));
}
//旅游路线单个总价
int [] pprice=new int[EP_ID.length];
for(int i=0;i<EP_ID.length;i++){
pprice[i]=Integer.parseInt(quantity[i])*Integer.parseInt(sPPrice[i]);
}
/得到序列
//往订单表里添加数据
int count=ESDao.insertDD(id, name, address,Integer.parseInt(price));
int getSequenceId=ESDao.getSequenceId();
//循环往订单详情添加
for(int i=0;i<EP_ID.length;i++){
EASYBUY_ORDER_DETAIL eod=new EASYBUY_ORDER_DETAIL(1,getSequenceId,Integer.parseInt(EP_ID[i]),Integer.parseInt(quantity[i]),pprice[i]);
int count2=ESDao.eodInsert(eod);
}
// 开单后,修改购物车
String [] esID=arg0.getParameterValues("esID");
for(int i=0;i<esID.length;i++){
int count3 =ESDao.esdelete(Integer.parseInt(esID[i]));
public class gmServlet extends HttpServlet {
@Override
protected void service(HttpServletRequest arg0, HttpServletResponse arg1)
throws ServletException, IOException {
arg1.setContentType("text/html;charset=utf-8");
PrintWriter out=arg1.getWriter();
EncodeUtil.encode(arg0);
HttpSession session=arg0.getSession();
EASYBUY_USER list=(EASYBUY_USER)session.getAttribute("name");
//用户id
String id=list.getEU_USER_ID();
//用户姓名
String name=list.getEU_USER_NAME();
//用户地址
String address=list.getEU_ADDRESS();
//总价钱
String price=arg0.getParameter("jstext");
//旅游路线id
String [] EP_ID=arg0.getParameterValues("spID");
//购买数量
String [] quantity=arg0.getParameterValues("number");
//旅游路线单价
String [] sPPrice=arg0.getParameterValues("sPPrice");
//购买后对旅游路线表的库存进行修改
for(int i=0;i<EP_ID.length;i++){
int count5=ESDao.updateStock(Integer.parseInt(quantity[i]),Integer.parseInt(EP_ID[i]));
}
//旅游路线单个总价
int [] pprice=new int[EP_ID.length];
for(int i=0;i<EP_ID.length;i++){
pprice[i]=Integer.parseInt(quantity[i])*Integer.parseInt(sPPrice[i]);
}
/得到序列
//往订单表里添加数据
int count=ESDao.insertDD(id, name, address,Integer.parseInt(price));
int getSequenceId=ESDao.getSequenceId();
//循环往订单详情添加
for(int i=0;i<EP_ID.length;i++){
EASYBUY_ORDER_DETAIL eod=new EASYBUY_ORDER_DETAIL(1,getSequenceId,Integer.parseInt(EP_ID[i]),Integer.parseInt(quantity[i]),pprice[i]);
try {
su.upload();
} catch (SmartUploadException e) {
e.printStackTrace();
}
Files fs = su.getFiles();//获得所有文件
File f = fs.getFile(0);//获得上传的文件
String fname = f.getFileName();//获得文件名
try {
su.save("images/product");//保存图片到指定位置
} catch (SmartUploadException e) {
e.printStackTrace();
}
Request req1 = su.getRequest();
String pname = req1.getParameter("productName");
String id = req1.getParameter("parentId");
String price = req1.getParameter("productPrice");
String desc = req1.getParameter("productDesc");
String stock = req1.getParameter("productStock");
EASYBUY_PRODUCT p = null;
if(price!=null && stock!=null && id!=null){
p = new EASYBUY_PRODUCT(0, pname, desc,
Integer.parseInt(price),
Integer.parseInt(stock),
Integer.parseInt(id.split("-")[0]),
Integer.parseInt(id.split("-")[1]),
fname);
}
int count = 0;
if(p!=null){
count = EASYBUY_PRODUCTDao.insert(p);
}
req.getRequestDispatcher("productSelect").forward(req, resp);
}
}
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
int width=120;
int height=60;
BufferedImage img=new BufferedImage(width, height,BufferedImage.TYPE_INT_RGB);
Graphics2D g=img.createGraphics();
g.setColor(Color.LIGHT_GRAY);
g.fillRect(0, 0, width, height);
g.setColor(Color.YELLOW);
Random rand=new Random();
for (int i = 0; i < 15; i++) {
int x1=rand.nextInt(width);
int y1=rand.nextInt(width);
int x2=rand.nextInt(width);
int y2=rand.nextInt(width);
g.drawLine(x1, y1, x2, y2);
}
Font f=new Font("Times New Roman",Font.BOLD,50);
g.setFont(f);
int red=0,green=0,blue=0;
String code="";
for (int i = 0; i < 4; i++) {
red=rand.nextInt(255);
green=rand.nextInt(255);
blue=rand.nextInt(255);
Color c=new Color(red,green,blue);
g.setColor(c);
int num=rand.nextInt(10);
code+=num;
g.drawString(num+"", i*20+20, 49);
}
HttpSession session=req.getSession();
session.setAttribute("syscode", code);
ServletOutputStream out=resp.getOutputStream();
ImageIO.write(img, "jpg", out);
}
}
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
//查询分类数据
ArrayList<EASYBUY_PRODUCT_CATEGORY> flist = EASYBUY_PRODUCT_CATEGORYDao.selectFather();
req.setAttribute("flist", flist);
ArrayList<EASYBUY_PRODUCT_CATEGORY> clist = EASYBUY_PRODUCT_CATEGORYDao.selectChild();
req.setAttribute("clist", clist);
ArrayList<EASYBUY_PRODUCT> tlist = EASYBUY_PRODUCTDao.selectAllByT();
req.setAttribute("tlist", tlist);
ArrayList<EASYBUY_PRODUCT> hlist = EASYBUY_PRODUCTDao.selectAllByHot();
req.setAttribute("hlist", hlist);
ArrayList<EASYBUY_NEWS> nlist = EASYBUY_NEWSDao.selectAll();
req.setAttribute("nlist", nlist);
HttpSession session = req.getSession();
//查询最近浏览的旅游路线
ArrayList<Integer> ids = (ArrayList<Integer>)session.getAttribute("ids");
if(ids!=null){
ArrayList<EASYBUY_PRODUCT> lastlylist = EASYBUY_PRODUCTDao.selectById(ids);
req.setAttribute("lastlylist", lastlylist);
}
req.getRequestDispatcher("index.jsp").forward(req, resp);
}
}
public class UserNumServlet extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
int width=120;
int height=60;
BufferedImage img=new BufferedImage(width, height,BufferedImage.TYPE_INT_RGB);
Graphics2D g=img.createGraphics();
if(cid!=null){
int id = Integer.parseInt(cid);
list = EASYBUY_PRODUCTDao.selectAllByCid(cpage, count, id);
tpage = EASYBUY_PRODUCTDao.totalPageByCid(count, id);
req.setAttribute("title", EASYBUY_PRODUCT_CATEGORYDao.selectById(id).getEPC_NAME());
}
if(name!=null){
list = EASYBUY_PRODUCTDao.selectAllByName(name);
tpage = EASYBUY_PRODUCTDao.totalPageByName(count, name);
req.setAttribute("title", "搜索旅游路线:"+name);
}
req.setAttribute("list", list);
//当前页数
req.setAttribute("cpage", cpage);
//总页数
req.setAttribute("tpage", tpage);
//搜索关键字
req.setAttribute("search_words", name);
//父分类
req.setAttribute("selected_fid", fid);
req.getRequestDispatcher("product-list.jsp").forward(req, resp);
}
}