javaWeb完整项目

这篇具有很好参考价值的文章主要介绍了javaWeb完整项目。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Java Web,是用Java技术来解决相关web互联网领域的技术总和。web包括:web服务器和web客户端两部分。Java在客户端的应用有java applet不过现在使用的很少,Java在服务器端的应用非常的丰富,比如Servlet,JSP和第三方框架等等。Java技术对Web领域的发展注入了强大的动力。

基本信息

  • 外文名:java web

  • 归属于:互联网

  • 类型:技术

  • 分类:服务器

目录

1主要框架

2关于Java

折叠编辑本段主要框架

Java的Web框架虽然各不相同,但基本也都是遵循特定的路数的:使用Servlet或者Filter拦截请求,使用MVC的思想设计架构,使用约定,XML或 Annotation实现配置,运用Java面向对象的特点,面向抽象实现请求和响应的流程,支持Jsp,Freemarker,Velocity等视图。

折叠JSP优点:


Java EE标准,这意味着有很大的市场需求和更多的工作机会

上手快速并且相对容易

有大量可用的组件库

折叠JSP缺点:


大量的JSP标签

对REST和安全支持不好

没有一个统一的实现。既有SUN的实现,又有Apache的实现--MyFaces。

折叠SpringMVC优点:


对Spring MVC覆盖绑定(overriding binding)、验证(validation)等提供生命周期管理

与许多表示层技术/框架无缝集成:JSP/JSTL、Tiles、Velocity、FreeMarker、Excel、XSL、PDF 等

便于测试--归功于IoC

折叠SpringMVC缺点:


大量的XML配置文件

太过灵活--没有公共的父控制器

没有内置的Ajax支持

折叠Stripes优点:


不需要书写XML配置文件

良好的学习文档

社区成员很热心

折叠Stripes缺点:


社区比较小

不如其他的项目活跃

ActionBean里面的URL是硬编码的

折叠Struts2优点:


架构简单--易于扩展

标记库很容易利用FreeMarker或者Velocity来定制

基于控制器或

者基于页面的导航

折叠Struts2缺点:


文档组织得很差

对新特征过分关注

折叠Tapestry优点:


一旦学会它,将极大地提高生产率

HTML模板--对页面设计师非常有利

每出一个新版本,都会有大量的创新

折叠Tapestry缺点:


文档过于概念性,不够实用

学习曲线陡峭

发行周期长--每年都有较大的升级

折叠Wicket优点:


对Java开发者有利(不是Web开发者)

页面和显示绑定紧密

社区活跃--有来自创建者的支持

折叠Wicket缺点:


HTML模板和Java代码紧挨着

需要对OO有较好的理解

Wicket逻辑--什么都用Java搞定

1创建项目

File+New+Project创建新的项目

javaweb项目,servlet,java,struts,Powered by 金山文档

然后

javaweb项目,servlet,java,struts,Powered by 金山文档

下一步:右键New选择Module项目

javaweb项目,servlet,java,struts,Powered by 金山文档

下一步和之前一样改名字看看JDK版本

javaweb项目,servlet,java,struts,Powered by 金山文档

下一步选择刚创建的项目右键

javaweb项目,servlet,java,struts,Powered by 金山文档

选择Web版本点击OK

javaweb项目,servlet,java,struts,Powered by 金山文档

创建一个新包lib加入jar包

javaweb项目,servlet,java,struts,Powered by 金山文档
javaweb项目,servlet,java,struts,Powered by 金山文档

右键全部打开

javaweb项目,servlet,java,struts,Powered by 金山文档
javaweb项目,servlet,java,struts,Powered by 金山文档

然后配置服务器 选择第一个

javaweb项目,servlet,java,struts,Powered by 金山文档

点击加号

javaweb项目,servlet,java,struts,Powered by 金山文档

找到Tomcat Local选择

javaweb项目,servlet,java,struts,Powered by 金山文档

然后谷歌浏览器标识的的地方可以修改浏览器下面是储存位置还有配置

javaweb项目,servlet,java,struts,Powered by 金山文档

后面选择旁边的位置

javaweb项目,servlet,java,struts,Powered by 金山文档

点击加号点击下面第一个

javaweb项目,servlet,java,struts,Powered by 金山文档

然后点击Apply最后OK

javaweb项目,servlet,java,struts,Powered by 金山文档

接下来实现增删改查

数据库

#判断存在即删除数据库
drop database if exists mydb;
#创建数据库
create database mydb;
#使用数据库
use mydb;


#创建表
create table t_user
(
    uid int primary key auto_increment,
    username varchar(20),
    password varchar(20),
    phone varchar(11),
    address varchar(50)
);


insert into t_user(username,password,phone,address) values('张三','666','18965423548','南阳');
insert into t_user(username,password,phone,address) values('李四','333','18754263548','许昌');
insert into t_user(username,password,phone,address) values('小美','123','18565234759','信阳');

select * from t_user where username=? and password=?
select * from t_user;


create table t_goods
(
    gid int primary key auto_increment,
    gname varchar(20),
    price double,
    mark varchar(100)
);

insert into t_goods(gname,price,mark) values('泡面',4.5,'够香够辣就是这个味!');
insert into t_goods(gname,price,mark) values('火腿',8.5,'肉质细腻Q弹!');
insert into t_goods(gname,price,mark) values('雪碧',3.5,'清爽冰凉随心爽!');

select * from t_goods;

数据库连接代码

 */
public class UserDao {
    //连接数据库的四大参数
    private String jdbcDriver="com.mysql.cj.jdbc.Driver";
    private String jdbcUrl="jdbc:mysql://127.0.0.1:3306/mydb?useSSL=false&serverTimezone=UTC";
    private String jdbcUser="root";
    private String jdbcPwd="root";

    private Connection con=null;//数据库连接对象
    private PreparedStatement pstm=null;//预处理对象
    private ResultSet rs=null;//结果集对象
    private int row=0;//增删改受影响的行数

增删改查



    /**
     * 根据用户名和密码完成数据库的登录查询
     * @param username
     * @param password
     * @return 数据库中查询到的用户信息对象
     */
    public User login(String username, String password){
        User login=null;

        try{
            Class.forName(jdbcDriver);
            con= DriverManager.getConnection(jdbcUrl,jdbcUser,jdbcPwd);
            String sql="select * from t_user where username=? and password=?";
            pstm=con.prepareStatement(sql);
            pstm.setObject(1,username);
            pstm.setObject(2,password);
            rs=pstm.executeQuery();

            if(rs.next()){
                //从结果集中取出数据,封装到User对象中
                login=new User();
                login.setUid(rs.getInt("uid"));
                login.setUsername(rs.getString("username"));
                login.setPassword(rs.getString("password"));
                login.setPhone(rs.getString("phone"));
                login.setAddress(rs.getString("address"));
            }
        } catch (Exception e){
            e.printStackTrace();
        } finally {
            try{
                if(rs!=null){
                    rs.close();
                }
                if(pstm!=null){
                    pstm.close();
                }
                if(con!=null){
                    con.close();
                }
            } catch (Exception e){
                e.printStackTrace();
            }
        }

        return login;
    }


    /**
     * 用户信息的注册,即数据库的添加操作
     * @param user
     * @return
     */
    public int add(User user){
        try{
            Class.forName(jdbcDriver);
            con= DriverManager.getConnection(jdbcUrl,jdbcUser,jdbcPwd);
            String sql="insert into t_user(username,password,phone,address) values(?,?,?,?)";
            pstm=con.prepareStatement(sql);
            pstm.setObject(1,user.getUsername());
            pstm.setObject(2,user.getPassword());
            pstm.setObject(3,user.getPhone());
            pstm.setObject(4,user.getAddress());

            row=pstm.executeUpdate();
        } catch (Exception e){
            e.printStackTrace();
        } finally {
            try{
                if(pstm!=null){
                    pstm.close();
                }
                if(con!=null){
                    con.close();
                }
            } catch (Exception e){
                e.printStackTrace();
            }
        }

        return row;
    }
}

/**
 * 对应商品表的实体类
 */
public class Goods {
    private Integer gid;
    private String gname;
    private Double price;
    private String mark;

    public Integer getGid() {
        return gid;
    }

    public void setGid(Integer gid) {
        this.gid = gid;
    }

    public String getGname() {
        return gname;
    }

    public void setGname(String gname) {
        this.gname = gname;
    }

    public Double getPrice() {
        return price;
    }

    public void setPrice(Double price) {
        this.price = price;
    }

    public String getMark() {
        return mark;
    }

    public void setMark(String mark) {
        this.mark = mark;
    }

    @Override
    public String toString() {
        return "Goods{" +
                "gid=" + gid +
                ", gname='" + gname + '\'' +
                ", price=" + price +
                ", mark='" + mark + '\'' +
                '}';
    }
}

/**
 * 对应用户信息表的实体类
 */
public class User {
    private Integer uid;
    private String username;
    private String password;
    private String phone;
    private String address;

    public Integer getUid() {
        return uid;
    }

    public void setUid(Integer uid) {
        this.uid = uid;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public String getPhone() {
        return phone;
    }

    public void setPhone(String phone) {
        this.phone = phone;
    }

    public String getAddress() {
        return address;
    }

    public void setAddress(String address) {
        this.address = address;
    }

    @Override
    public String toString() {
        return "User{" +
                "uid=" + uid +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                ", phone='" + phone + '\'' +
                ", address='" + address + '\'' +
                '}';
    }
}

import com.chen.bean.Goods;

import java.sql.*;
import java.util.ArrayList;
import java.util.List;

/**
 * 用来完成t_goods表的JDBC操作
 */
public class GoodsDao {
    //连接数据库的四大参数
    private String jdbcDriver="com.mysql.cj.jdbc.Driver";
    private String jdbcUrl="jdbc:mysql://127.0.0.1:3306/mydb?useSSL=false&serverTimezone=UTC";
    private String jdbcUser="root";
    private String jdbcPwd="root";

    private Connection con=null;//数据库连接对象
    private PreparedStatement pstm=null;//预处理对象
    private ResultSet rs=null;//结果集对象
    private int row=0;//增删改受影响的行数

    public List<Goods> selectAll(){
        List<Goods> goodsList=new ArrayList<>();
        try{
            Class.forName(jdbcDriver);
            con= DriverManager.getConnection(jdbcUrl,jdbcUser,jdbcPwd);
            String sql="select * from t_goods";
            pstm=con.prepareStatement(sql);
            rs=pstm.executeQuery();
            while (rs.next()){
                //从结果集中获取数据,封装到Goods对象中
                Goods goods=new Goods();
                goods.setGid(rs.getInt("gid"));
                goods.setGname(rs.getString("gname"));
                goods.setPrice(rs.getDouble("price"));
                goods.setMark(rs.getString("mark"));

                //把当前行对应的对象存储到集合中
                goodsList.add(goods);
            }
        } catch (Exception e){
            e.printStackTrace();
        } finally {
            try{
                if(rs!=null){
                    rs.close();
                }
                if(pstm!=null){
                    pstm.close();
                }
                if(con!=null){
                    con.close();
                }
            } catch (Exception e){
                e.printStackTrace();
            }
        }

        return goodsList;
    }

    public List<Goods> seach(String keyword){

            List<Goods> goodsList=new ArrayList<>();
            try{
                Class.forName(jdbcDriver);
                con= DriverManager.getConnection(jdbcUrl,jdbcUser,jdbcPwd);
                String sql="select * from t_goods where gname like concat('%',?'%')";
                pstm=con.prepareStatement(sql);
                pstm.setObject(1,keyword);
                rs=pstm.executeQuery();
                while (rs.next()){
                    //从结果集中获取数据,封装到Goods对象中
                    Goods goods=new Goods();
                    goods.setGid(rs.getInt("gid"));
                    goods.setGname(rs.getString("gname"));
                    goods.setPrice(rs.getDouble("price"));
                    goods.setMark(rs.getString("mark"));

                    //把当前行对应的对象存储到集合中
                    goodsList.add(goods);
                }
            } catch (Exception e){
                e.printStackTrace();
            } finally {
                try{
                    if(rs!=null){
                        rs.close();
                    }
                    if(pstm!=null){
                        pstm.close();
                    }
                    if(con!=null){
                        con.close();
                    }
                } catch (Exception e){
                    e.printStackTrace();
                }
            }

            return goodsList;
        }



    public Goods selectById(int gid){
        Goods goods=null;
        try{
            Class.forName(jdbcDriver);
            con= DriverManager.getConnection(jdbcUrl,jdbcUser,jdbcPwd);
            String sql="select * from t_goods where gid=?";
            pstm=con.prepareStatement(sql);
            pstm.setObject(1,gid);
            rs=pstm.executeQuery();
            if (rs.next()){
                //从结果集中获取数据,封装到Goods对象中
                goods=new Goods();
                goods.setGid(rs.getInt("gid"));
                goods.setGname(rs.getString("gname"));
                goods.setPrice(rs.getDouble("price"));
                goods.setMark(rs.getString("mark"));
            }
        } catch (Exception e){
            e.printStackTrace();
        } finally {
            try{
                if(rs!=null){
                    rs.close();
                }
                if(pstm!=null){
                    pstm.close();
                }
                if(con!=null){
                    con.close();
                }
            } catch (Exception e){
                e.printStackTrace();
            }
        }

        return goods;
    }

    public int add(Goods goods){
        try{
            Class.forName(jdbcDriver);
            con=DriverManager.getConnection(jdbcUrl,jdbcUser,jdbcPwd);
            String sql="insert into t_goods(gname,price,mark) values(?,?,?)";
            pstm=con.prepareStatement(sql);
            pstm.setObject(1,goods.getGname());
            pstm.setObject(2,goods.getPrice());
            pstm.setObject(3,goods.getMark());
            row=pstm.executeUpdate();
        } catch (Exception e){
            e.printStackTrace();
        } finally {
            try{
                if(pstm!=null){
                    pstm.close();
                }
                if(con!=null){
                    con.close();
                }
            } catch (Exception e){
                e.printStackTrace();
            }
        }

        return row;
    }
    public int deleteById(int gid){
        try{
            Class.forName(jdbcDriver);
            con=DriverManager.getConnection(jdbcUrl,jdbcUser,jdbcPwd);
            String sql="delete from t_goods where gid=?";
            pstm=con.prepareStatement(sql);
            pstm.setObject(1,gid);
            row=pstm.executeUpdate();
        } catch (Exception e){
            e.printStackTrace();
        } finally {
            try{
                if(pstm!=null){
                    pstm.close();
                }
                if(con!=null){
                    con.close();
                }
            } catch (Exception e){
                e.printStackTrace();
            }
        }

        return row;
    }

    public int update(Goods goods){
        Goods tow=null;
        try{
            Class.forName(jdbcDriver);
            con= DriverManager.getConnection(jdbcUrl,jdbcUser,jdbcPwd);
            String sql = "update t_goods set gname=?,price=?,mark=? where gid = ?";
            pstm=con.prepareStatement(sql);

            rs=pstm.executeQuery();
            if (rs.next()){
                //从结果集中获取数据,封装到Goods对象中
                goods=new Goods();
                goods.setGid(rs.getInt("gid"));
                goods.setGname(rs.getString("gname"));
                goods.setPrice(rs.getDouble("price"));
                goods.setMark(rs.getString("mark"));
            }
        } catch (Exception e){
            e.printStackTrace();
        } finally {
            try{
                if(rs!=null){
                    rs.close();
                }
                if(pstm!=null){
                    pstm.close();
                }
                if(con!=null){
                    con.close();
                }
            } catch (Exception e){
                e.printStackTrace();
            }
        }

        return tow.getGid();
    }
}

import com.chen.bean.User;
import com.chen.dao.UserDao;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
import java.util.List;


@WebServlet("/login")
public class Login extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doPost(request, response);
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //1.设置请求和响应的编码格式,以及响应的格式
        request.setCharacterEncoding("utf-8");  //设置请求的编码格式为中文
        response.setCharacterEncoding("utf-8"); //设置响应的编码格式

        //2.获取请求的参数
        String username = request.getParameter("username");  //根据表单的name属性获取用户输入的值
        String password = request.getParameter("password");
        System.out.println(username);
        System.out.println(password);
        //3.执行业务处理---jdbc操作
        UserDao userDao=new UserDao();
        User login = userDao.login(username, password);
        System.out.println(login);
        //4.判断登录的用户信息是否为空
        if(login!=null){
            //把用户信息存储到session中
            HttpSession session = request.getSession();
            session.setAttribute("user",login);

            //登录成功,当前servlet的业务处理完毕----后续执行查询商品的操作应该由别人来完成---请求转发给别的servlet处理
            request.getRequestDispatcher("selectAllGoods").forward(request,response);//请求别的地址
        } else{
            //登录失败,跳转到错误页
            request.setAttribute("error_msg","用户名或密码错误!");
            request.getRequestDispatcher("error.jsp").forward(request,response);
        }
    }
}

import com.chen.bean.User;
import com.chen.dao.UserDao;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;


//设置当前类用来处理 /register 的请求
@WebServlet("/register")
public class Register extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doPost(request, response);
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //1.设置编码
        request.setCharacterEncoding("utf-8");
        response.setCharacterEncoding("utf-8");

        //2.获取请求参数
        String username=request.getParameter("username");
        String password=request.getParameter("password");
        String phone=request.getParameter("phone");
        String address=request.getParameter("address");
        //封装:把上面所有的变量装载到User对象中
        User user=new User();
        user.setUsername(username);
        user.setPassword(password);
        user.setPhone(phone);
        user.setAddress(address);

        System.out.println(user);
        //3.执行业务处理---jdbc的操作
        UserDao userDao=new UserDao();
        int row=userDao.add(user);

        //4.做出响应
        if(row>0){
            //注册成功跳转到登录页
            response.sendRedirect("login.jsp");
        } else{
            //注册失败继续跳转回注册页
            request.setAttribute("error_msg","注册出现了一些问题,稍后再试!");
            request.getRequestDispatcher("error.jsp").forward(request,response);
        }
    }
}

import com.chen.bean.Goods;
import com.chen.dao.GoodsDao;

import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.io.IOException;
import java.util.List;

@WebServlet("/selectAllGoods")
public class SelectAllGoods extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doPost(request, response);
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //查询所有商品信息
        GoodsDao goodsDao=new GoodsDao();
        List<Goods> goodsList = goodsDao.selectAll();

        //把数据传递到前端页面
        //通过request获取session对象,该对象可以向前端传输数据的容器
        HttpSession session = request.getSession();
        //向session中存入商品信息集合
        session.setAttribute("goodsList",goodsList);

        //登录成功,跳转到主页
        response.sendRedirect("zhuye.jsp");  //指定跳转的页面
    }
}

import com.chen.bean.Goods;
import com.chen.dao.GoodsDao;

import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.io.IOException;

@WebServlet("/addGoods")
public class AddGoods extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doPost(request, response);
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        request.setCharacterEncoding("utf-8");
        response.setCharacterEncoding("utf-8");

        //获取请求参数并封装到Goods对象中
        Goods goods=new Goods();
        goods.setGname(request.getParameter("gname"));
        //使用Double包装类把request.getParameter获取到字符串数字 转换为 double类型的数据
        goods.setPrice(Double.parseDouble(request.getParameter("price")));
        goods.setMark(request.getParameter("mark"));

        //执行JDBC的添加操作
        GoodsDao goodsDao=new GoodsDao();
        int row = goodsDao.add(goods);

        if(row>0){
            //添加成功,请求selectAllGoods地址,执行对应的Servlet(查询商品信息、存入session中、跳转到主页)
            request.getRequestDispatcher("selectAllGoods").forward(request,response);
        } else{
            request.setAttribute("error_msg","添加商品出错啦!");
            request.getRequestDispatcher("error.jsp").forward(request,response);
        }

    }
}

import com.chen.dao.GoodsDao;

import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.io.IOException;

@WebServlet("/dell")
public class DellGoods extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doPost(request, response);
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //获取要删除的商品id
        int gid=Integer.parseInt(request.getParameter("gid"));

        //执行JDBC根据gid删除操作
        GoodsDao goodsDao=new GoodsDao();
        int row = goodsDao.deleteById(gid);

        if(row>0){
            request.getRequestDispatcher("selectAllGoods").forward(request,response);
        } else{
            request.setAttribute("error_msg","删除出现了异常!");
            request.getRequestDispatcher("error.jsp").forward(request,response);
        }
    }
}

import com.chen.bean.Goods;
import com.chen.dao.GoodsDao;

import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.io.IOException;

@WebServlet("/findById")
public class FindGoodsById extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doPost(request, response);
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        int gid=Integer.parseInt(request.getParameter("gid"));
        //根据gid查询该商品信息
        GoodsDao goodsDao=new GoodsDao();
        Goods goods = goodsDao.selectById(gid);

        if(goods!=null){
            //把数据存储到request域对象中,然后请求转发到页面
            request.setAttribute("goods",goods);
            request.getRequestDispatcher("showGoods.jsp").forward(request,response);
        } else{
            //登录失败,跳转到错误页
            request.setAttribute("error_msg","修改出现异常");
            request.getRequestDispatcher("error.jsp").forward(request,response);
        }


    }
}

import com.chen.bean.Goods;
import com.chen.dao.GoodsDao;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.awt.*;
import java.io.IOException;
import java.util.List;

public class seach extends HttpServlet {
    @Override
    protected void doPost(HttpServletRequest request , HttpServletResponse response) throws ServletException, IOException {
        doPost(request, response);
    }

    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        request.setCharacterEncoding("utf-8");  //设置请求的编码格式为中文
        response.setCharacterEncoding("utf-8"); //设置响应的编码格式
        //根据用户输入的搜索关键词
        String keyword=request.getParameter("keyword");
        System.out.println(keyword);
        //根据关键词执行jdbc的模糊查询
        GoodsDao goodsDao=new GoodsDao();
        List<Goods> goodsList = goodsDao.seach(keyword);
        //向session中存入模糊查询到的商品信息集合
        HttpSession session=request.getSession();
        session.setAttribute("goodsList",goodsList);
        //登录成功,跳转到主页
        response.sendRedirect("zhuye.jsp");//指定跳转页面
    }
}

import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.io.IOException;

@WebServlet("/test01")
public class Test01 extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doPost(request, response);
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //作用域对象
        //1.pageContext--(页面级作用域)

        //2.request--(请求间作用域)
        request.setAttribute("name","request");
        //3.session--(会话间作用域)用户使用同一个浏览器在任何页面都可以共享session
        HttpSession session = request.getSession();
        session.setAttribute("name","session");
        //4.application--(服务器级作用域)
        ServletContext application = request.getServletContext();
        application.setAttribute("name","application");

        //重定向---让浏览器重新请求test01.jsp
        response.sendRedirect("test01.jsp");   //session

        //请求转发---浏览器当前的请求还没断开,还是同一次请求
        //request.getRequestDispatcher("test01.jsp").forward(request,response);  //request
    }
}

import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.io.IOException;

@WebServlet("/test01")
public class Test01 extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doPost(request, response);
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //作用域对象
        //1.pageContext--(页面级作用域)

        //2.request--(请求间作用域)
        request.setAttribute("name","request");
        //3.session--(会话间作用域)用户使用同一个浏览器在任何页面都可以共享session
        HttpSession session = request.getSession();
        session.setAttribute("name","session");
        //4.application--(服务器级作用域)
        ServletContext application = request.getServletContext();
        application.setAttribute("name","application");

        //重定向---让浏览器重新请求test01.jsp
        response.sendRedirect("test01.jsp");   //session

        //请求转发---浏览器当前的请求还没断开,还是同一次请求
        //request.getRequestDispatcher("test01.jsp").forward(request,response);  //request
    }
}

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>登录</title>
</head>
<body>
    <h2>登录</h2>
    <form action="login" method="post">
        账号:<input type="text" name="username" value="" /> <br/>
        密码:<input type="password" name="password" value="" /> <br/>
        <input type="submit" value="登录">&nbsp;&nbsp;&nbsp;
        <a href="register.jsp">没有账号?请注册</a>
    </form>
</body>
</html>

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
  <head>
    <title>第一个Web项目</title>
  </head>
  <body>
  <h2>欢迎学习Java Web!</h2>
  <a href="login.jsp">去登录</a> <br/>
  </body>
</html>

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>注册页</title>
</head>
<body>
  <h2>进行注册</h2>
  <form action="register" method="post">
    账号:<input type="text" name="username" value="" /> <br/>
    密码:<input type="password" name="password" value="" /> <br/>
    电话:<input type="text" name="phone" value="" /> <br/>
    地址:<input type="text" name="address" value="" /> <br/>
    <input type="submit" value="注册">&nbsp;&nbsp;&nbsp;
    <a href="login.jsp">已有账号?请登录</a>
  </form>
</body>
</html>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<!--导入JSTL的核心类库-->
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>

<html>
<head>
    <title>主页</title>
</head>
<body>
    <!--EL表达式:通过 $ { } 从作用域对象中获取数据,如果该数据是对象,则可以通过对象名.属性名获取其数值-->
    <h2>欢迎来自${user.address}的${user.username}访问项目主页</h2>
    <form action="seach" method="post">
        <input type="text" name="keyword" value="">
        <input type="submit" value="搜索">

    </form>
    <a href="addGoods.jsp">添加商品</a>
    <table>
        <thead>
            <tr>
                <th>商品编号</th>
                <th>商品名称</th>
                <th>商品价格</th>
                <th>商品说明</th>
                <th>操作</th>
            </tr>
        </thead>

        <tbody id="list">
            <!--items:要遍历的集合对象(写EL表达式)   var:集合中对应临时对象-->
            <c:forEach items="${goodsList}" var="goods">
                <tr>
                    <td>${goods.gid}</td>
                    <td>${goods.gname}</td>
                    <td>${goods.price}</td>
                    <td>${goods.mark}</td>
                    <td>
                        <a href="findById?gid=${goods.gid}">修改</a>
                        <a href="dell?gid=${goods.gid}">删除</a>
                    </td>
                </tr>
            </c:forEach>
        </tbody>
    </table>
</body>
</html>

一、Filter过滤器简介

Filter也称之为过滤器,WEB开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, 静态图片文件或静态 html 文件等进行拦截,从而实现一些特殊的功能。例如实现URL级别的权限访问控制、过滤敏感词汇、压缩响应信息等一些高级功能。

Filter 过滤器它是 JavaWeb 的三大组件之一。三大组件分别是:Servlet 程序、Listener 监听器、Filter

过滤器

Filter 过滤器它是 JavaEE 的规范。也就是接口

Filter 过滤器它的作用是:拦截请求,过滤响应。

二、Filter拦截原理

Filter接口中有一个doFilter方法,当我们编写好Filter,并配置对哪个web资源进行拦截后,WEB服务器每次在调用web资源的service方法之前,都会先调用一下filter的doFilter方法。web服务器在调用doFilter方法时,会传递一个filterChain对象进来,filterChain对象也提供了一个doFilter方法,开发人员可以根据需求决定是否调用此方法。调用filterChian对象的doFilter方法,web服务器会检查FilterChain对象中是否还有filter,如果有,则调用第2个filter,如果没有,则调用目标资源。相反,如果不调用该方法,web资源不会被访问。

三、创建Filter步骤

创建Filter必须实现Filter接口,实现Filter接口必须重写三个方法:

(1)过滤器初始化:init(FilterConfig filterConfig)

(2)重写doFilter(ServletRequest req, ServletResponse resp, FilterChain

filterChain);Filter中的doFilter()方法主要写实现过滤器功能的代码,doFillter方法中可以一句需求决定是否调用filterChain的doFilter方法放行

(3)注销过滤器:destroy()

除此之外,需要在xml文件中配置需要过滤的web资源。

Filter开发步骤:

(1)导入相关依赖包

<dependencies>

<dependency>

<groupId>javax.servlet</groupId>

<artifactId>servlet-api</artifactId>

<version>2.5</version>

</dependency>

<dependency>

<groupId>javax.servlet.jsp</groupId>

<artifactId>javax.servlet.jsp-api</artifactId>

<version>2.3.3</version>

</dependency>

<dependency>

<groupId>javax.servlet.jsp.jstl</groupId>

<artifactId>jstl-api</artifactId>

<version>1.2</version>

</dependency>

<dependency>

<groupId>taglibs</groupId>

<artifactId>standard</artifactId>

<version>1.1.2</version>

</dependency>

<dependency>

<groupId>mysql</groupId>

<artifactId>mysql-connector-java</artifactId>

<version>5.1.47</version>

</dependency>

</dependencies>

(2)编写过滤器

实现Filter接口(注意导包不要导错!)javax.servlet包下的Filter,实现对应的方法即可

public class CharacterEncodingFilter implements Filter {

//初始化:web服务器启动就初始化了

public class CharacterEncodingFilter implements Filter {

//初始化:web服务器启动就初始化了

public void init(FilterConfig filterConfig) throws ServletException {

System.out.println("CharacterEncodingFilter初始化");

}

/*

- 1.过滤中的所有代码,在过滤特定请求的时候都会执行

- 2.必须要让过滤器继续前行

- chain.doFilter(request,response);

- */

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {

//在这里统一处理编码问题

request.setCharacterEncoding("utf-8");

response.setCharacterEncoding("utf-8");

response.setContentType("text/html;charset=utf-8");

System.out.println("CharacterEncodingFilter执行之前");

chain.doFilter(request,response);//让我们的请求继续走,如果不写,程序到这里就会被拦截停止!

System.out.println("CharacterEncodingFilter执行之后");

}

//销毁:web服务器关闭的时候,过滤会销毁

public void destroy() {

System.out.println("CharacterEncodingFilter销毁");

}

}

public void destroy() {

System.out.println("CharacterEncodingFilter销毁");

}

}

(3)在web.xml配置Filter

<filter>

<filter-name>charset</filter-name>

<filter-class>com.xiaoyao.filter.CharacterEncodingFilter</filter-class>

</filter>

<filter-mapping>

<filter-name>charset</filter-name>

<!--只要是 /servlet 的任何请求,会经过这个过滤器-->

<url-pattern>/servlet/*</url-pattern>

</filter-mapping>

四、Filter的生命周期

Filter的创建和销毁由WEB服务器负责。web应用程序启动时,web 服务器将创建Filter 的实例对象,并调用其init方法,完成对象的初始化功能,从而为后续的用户请求作好拦截的准备工作,filter对象只会创建一次,init方法也只会执行一次。过滤器的注销会随着服务器的关闭而关闭。除此之外,Web容器还可以通过调用destroy方法销毁Filter。destroy方法在Filter的生命周期中仅执行一次。在destroy方法中,可以释放过滤器使用的资源。

Filter 的生命周期包含几个方法:

(1)构造器方法

(2)**init 初始化方法:**第 1,2 步,在 web 工程启动的时候执行(Filter 已经创建)

(3)**doFilter 过滤方法:**第 3 步,每次拦截到请求,就会执行(访问 admin 目录下的 a.jsp

页面,访问一次,拦截一次请求)

(4)**destroy 销毁:**第 4 步,停止 web 工程的时候,就会执行(停止 web 工程,也会销毁 Filter 过滤器)

有些不足还需改善!望海涵!文章来源地址https://www.toymoban.com/news/detail-769062.html

到了这里,关于javaWeb完整项目的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • JavaWeb小项目之Servlet实现用户登录(详细教程学习笔记)【IDEA工具】

    这个【Servlet实现用户登录】小项目,作为 JavaWeb小项目系列 的开篇,未来我会继续完善各个功能,直到可以真正作为一个Web项目(PS:希望这个坑可以填上,说来遗憾,现在已经大三了,人生也比较迷茫,希望可以通过考研改变自己吧。岁月蹉跎,大一学C++,大二学JavaSE的时

    2023年04月11日
    浏览(42)
  • 详细地讲解使用MyEclipse创建一个简单的html与servlet交互的JavaWeb项目

    如图:在用户名和密码输入内容后,点击登录跳转到下一个页面 这个图片里面的验证码、下拉框什么的可以忽略,我们只做用户名和密码,因为不涉及连接到数据库,我们的密码是随便输入的。 下面我们来开始创建项目 打开MyEclipse,点击左上角的File,选择new,再选择Web P

    2024年02月06日
    浏览(37)
  • 【图书管理系统】Servlet+JSP+MySql 实现的一个前后端 javaweb项目(内附源码)

    源码分享在文末! 学习完Javaweb的知识后做了个项目练练手,我选择了经典而且比较简单的图书管理系统。 最近有时间,整理了一下,分享给大家,希望能够帮到你! 基于B/S结构 前端: HTML+CSS+JS +JQuery 后端: Servlet+JSP+MySql 操作系统: win8/win10 JDK: 8.0 开发工具: Intellij IDEA2020.1 旗舰

    2024年02月06日
    浏览(40)
  • JavaWeb开发框架对比与选择:Struts、Spring MVC、JavaEE

    引言:         在JavaWeb开发领域,选择合适的开发框架对于项目的成功与否至关重要。随着技术的不断发展,出现了许多优秀的开发框架,其中最为知名的包括Struts、Spring MVC和JavaEE。本文将对这三个框架进行对比,并给出选择的建议。 一、Struts框架         Struts是一

    2024年02月04日
    浏览(32)
  • 如何使用eclipse导入别人的javaWeb项目(超详细完整)

    1、点击文件,点击导入  2、选择常规 现有项目到工作空间中 下一步  3、点击浏览找到对应项目,最好将“选项”下方的将项目复制到工作空间复选框打上勾(相当于将项目拷贝一份到你的workspace工作空间,对项目代码修改只修改到工作空间的项目,不会影响原项目文件)

    2024年02月03日
    浏览(43)
  • 【JAVA】Eclipse+MYSQL数据库+JSP+基础Servlet开发JavaWeb学生信息管理系统

    目录 前言 一、搭建环境  二、功能实现、 1、   登陆界面 注册按钮 2、学生信息管理系统主界面 3、dao包  4、用户的信息展示,添加,删除,修改功能(只展示添加代码) 5、学生的信息展示,添加,删除,修改功能(只展示添加代码) 6、成绩的信息展示,添加,删除,修

    2024年02月05日
    浏览(47)
  • 基于javaweb+mysql的jsp+servlet图书图书馆管理系统(java+jsp+layui+bootstrap+servlet+mysql)

    基于javaweb+mysql的jsp+servlet图书图书馆管理系统(java+jsp+layui+bootstrap+servlet+mysql) 运行环境 Java≥8、MySQL≥5.7、Tomcat≥8 开发工具 eclipse/idea/myeclipse/sts等均可配置运行 适用 课程设计,大作业,毕业设计,项目练习,学习演示等 功能说明 基于javaweb+mysql的JSP+Servlet图书图书馆管理系统

    2024年02月04日
    浏览(43)
  • 基于javaweb+mysql的jsp+servlet幼儿园管理系统(java+jsp+easyui+h-ui+servlet+mysql)

    基于javaweb+mysql的jsp+servlet幼儿园管理系统(java+jsp+easyui+h-ui+servlet+mysql) 私信 源码获取及调试交流 运行环境 Java≥8、MySQL≥5.7、Tomcat≥8 开发工具 eclipse/idea/myeclipse/sts等均可配置运行 适用 课程设计,大作业,毕业设计,项目练习,学习演示等 功能说明 基于javaweb的JSP+Servlet幼儿

    2024年01月16日
    浏览(63)
  • 基于javaweb+mysql的jsp+servlet学生成绩管理系统(管理员、教师、学生)(java+jsp+servlet+javabean+mysql+tomcat)

    基于javaweb+mysql的jsp+servlet学生成绩管理系统(管理员、教师、学生)(java+jsp+servlet+javabean+mysql+tomcat) 运行环境 Java≥8、MySQL≥5.7、Tomcat≥8 开发工具 eclipse/idea/myeclipse/sts等均可配置运行 适用 课程设计,大作业,毕业设计,项目练习,学习演示等 功能说明 管理员:个人信息、课程

    2024年02月02日
    浏览(47)
  • JavaWeb小项目——【源码】使用Vue+axios+Servlet+Lombok+JDBC+MySQL技术栈实现云笔记管理系统案例的开发

    使用Vue+axios+Servlet+Lombok+JDBC+MySQL技术栈实现云笔记管理系统案例的开发 (一)题目要求 使用Vue+axios+Servlet+Lombok+JDBC+MySQL技术栈实现云笔记管理系统案例的开发 (二)数据库设计(10分) 创建数据库woniu_note (1)用户表:t_user,必要字段包含:用户名(username)、密码(passwd)

    2024年02月09日
    浏览(28)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包