JavaWeb完整案例详细步骤

废话少说,展示完整案例

代码的业务逻辑图

主要实现功能

基本的CURD、分页查询、条件查询、批量删除

所使用的技术

  • 前端:Vue+Ajax+Elememt-ui

  • 后端:Web层(Servlet)+Service层+Dao层(持久层)+Mybatis

步骤:

第一步:创建项目、导入jar包、创建数据库、Element-ui、Axios框架

  • pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
 <modelVersion>4.0.0</modelVersion>
 <groupId>com.wfy</groupId>
 <artifactId>BrandTest</artifactId>
 <packaging>war</packaging>
 <version>1.0-SNAPSHOT</version>
 <name>BrandTest Maven Webapp</name>
 <url>http://maven.apache.org</url>
 <dependencies>
   <dependency>
     <groupId>junit</groupId>
     <artifactId>junit</artifactId>
     <version>4.13.2</version>
     <scope>test</scope>
   </dependency>
<!-- servlet-->
   <dependency>
     <groupId>javax.servlet</groupId>
     <artifactId>javax.servlet-api</artifactId>
     <version>4.0.1</version>
   </dependency>
<!-- mysql-->
   <dependency>
     <groupId>mysql</groupId>
     <artifactId>mysql-connector-java</artifactId>
     <version>8.0.30</version>
   </dependency>
<!-- ajax-->
   <dependency>
     <groupId>com.alibaba</groupId>
     <artifactId>fastjson</artifactId>
     <version>2.0.14</version>
   </dependency>
<!--mybatis-->
   <dependency>
     <groupId>org.mybatis</groupId>
     <artifactId>mybatis</artifactId>
     <version>3.5.11</version>
     <scope>compile</scope>
   </dependency>
 </dependencies>
 <build>
   <finalName>BrandTest</finalName>
 </build>
</project>
  • mybatis-config.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
       PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
       "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>

   <!--起别名-->
   <typeAliases>
       <package name="com.wfy.pojo"/>
   </typeAliases>
   <environments default="development">
       <environment id="development">
           <transactionManager type="JDBC"/>
           <dataSource type="POOLED">
               <property name="driver" value="com.mysql.jdbc.Driver"/>
               <property name="url" value="jdbc:mysql:///test?useSSL=false&amp;useServerPrepStmts=true"/>
               <property name="username" value="root"/>
               <property name="password" value="root"/>
           </dataSource>
       </environment>
   </environments>
   <mappers>
       <!--扫描mapper-->
       <package name="com.wfy.mapper"/>
   </mappers>
</configuration>
  • 数据库sql文件

/*
Navicat Premium Data Transfer

Source Server         : Mybatis
Source Server Type   : MySQL
Source Server Version : 50528
Source Host           : localhost:3306
Source Schema         : test

Target Server Type   : MySQL
Target Server Version : 50528
File Encoding         : 65001

Date: 16/10/2022 09:32:18
*/

SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
-- Table structure for brand
-- ----------------------------
DROP TABLE IF EXISTS `brand`;
CREATE TABLE `brand`  (
 `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '编号',
 `brand_name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '品牌名',
 `company_name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '公司名',
 `ordered` int(11) NOT NULL COMMENT '排序字段',
 `description` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT '描述信息',
 `status` int(11) NOT NULL COMMENT '状态',
 PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 74 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Compact;

-- ----------------------------
-- Records of brand
-- ----------------------------
INSERT INTO `brand` VALUES (1, '小潮Team', '上海潮晟文化传播有限公司', 2, '带给别人快乐是一件很酷的事情', 1);
INSERT INTO `brand` VALUES (2, '宠物星球', '凌飞科技有限公司', 1, '为理想打造梦幻家园', 1);
INSERT INTO `brand` VALUES (3, '小潮Team', '上海潮晟文化传播有限公司', 3, '带给别人快乐是一件很酷的事情', 1);
INSERT INTO `brand` VALUES (4, '小潮Team', '上海潮晟文化传播有限公司', 5, '带给别人快乐是一件很酷的事情', 1);
INSERT INTO `brand` VALUES (5, '小潮Team', '上海潮晟文化传播有限公司', 10, '带给别人快乐是一件很酷的事情', 1);
INSERT INTO `brand` VALUES (6, '宠物星球', '凌飞科技有限公司', 15, '为理想打造梦幻家园', 1);
INSERT INTO `brand` VALUES (7, '宠物星球', '凌飞科技有限公司', 18, '为理想打造梦幻家园', 1);
INSERT INTO `brand` VALUES (8, '小米', '小米科技有限公司', 102, '为发烧而生', 0);
INSERT INTO `brand` VALUES (9, '华为', '华为科技有限公司', 20, '就是割韭菜', 0);
INSERT INTO `brand` VALUES (10, '三只松鼠', '三只松鼠股份有限公司', 50, '吃吃吃', 1);
INSERT INTO `brand` VALUES (11, '京东', '北京京东世纪贸易有限公司', 34, '嗖嗖嗖', 1);
INSERT INTO `brand` VALUES (12, '腾讯', '腾讯计算机系统有限公司', 45, '就是圈钱', 1);
INSERT INTO `brand` VALUES (13, '百度', '百度在线网络技术公司', 10, '搜的就是快', 1);
INSERT INTO `brand` VALUES (14, 'aa', 'aaa', 23, 'aaa', 0);
INSERT INTO `brand` VALUES (15, 'bbb', 'bbb', 24, 'bbb', 1);
INSERT INTO `brand` VALUES (16, 'ccc', 'ccc', 25, 'ccc', 0);
INSERT INTO `brand` VALUES (17, 'ddd', 'ddd', 26, 'ddd', 1);
INSERT INTO `brand` VALUES (18, 'eee', 'eee', 27, 'eee', 1);
INSERT INTO `brand` VALUES (19, 'fff', 'fff', 28, 'fff', 1);
INSERT INTO `brand` VALUES (20, 'ggg', 'ggg', 29, 'ggg', 1);
INSERT INTO `brand` VALUES (21, 'hhh', 'hhh', 30, 'hhh', 0);
INSERT INTO `brand` VALUES (22, 'iii', 'iii', 31, 'iii', 1);
INSERT INTO `brand` VALUES (23, 'jjj', 'jjj', 32, 'jjj', 0);
INSERT INTO `brand` VALUES (24, 'kkk', 'kkk', 33, 'kkk', 1);
INSERT INTO `brand` VALUES (25, 'lll', 'lll', 34, 'lll', 1);
INSERT INTO `brand` VALUES (26, 'mmm', 'mmm', 35, 'mmm', 1);
INSERT INTO `brand` VALUES (27, 'nnn', 'nnn', 36, 'nnn', 1);
INSERT INTO `brand` VALUES (28, '111', '111', 37, '111', 0);
INSERT INTO `brand` VALUES (29, '222', '222', 38, '222', 0);
INSERT INTO `brand` VALUES (30, '333', '333', 39, '333', 0);
INSERT INTO `brand` VALUES (31, '444', '444', 40, '444', 0);
INSERT INTO `brand` VALUES (32, '555', '555', 41, '555', 0);
INSERT INTO `brand` VALUES (33, '666', '666', 42, '666', 1);
INSERT INTO `brand` VALUES (34, '777', '777', 43, '777', 0);
INSERT INTO `brand` VALUES (35, '888', '888', 44, '888', 1);

SET FOREIGN_KEY_CHECKS = 1;
  • Element-ui和Axios---需要自取

链接:https://pan.baidu.com/s/1vGP-cTM5H2r90xssVB1EYA?pwd=0323 提取码:0323

第二步:项目分析

首先,我们要先进行分析,要实现案例对品牌信息的操作,需要三层架构的相互调用和操作来实现。

  1. Web层(表现层):表现层我们要实现通过对页面相应的操作,获取页面上的请求或者数据发送到Service层,然后通过Service层的一些方法将数据返回到Web层,进行显示

  2. Service层(业务逻辑层):这里主要是进行方法的编写、数据的调度,将从前端拿到的数据或者请求传入到相应的方法体内,调用相应的方法实现相应的操作。

  3. Dao层(数据访问层):主要创建pojo实体类,通过mapper映射的方式,获取数据库的数据。

第三步:废话少说开始编写

  1. 创建Maven项目,创建brand.html页面,导入axios.js和vue.js,以及element-ui的框架

这里用到的Element前端框架组件,可以参考:Element - 网站快速成型工具

<link rel='stylesheet' href='js/lib-master/theme-chalk/index.css'>
<script src='js/vue.js' charset='UTF-8'></script>
<script src='js/lib-master/index.js' charset='UTF-8'></script>
<script src='js/axios-0.18.0.js' charset='UTF-8'></script>
<!DOCTYPE html>
<html lang="en" >
<head>
   <meta charset="UTF-8">
   <title>Title</title>
 <style>
   .el-table .warning-row {
     background: oldlace;
  }

   .el-table .success-row {
     background: #f0f9eb;
  }
 </style>
</head>
<body>
<div id="app">
<!-- 搜索表单 -->
 <el-form :inline="true" :model="brand" class="demo-form-inline">
   <el-form-item label="当前状态">
   </el-form-item>
   <el-select v-model="brand.status" placeholder="当前状态">
     <el-option label="启用" value="1"></el-option>
     <el-option label="禁用" value="0"></el-option>
   </el-select>
   <el-form-item label="企业名称">
     <el-input v-model="brand.companyName" placeholder="企业名称"></el-input>
   </el-form-item>
   <el-form-item label="品牌名称">
     <el-input v-model="brand.brandName" placeholder="品牌名称"></el-input>
   </el-form-item>
   <el-form-item>
     <el-button type="primary" @click="onSubmit">查询</el-button>
   </el-form-item>
 </el-form>
<!-- 删除和新增按钮-->
 <el-row>
   <el-button type="danger" plain @click="deleteByIds">批量删除</el-button>
   <el-button type="primary" @click="dialogVisible=true" plain>新增</el-button>
 </el-row>

<!-- 新增数据的对话框表单-->
 <el-dialog
         title="编辑品牌"
         :visible.sync="dialogVisible"
         width="30%"
         >
   <el-form ref="form" :model="brand" label-width="80px">
     <el-form-item label="品牌名称">
       <el-input v-model="brand.brandName"></el-input>
     </el-form-item>
     <el-form-item label="企业名称">
       <el-input v-model="brand.companyName"></el-input>
     </el-form-item>
     <el-form-item label="排序">
       <el-input v-model="brand.ordered"></el-input>
     </el-form-item>
     <el-form-item label="备注">
       <el-input type="textarea" v-model="brand.description"></el-input>
     </el-form-item>
     <el-form-item label="状态">
       <el-switch v-model="brand.status" active-value="1" inactive-value="0"></el-switch>
     </el-form-item>
     <el-form-item>
       <el-button type="primary" @click="addBrand">提交</el-button>
       <el-button @click="dialogVisible = false">取消</el-button>
     </el-form-item>
   </el-form>
 </el-dialog>
<!-- 更改数据的表单-->
 <el-dialog
         title="更改品牌数据信息"
         :visible.sync="dialogVisible_update"
         width="30%"
 >
   <template slot-scope="scope">
     <el-form ref="form" :model="updateTable" label-width="80px">
       <el-form-item label="品牌名称">
         <el-input v-model="updateTable.brandName"></el-input>
       </el-form-item>
       <el-form-item label="企业名称">
         <el-input v-model="updateTable.companyName"></el-input>
       </el-form-item>
       <el-form-item label="排序">
         <el-input v-model="updateTable.ordered"></el-input>
       </el-form-item>
       <el-form-item label="备注">
         <el-input type="textarea" v-model="updateTable.description"></el-input>
       </el-form-item>
       <el-form-item label="状态">
         <el-switch v-model="updateTable.status" active-value="1" inactive-value="0"></el-switch>
       </el-form-item>
       <el-form-item>
         <el-button type="primary" @click="updateBrand">提交</el-button>
         <el-button @click="dialogVisible_update = false">取消</el-button>
       </el-form-item>
     </el-form>
   </template>

 </el-dialog>
<!-- 表格-->
 <template >
   <el-table
           :data='tableData'
           style='width: 100%'
           :row-class-name='tableRowClassName'
           @selection-change='handleSelectionChange'
          >
     <el-table-column
             type='selection'
             width='55'>
     </el-table-column>
     <el-table-column
             type='index'
             width='50'>
     </el-table-column>
     <el-table-column
             prop='brandName'
             label='品牌名称'
             align='center'
            >
     </el-table-column>
     <el-table-column
             prop='companyName'
             label='企业名称'
             align='center'
             >
     </el-table-column>
     <el-table-column
             prop='ordered'
             align='center'
             label='排序'>
     </el-table-column>
     <el-table-column
             prop='description'
             align='center'
             label='描述'>
     </el-table-column>
     <el-table-column
             prop='statusStr'
             align='center'
             label='当前状态'>
     </el-table-column>
     <el-table-column
             align='center'
             label='操作'>

       <template slot-scope="scope">
       <el-row>
         <el-button type='primary'  @click="selectById(scope.row.id)"  >修改</el-button>
         <el-button type='danger'@click="deleteBrand(scope.row.id)">删除</el-button>
       </el-row>
       </template>

     </el-table-column>

   </el-table>
 </template>
<!-- 分页工具条-->
 <el-pagination
         @size-change='handleSizeChange'
         @current-change='handleCurrentChange'
         :current-page='currentPage'
         :page-sizes='[5, 10, 15, 20]'
         :page-size='5'
         layout='total, sizes, prev, pager, next, jumper'
         :total='totalCount'>
 </el-pagination>
</div>




<link rel='stylesheet' href='js/lib-master/theme-chalk/index.css'>
<script src='js/vue.js' charset='UTF-8'></script>
<script src='js/lib-master/index.js' charset='UTF-8'></script>
<script src='js/axios-0.18.0.js' charset='UTF-8'></script>
<script>
new Vue({
  el:'#app',
  mounted(){
  this.selectByPage()
  },
  data() {
    return {
      //总记录数
      totalCount:'',
      //分页 --当前页码
      currentPage:1 ,
      //每页显示的条数
      pageSize:5,
      //新增表单的显示与隐藏的标记
      dialogVisible: false,
      dialogVisible_update:false,

      //品牌模型数据
      brand: {
        status:'',
        companyName: '',
        brandName: '',
        id:'',
        ordered:'',
        description:'',
      },
      updateTable:{
        status:'',
        companyName: '',
        brandName1: '',
        id:'',
        ordered:'',
        description:'',
      },
      //被选中的id数组
      selectIds:[],

      //复选框选择信息集合
      multipleSelection: [],
      //表格的数据
      tableData: [{
        brandName: '',
        companyName: '',
        ordered: '',
        description:'',
        status:''
      }],
    }
  },
  methods: {

    //响应数据,显示所有信息
    GetAll(){
      console.log('提示语句')
      //当页面加载完成后,发送异步请求,获取数据
      axios({
        method:'get',
        url:'brand/selectAll',
      }).then( resp=>{
        this.tableData=resp.data ;
        console.log('提示语句')
      })
    },
    //查询分页的数据
    selectByPage(){
      axios({
        method:'post',
        url:'brand/selectByPageAndCondition?currentPage='+this.currentPage+'&pageSize='+this.pageSize,
        data:this.brand,
      }).then(response=>{
        //设置表格数据
        this.tableData= response.data.rows; //{rows:[],totalCount:}
        //设置总记录数
        this.totalCount=response.data.totalCount;
      })
    },

  tableRowClassName({row, rowIndex}) {
      if (rowIndex === 1) {
        return 'warning-row';
      } else if (rowIndex === 3) {
        return 'success-row';
      }
      return '';
    },
    //复选框选中后执行的操作
    handleSelectionChange(val) {
      this.multipleSelection = val;
      console.log(this.multipleSelection)
    },

    //查询的方法
    onSubmit() {
      //console.log(this.brand);
      this.selectByPage();

    },
    //添加表单数据的方法
    addBrand(){
       //console.log(this.brand)
      //发送ajax请求,添加数据
      axios({
        method:'post',
        url: 'brand/add',
        data: this.brand
      }).then(resp=>{
          if(resp.data=="success"){
            //添加成功
            this.selectByPage();
            //关闭窗口
            this.dialogVisible=false;
            //添加成功的标识
            this.$message({
              showClose: true,
              message: '成功添加数据',
              type: 'success'
            });
          }
      })
    },

    //删除一条指定数据操作
    deleteBrand(id){
      //弹窗提示是否删除
      this.$confirm('此操作将永久删除该文件, 是否继续?', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(() => {
        this.$message({
          type: 'success',
          message: '删除成功!'
        });
      }).catch(() => {
        this.$message({
          type: 'info',
          message: '已取消删除'
        });
      });
             axios({
               method:'post',
               url:'brand/deleteById',
               data:id
            }).then(response=>{
               if(response.data=='success'){
                 //重新查询
                 this.selectByPage();
                 //显示成功提示
                 this.$message({
                   showClose: true,
                   message: '删除数据成功',
                   type: 'success'
                });
              }
            })
    },
    //更改用户数据
    //1.对用户数据进行回显操作
    selectById(id){
      axios({
        method:'post',
        url: 'brand/selectById',
        data: id
      }).then(response=>{
        // console.log(id)
        //回显数据
        this.updateTable=response.data;
        // console.log(_this.updateTable)
        //弹出修改框
        this.dialogVisible_update=true;
      })
    },
    //2.对回显数据进行更改操作
    updateBrand(){
        axios({
          method:'post',
          url:'brand/updateBrand',
          data:this.updateTable
        }).then(resp=>{
          if(resp.data=='success'){
            //重新查询数据
            this.selectByPage();
            //关闭窗口
            this.dialogVisible_update=false;
            //更改成功提示
            this.$message({
              showClose: true,
              message: '数据更改成功',
              type: 'success'
            });
          }
        })
    },

    //删除多条数据
    deleteByIds(){

      //弹出确认对话框
      this.$confirm('此操作将永久删除该文件, 是否继续?', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(() => {
        this.$message({
          type: 'success',
          message: '删除成功!'
        });
      }).catch(() => {
        this.$message({
          type: 'info',
          message: '已取消删除'
        });
      });

      //1.创建id数组[] 从this.multipleSelection里面获取id
      for (let i = 0; i < this.multipleSelection.length; i++) {
        let selectionElement=this.multipleSelection[i];
        this.selectIds[i]=selectionElement.id;
        //console.log(this.selectIds)
      }
         //2.发送ajax请求,并携带ids数据
      axios({
        method:'post',
        url:'brand/deleteByIds',
        data:this.selectIds
      }).then(resp=>{
        if(resp.data=='success'){
          //删除成功
          //重新查询数据
          this.selectByPage();
          //删除成功提示
          this.$message({
            showClose: true,
            message: '删除成功',
            type: 'success'
          });
        }
      })
    },
    //分页工具条
    handleSizeChange(val) {
      //console.log(`每页 ${val} 条`);
      //设置每页展示的条数
      this.pageSize = val;
    },
    handleCurrentChange(val) {
     // console.log(`当前页: ${val}`);
      //重新设置当前页码数
      this.currentPage=val;
      this.selectByPage();
    }
  },

})
</script>
</body>
</html>
  1. Dao层

  • 创建pojo实体类

package com.wfy.pojo;

public class Brand {
   //id 主键
   private Integer id;
   //brandName 品牌名称
   private String brandName;
   //企业名称
   private String companyName;
   //排序字段
   private Integer ordered;
   //描述信息
   private String description;
   //状态: 0:禁用 1:启动
   private Integer status;
   private String statusStr;

   public Integer getId() {
       return id;
  }

   public void setId(Integer id) {
       this.id = id;
  }

   public String getBrandName() {
       return brandName;
  }

   public void setBrandName(String brandName) {
       this.brandName = brandName;
  }

   public String getCompanyName() {
       return companyName;
  }

   public void setCompanyName(String companyName) {
       this.companyName = companyName;
  }

   public Integer getOrdered() {
       return ordered;
  }

   public void setOrdered(Integer ordered) {
       this.ordered = ordered;
  }

   public String getDescription() {
       return description;
  }

   public void setDescription(String description) {
       this.description = description;
  }

   public Integer getStatus() {
       return status;
  }

   //逻辑视图
   public String getStatusStr(){
       if(status==1){
           return "启用";
      }
       return status==0 ?"禁用":"启用";
  }

   public void setStatus(Integer status) {
       this.status = status;
  }

   @Override
   public String toString() {
       return "Brand{" +
               "id=" + id +
               ", brandName='" + brandName + '\'' +
               ", companyName='" + companyName + '\'' +
               ", ordered=" + ordered +
               ", description='" + description + '\'' +
               ", status=" + status +
               '}';
  }
}
  • PageBean实体类--分页查询

package com.wfy.pojo;

import java.util.List;

//分页查询的JavaBean
public class PageBean<T> {

   //总记录数
   private  int totalCount;

   //当前业数据
   private List<T> rows;

   public int getTotalCount() {
       return totalCount;
  }

   public void setTotalCount(int totalCount) {
       this.totalCount = totalCount;
  }

   public List<T> getRows() {
       return rows;
  }

   public void setRows(List<T> rows) {
       this.rows = rows;
  }
}
  • BrandMapper的接口和映射文件

package com.wfy.mapper;

import com.wfy.pojo.Brand;
import org.apache.ibatis.annotations.*;

import java.util.List;

public interface BrandMapper {

   //查询所有
   @Select("select * from brand")
   @ResultMap("brandResultMap")
   List<Brand> SelectAll();

   //新增品牌
   @Insert("insert into brand values (null,#{brandName},#{companyName},#{ordered},#{description},#{status})")
   void AddBrand(Brand brand);

   //根据id来获取指定品牌信息,实现数据的回显操作
   @Select("select * from brand where id = #{id}")
   @ResultMap("brandResultMap")
   Brand SelectById(int id);
   //更改品牌信息
   @Update("update brand set brand_name=#{brandName},company_name=#{companyName},ordered=#{ordered},description=#{description} where id=#{id} ")
   void UpdateBrand(Brand brand);

   //删除指定品牌数据
   @Delete("delete from brand where id =#{id}")
   void deleteById(int id);

   //删除多条数据
   void DeleteByIds( @Param("ids") int[] ids);

   //分页查询 begin--开始的索引 size--获取信息的条目数
   @Select("select * from brand limit #{begin},#{size} ")
  @ResultMap("brandResultMap")
   List<Brand> SelectByPage(@Param("begin") int begin,@Param("size") int size);

   //查询总信息条数
   @Select("select count(*) from brand")
   int SelectTotalCount();

   //分页条件查询 begin--开始的索引 size--获取信息的条目数
   List<Brand> SelectByPageAndCondition(@Param("begin") int begin,@Param("size") int size,@Param("brand")Brand brand);

   //条件查询总信息条数
   int SelectTotalCountByCondition(Brand brand);
}
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
       PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
       "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--
namespace:名称空间
数据库的字段名称 和 实体类的属性名称 不一样 则不能自动封装数据
* 方法: 1.起别名 : 用as ,对不一样的列明起别名,让别名和列明相同
2.resultMap:完成不一样的属性名和列名的映射
1.定义<resultMap>标签
2.在<select>标签中,使用resultMap属性替换resultType属性

-->

<mapper namespace="com.wfy.mapper.BrandMapper">

   <resultMap id="brandResultMap"  type="brand">
       <result property="brandName" column="brand_name"/>
       <result property="companyName" column="company_name"/>
   </resultMap>


   <delete id="DeleteByIds">
      delete from brand where id in
           <foreach collection="ids" item="id" open="(" separator="," close=")">
              #{id}
           </foreach>
   </delete>
<!--   where brand_name=#{brand.brandName}-->
   <select id="SelectByPageAndCondition" resultMap="brandResultMap">
  select *
    from brand
<where>
    <if test="brand.brandName !=null and brand.brandName!=''">
        and brand_name like #{brand.brandName}
    </if>
    <if test="brand.companyName !=null and brand.companyName!=''">
        and company_name like #{brand.companyName}
    </if>
    <if test="brand.status !=null">
        and status=#{brand.status}
    </if>
</where>

      limit #{begin} ,#{size}

   </select>
   <select id="SelectTotalCountByCondition" resultType="java.lang.Integer">
          select count(*)
            from brand
       <where>
           <if test="brandName !=null and brandName!=''">
              and brand_name like #{brandName}
           </if>
           <if test="companyName !=null and companyName!=''">
              and company_name like #{companyName}
           </if>
           <if test="status !=null">
              and status=#{status}
           </if>
       </where>


</select>


</mapper>

注意这里的映射文件需要在resource目录下创建分层目录,通过‘\’进行分割

及文件的目录名为:“ com\wfy\mapper”

  1. Service层(业务逻辑层)

因为我们需要不断的调用SqlSession的方法,通过mapper映像的方式,为了降低程序的耦合度,同时为了简化代码,通过接口的方式来实现对方法的调用

  • 创建BrandService接口

package com.wfy.service;

import com.wfy.pojo.Brand;
import com.wfy.pojo.PageBean;

import java.util.List;

public interface BrandService {

   //查询所有数据
   public List<Brand> SelectAll();
   //新增数据
   void AddBrand(Brand brand);
//更改数据信息
   //获取查询到的数据进行表格显现
   Brand SelectById(int id);
   void UpdateBrand(Brand brand);

 //删除指定数据
   void DeleteById(int id);

   //删除多条数据
   void DeleteByIds(int[] ids);

  //分页查询     currentPage--当前页码     pageSize--每页展示条数
   PageBean<Brand> SelectByPage(int currentPage,int pageSize);

   //分页条件查询
   PageBean<Brand> SelectByPageAndCondition(int currentPage,int pageSize,Brand brand);

}
  • 创建BrandServiceImpl接口的实现方法

因为需要不断的调用SqlSessionFactoy工厂,为了简化代码,创建Util包,编写一个SqlSessionFactoryUtils来简化代码逻辑

package com.wfy.util;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.IOException;
import java.io.InputStream;

public class SqlSessionFactoryUtils {
   private static SqlSessionFactory sqlSessionFactory;
   static {
      //静态代码块会随着类的加载而自动执行,且只执行一次
       try {
           String resource = "mybatis-config.xml";
           InputStream inputStream = null;
           inputStream = Resources.getResourceAsStream(resource);
           sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
      } catch (IOException e) {
           throw new RuntimeException(e);
      }
  }
   public static SqlSessionFactory getSqlSessionFactory(){
            return sqlSessionFactory;
  }
}
package com.wfy.service.impl;

import com.wfy.mapper.BrandMapper;
import com.wfy.pojo.Brand;
import com.wfy.pojo.PageBean;
import com.wfy.service.BrandService;
import com.wfy.util.SqlSessionFactoryUtils;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;

import java.util.List;

public class BrandServiceImpl implements BrandService {
   //1.创建sqlSessionFactory 工厂对象
   SqlSessionFactory factory = SqlSessionFactoryUtils.getSqlSessionFactory();
   public List<Brand> SelectAll() {
    //2.获取SqlSession对象
       SqlSession sqlSession = factory.openSession();
       //3.获取BrandMapper
       BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);
       //4.调用方法
       List<Brand> brands = mapper.SelectAll();
       //5.释放资源
       sqlSession.close();
       return brands;
  }

   public void AddBrand(Brand brand) {
       SqlSession sqlSession = factory.openSession();
       BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);
       mapper.AddBrand(brand);
       sqlSession.commit();
       sqlSession.close();
  }

   public Brand SelectById(int id) {
      //2.获取SqlSession对象
       SqlSession sqlSession = factory.openSession();
       BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);
       Brand brand = mapper.SelectById(id);
       //关闭资源
       sqlSession.close();

       return brand;

  }

   public void UpdateBrand(Brand brand) {
       SqlSession sqlSession = factory.openSession();
       BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);
       mapper.UpdateBrand(brand);
       //提交事务、关闭资源
       sqlSession.commit();
       sqlSession.close();
  }

   public void DeleteById(int id) {
       SqlSession sqlSession = factory.openSession();
       BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);
       mapper.deleteById(id);
       sqlSession.commit();
       sqlSession.close();
  }

   public void DeleteByIds(int[] ids) {
       //2.获取SqlSession对象
       SqlSession sqlSession = factory.openSession();
       //3.获取BrandMapper
       BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);
       //4.调用方法
         mapper.DeleteByIds(ids);

       sqlSession.commit();

       sqlSession.close();

  }

   public PageBean<Brand> SelectByPage(int currentPage, int pageSize) {
       //2.获取SqlSession对象
       SqlSession sqlSession = factory.openSession();
       //3.获取BrandMapper
       BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);

       //4.计算开始索引=(当前页码数-1)*展示的信息条数
       int begin=(currentPage-1) * pageSize;
       //计算条目数
       int size=pageSize;
      //5.查询当前页数据
       List<Brand> rows = mapper.SelectByPage(begin, size);
       //6.查询总记录数
       int totalCount = mapper.SelectTotalCount();
       //7.封装PageBean对象
       PageBean<Brand> pageBean=new PageBean<Brand>();
       pageBean.setRows(rows);
       pageBean.setTotalCount(totalCount);

       //8.释放资源
       sqlSession.close();
       return pageBean;

  }

   public PageBean<Brand> SelectByPageAndCondition(int currentPage, int pageSize, Brand brand) {
       //2.获取SqlSession对象
       SqlSession sqlSession = factory.openSession();
       //3.获取BrandMapper
       BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);

       //4.计算开始索引=(当前页码数-1)*展示的信息条数
       int begin=(currentPage-1) * pageSize;
       //计算条目数
       int size=pageSize;
       //处理brand条件,设置模糊表达式
       String brandName = brand.getBrandName();
       if (brandName !=null&&brandName.length()>0){
           brand.setBrandName("%"+brandName+"%");
      }
       String companyName = brand.getCompanyName();
       if (companyName !=null&&companyName.length()>0){
           brand.setCompanyName("%"+companyName+"%");
      }
       //5.查询当前页数据
       List<Brand> rows = mapper.SelectByPageAndCondition(begin,size,brand);
       //6.查询总记录数
       int totalCount = mapper.SelectTotalCountByCondition(brand);
       //7.封装PageBean对象
       PageBean<Brand> pageBean=new PageBean<Brand>();
       pageBean.setRows(rows);
       pageBean.setTotalCount(totalCount);

       //8.释放资源
       sqlSession.close();
       return pageBean;
  }
}
  1. Servlet的编写

如果为了实现不同的方法,我们需要不断地调用HttpServlet,因此通过编写一个BaseServlet来代替HttpServlet

package com.wfy.servlet;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;

//替换HttpServlet ,根据请求的最后一段路径来进行方法分发
public class BaseServlet extends HttpServlet {
   //根据请求的最后一段路径来进行方法的分发
   @Override
   protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
       //1.获取请求路径
       String uri = req.getRequestURI();  //BrandTest/brand/SelectAllServlet
      // System.out.println(uri);
       //2.获取最后一段路径----方法名
       int index=uri.lastIndexOf('/');
       String methodName = uri.substring(index+1);
       //System.out.println(methodName);
       //3.执行方法
       //3-1获取BrandServlet的字节码对象 class
       // this:指代关系 谁调用我(this 所在的方法),我(this)代表谁
      // System.out.println(this);//com.wfy.servlet.BrandServlet@61f761f5
       Class<? extends BaseServlet> cls = this.getClass();
       //3-2.获取方法的Method对象
       try {
           Method method = cls.getMethod(methodName, HttpServletRequest.class, HttpServletResponse.class);
           //3-3执行方法
           method.invoke(this,req,resp);
      } catch (NoSuchMethodException e) {
           throw new RuntimeException(e);
      } catch (InvocationTargetException e) {
           throw new RuntimeException(e);
      } catch (IllegalAccessException e) {
           throw new RuntimeException(e);
      }
  }
}
package com.wfy.servlet;

import com.alibaba.fastjson.JSON;
import com.wfy.pojo.Brand;
import com.wfy.pojo.PageBean;
import com.wfy.service.BrandService;
import com.wfy.service.impl.BrandServiceImpl;

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

@WebServlet("/brand/*")
public class BrandServlet extends BaseServlet{
   private BrandService service = new BrandServiceImpl();

   //获取全部信息
   public void selectAll(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
       //1.调用service查询
       List<Brand> brands = service.SelectAll();
       //2.将数据转换为JSON
       String toJSONString = JSON.toJSONString(brands);
       //3.写数据
       response.setContentType("text/json;charset=utf-8");
       response.getWriter().write(toJSONString);
  }
   //新增信息
   public void add(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{
       //1.接收品牌的数据
       BufferedReader reader = request.getReader();
       String params = reader.readLine();//json字符串
       Brand brand = JSON.parseObject(params, Brand.class);
       //2.调用service
       service.AddBrand(brand);
       //3.响应成功标识
       response.getWriter().write("success");
  }
   //更改指定数据信息
   //1-根据id查找指定数据,进行数据的回显操作
   public void selectById(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
       //1.接收从web层传输过来的id
       BufferedReader reader = request.getReader();
       String params = reader.readLine();
       Integer id = JSON.parseObject(params, int.class);
       Brand brand = service.SelectById(new Integer(id).intValue());
       //2.将数据转化为JSON
       String toJSONString = JSON.toJSONString(brand);
       //3.写入数据
       response.setContentType("text/json;charset=utf-8");
       response.getWriter().write(toJSONString);


  }

   //2-更改品牌的信息
   public void updateBrand(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //1.接收web层传输过来的数据
       BufferedReader reader = request.getReader();
       String params = reader.readLine();
       Brand brand = JSON.parseObject(params, Brand.class);
       //将数据进行回显操作
      // System.out.println(brand);
      service.UpdateBrand(brand);
      //3.响应成功标识
       response.getWriter().write("success");
  }
   //删除指定数据
   public void deleteById(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{
       //1.接收用户传递的id
       BufferedReader reader = request.getReader();
       String params = reader.readLine();
       //将JSON数据转换为java数据
       Integer id = JSON.parseObject(params, int.class);
       service.DeleteById(new Integer(id).intValue());
       //响应成功标识
       response.getWriter().write("success");
  }
   //删除多条数据
   public void deleteByIds(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{
       //1.接收需要删除品牌数据的ids
       BufferedReader reader = request.getReader();
       String params = reader.readLine();
     // System.out.println(params);
       //1-2将接收到的信息转换为int[]
       int[] ids = JSON.parseObject(params, int[].class);
//             for(int id:ids){
//                 System.out.println(id);
//             }
       //2.调用service
        service.DeleteByIds(ids);

       //3.响应成功标识
       response.getWriter().write("success");
  }

   //分页查询
   public void selectByPage(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
       //1.接收参数   当前页码 和 每页展示的条数 在url后进行拼接   url?currentPage=1&pageSize=5
       String _currentPage = request.getParameter("currentPage");
       String _pageSize = request.getParameter("pageSize");
       int currentPage = Integer.parseInt(_currentPage);
       int pageSize = Integer.parseInt(_pageSize);

       //2.调用service进行查询
       PageBean<Brand> pageBean = service.SelectByPage(currentPage, pageSize);
       //3.转换成JSON对象
       String jsonString = JSON.toJSONString(pageBean);
       //4.将数据写入
       response.setContentType("text/json;charset=utf-8");
       response.getWriter().write(jsonString);
  }
   //分页条件查询
   public void selectByPageAndCondition(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
       //1.接收参数   当前页码 和 每页展示的条数 在url后进行拼接   url?currentPage=1&pageSize=5
       String _currentPage = request.getParameter("currentPage");
       String _pageSize = request.getParameter("pageSize");
       int currentPage = Integer.parseInt(_currentPage);
       int pageSize = Integer.parseInt(_pageSize);

       //获取条件查询的对象
       BufferedReader reader = request.getReader();
       String params = reader.readLine();
       Brand brand = JSON.parseObject(params, Brand.class);

       //2.调用service进行查询
       PageBean<Brand> pageBean = service.SelectByPageAndCondition(currentPage,pageSize,brand);
       //3.转换成JSON对象
       String jsonString = JSON.toJSONString(pageBean);
       //4.将数据写入
       response.setContentType("text/json;charset=utf-8");
       response.getWriter().write(jsonString);
  }
}
 

JavaWeb完整案例详细步骤的更多相关文章

  1. eclipse弃坑记第一篇之在idea上配置Tomcat环境并创建Javaweb项目的详细步骤原创

    IntelliJ IDEA是一款功能强大的开发工具,在代码自动提示.重构.J2EE支持.各类版本工具(如git.svn.github).maven等方面都有很好的应用. IntelliJ IDEA有免 ...

  2. centos7+tomcat部署JavaWeb项目超详细步骤

    我们平时访问的网站大多都是发布在云服务器上的,比如阿里云.腾讯云等.对于新手,尤其是没有接触过linux系统的人而言是比较有困难的,而且至今使用云服务器也是有成本的,很多时候我们可以通过虚拟机自己搭建 ...

  3. 【转载】centos7+tomcat部署JavaWeb项目超详细步骤

    我们平时访问的网站大多都是发布在云服务器上的,比如阿里云.腾讯云等.对于新手,尤其是没有接触过linux系统的人而言是比较有困难的,而且至今使用云服务器也是有成本的,很多时候我们可以通过虚拟机自己搭建 ...

  4. webpack+vue+vueRouter模块化构建完整项目实例详细步骤-入门篇

    新建项目 开始(确认已经安装node环境和npm包管理工具) 1.新建项目文件名为start_vuedemo 2.npm init -y 初始化项目,我的win7系统,工程在d盘的vue_test_p ...

  5. 用grunt搭建自动化的web前端开发环境实战教程(详细步骤)

    用grunt搭建自动化的web前端开发环境实战教程(详细步骤) jQuery在使用grunt,bootstrap在使用grunt,百度UEditor在使用grunt,你没有理由不学.不用!前端自动化, ...

  6. java连接mysql数据库详细步骤解析

    java连接mysql数据库详细步骤解析      第一步:下载一个JDBC驱动包,例如我用的是:mysql-connector-java-5.1.17-bin.jar      第二步:导入下载的J ...

  7. Linux Makefile文件编写详细步骤与实践

    Linux Makefile文件编写详细步骤与实践 1.makefile概述 Windows环境下IDE会帮你完成makefile文件的编写,但在UNIX环境下你就必须自己写makefile了,会不会 ...

  8. 如何发布一个自定义Node.js模块到NPM(详细步骤)

    咱们闲话不多说,直接开始! 由于我从没有使用过MAC,所以我不保证本文中介绍的操作与MAC一致. 文章开始我先假定各位已经在window全局安装了Node.js,下面开始进行详细步骤介绍: 本文本着, ...

  9. JavaEE开发之记事本完整案例(SpringBoot + iOS端)

    上篇博客我们聊了<JavaEE开发之SpringBoot整合MyBatis以及Thymeleaf模板引擎>,并且在之前我们也聊了<Swift3.0服务端开发(五) 记事本的开发(iO ...

随机推荐

  1. css基础04

    所有浮动都是贴着浮动的.一左一右的话就毫无联系了. 浮动元素和标准流是两个级别了,浮起来了,后面的人会补上空缺的位置,让其他标准流的盒子占有. 很容易形成叠加效果,(蓝色的标准流会上去补上浮动的位置, ...

  2. Vue3系列2--项目目录介绍及运行项目

    1 Vite项目目录 用Vscode打开创建的项目,看到下面的目录结构: 通过运行  npm install 初始化项目后生成两个初始化文件:node_modules和 package-lock.js ...

  3. LuoguP1799 数列_NOI导刊2010提高 (动态规划)

    $ f[j]=max(f[i−1][j],f[i−1][j−1]+(x == j) $ #include <iostream> #include <cstdio> #inclu ...

  4. Spring源码 17 IOC refresh方法12

    参考源 https://www.bilibili.com/video/BV1tR4y1F75R?spm_id_from=333.337.search-card.all.click https://ww ...

  5. 记录第一次给开源项目提 PR

    本文是深入浅出 ahooks 源码系列文章的第八篇,该系列已整理成文档-地址.觉得还不错,给个 star 支持一下哈,Thanks. 本篇文章算是该系列的一个彩蛋篇,记录一下第一次给开源项目提 PR ...

  6. identity4 系列————案例篇[三]

    前言 前文介绍了identity的用法,同时介绍了什么是identitySourece.apiSource.client 这几个概念,和具体案例,那么下面继续介绍案例了. 正文 这里用官网的案例,因为 ...

  7. HDU6623 Minimal Power of Prime (简单数论)

    题面 T ≤ 50   000 T\leq50\,000 T≤50000 组数据: 输入一个数 N N N ( 2 ≤ N ≤ 1 0 18 2\leq N\leq 10^{18} 2≤N≤1018) ...

  8. 「JOI 2015 Final」分蛋糕 2

    「JOI 2015 Final」分蛋糕 2 题解 这道题让我想起了新年趣事之红包这道DP题,这道题和那道题推出来之后的做法是一样的. 我们可以定义dp[i][len][1] 表示从第i块逆时针数len ...

  9. python中的画图神器——turtle模块

    turtle库的基础命令介绍(1)画布画布cancas是绘图区域,可以设置它的大小和初始位置 turtle.screensize(1000,600,'red') 大小的设置 turtle.setup( ...

  10. dotnet 设计规范 · 抽象定义

    严格来说,只有一个类被其他的类继承,那么这个类就是基类.在很多时候,基类的定义是提供足够的抽象和通用方法和属性.默认实现.在继承关系中,基类定义在上层抽象和底层自定义之间. 他们充当抽象实现的实现帮助 ...