SpringMVC实现与CRUD整合

SpringMVC实现与CRUD整合
说明,该demo中使用List模拟了一套数据源,可以实现简单的crud操作,其中修改使用了SpringMVC的问号传参,删除操作使用了路径传参。
对比问号传参与路径传参:
​ 问号传参,需要使用问号来拼接参数,在接受方,使用request.getParameter(“key”)来获取问号所传递过来的值,如果数据类型不为String,还需要手动转换。可以传递多个值,如果使用多个值,使用&来拼接,不会改变路径级别

​ 路径传参,使用路径符号来传递参数,优点,可以不用做类型转换来直接获取其值。

​ 路径传参也可以使用统配规则,如果同时统配和具体的url都满足,则以最具体的url来处理该请求。

Emp.java

package com.qfedu.bean;

public class Emp {

private int eid;
private String name;
private double salary;

public Emp() {
}

public Emp(int eid, String name, double salary) {
    this.eid = eid;
    this.name = name;
    this.salary = salary;
}

@Override
public String toString() {
    return "Emp{" +
            "eid=" + eid +
            ", name='" + name + '\'' +
            ", salary=" + salary +
            '}';
}

public int getEid() {
    return eid;
}

public void setEid(int eid) {
    this.eid = eid;
}

public String getName() {
    return name;
}

public void setName(String name) {
    this.name = name;
}

public double getSalary() {
    return salary;
}

public void setSalary(double salary) {
    this.salary = salary;
}

}

EmpController.java

RequestMapping

可以通过method来区分不同的请求方式
@RequestMapping(value = “/updateEmp”, method = RequestMethod.POST)代表处理post请求
@RequestMapping(value = “/updateEmp”, method = RequestMethod.GET)代表处理get请求
GETMapping,可以简化代码,专门用来处理get请求(4.3以后的Spring版本可用)

PostMapping,可以简化代码,专门用来处理post请求(4.3以后的Spring版本可用)

PathVariable路径传参的注解,可以实现路径传参。

package com.qfedu.controller;

import com.qfedu.bean.Emp;
import com.qfedu.service.IEmpService;
import com.qfedu.service.impl.EmpServiceImpl;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.*;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
import java.util.List;

@Controller
@RequestMapping("/emp")
public class EmpController {

private IEmpService empService = new EmpServiceImpl();

/**
 * 如果有了users请求,那么该方法会被调用,返回值为将来要渲染的页面
 * @return
 */
@RequestMapping("/emps")
public String getUsersPage(Model model, HttpSession session){

    List<Emp> list = empService.getAllEmps();

    model.addAttribute("list", list);

    session.setAttribute("list",  list);

    return "emp.jsp";
}

@RequestMapping("/getEmpByEid")
public String getEmpByEid(HttpServletRequest request, Model model){

    String seid = request.getParameter("eid");

    int eid = seid == null ? -1 : Integer.parseInt(seid);

    Emp emp = empService.getEmpByEid(eid);

    model.addAttribute("emp", emp);

    return "updateEmp.jsp";
}

//@RequestMapping(value = "/updateEmp", method = RequestMethod.POST)
@PostMapping("/updateEmp")
//public String updateEmp(HttpServletRequest request){
public String updateEmp(Emp e){

    //System.out.println(request.getParameter("eid"));
    System.out.println(e);

    boolean flag = empService.updateEmp(e);

    if(flag){
        return "redirect:/emp/emps";
    }

    return "";
}


@GetMapping("/deleteByEid/{eid}")
public String deleteByEid(@PathVariable int eid){
    //System.out.println(eid);

    boolean flag = empService.deleteEmpByEid(eid);

    if(flag){
        return "redirect:/emp/emps";
    }

    return "";
}

}

IEmpService.java

package com.qfedu.service;

import com.qfedu.bean.Emp;

import java.util.List;

public interface IEmpService {

List<Emp> getAllEmps();

Emp getEmpByEid(int eid);
boolean updateEmp(Emp emp);

boolean deleteEmpByEid(int eid);

}

EmpServiceImpl.java

package com.qfedu.service.impl;

import com.qfedu.bean.Emp;
import com.qfedu.dao.impl.EmpDaoImpl;
import com.qfedu.dao.IEmpDao;
import com.qfedu.service.IEmpService;

import java.util.List;

public class EmpServiceImpl implements IEmpService {

private IEmpDao empDao = new EmpDaoImpl();

@Override
public List<Emp> getAllEmps() {
    return empDao.getAllEmps();
}

@Override
public Emp getEmpByEid(int eid) {
    return empDao.getEmpByEid(eid);
}

@Override
public boolean updateEmp(Emp emp) {
    return empDao.updateEmp(emp);
}

@Override
public boolean deleteEmpByEid(int eid) {
    return empDao.deleteEmpByEid(eid);
}

}

IEmpDao.java

package com.qfedu.dao;

import com.qfedu.bean.Emp;

import java.util.List;

public interface IEmpDao {

List<Emp> getAllEmps();

Emp getEmpByEid(int eid);

boolean updateEmp(Emp emp);

boolean deleteEmpByEid(int eid);

}

EmpDaoImpl.java

package com.qfedu.dao.impl;

import com.qfedu.bean.Emp;
import com.qfedu.dao.IEmpDao;

import java.util.ArrayList;
import java.util.List;

public class EmpDaoImpl implements IEmpDao {

private static List<Emp> emps = new ArrayList<>();

static {
    for(int i = 0; i < 20; i++){
        emps.add(new Emp(i + 1, "name " + i, 8000 + i * 100));
    }
}

@Override
public List<Emp> getAllEmps() {
    return emps;
}


@Override
public Emp getEmpByEid(int eid) {
    return emps.get(eid - 1);
}

@Override
public boolean updateEmp(Emp emp) {

    try{
        emps.set(emp.getEid() - 1, emp);
        return true;
    }catch (Exception e){
        e.printStackTrace();
    }

    return false;
}

@Override
public boolean deleteEmpByEid(int eid) {
    try{
        emps.remove(eid -1 );
        return true;
    }catch (Exception e){
        e.printStackTrace();
    }
    return false;
}

}
emp.jsp

<%--
Created by IntelliJ IDEA.
User: james
Date: 2020/3/3
Time: 4:04 PM
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
<title>user</title>
</head>
<body>
<h1>this is users page.</h1>

<c:if test="${list != null}">
    <table border="1" align="center" width="80%">
        <tr>
            <th>eid</th>
            <th>name</th>
            <th>salary</th>
            <th>manage</th>
        </tr>

        <c:forEach items="${list}" var="e">
            <tr>
                <td>&nbsp; ${e.eid}</td>
                <td>&nbsp; ${e.name}</td>
                <td>&nbsp; ${e.salary}</td>
                <td>&nbsp; <a href="/emp/getEmpByEid?eid=${e.eid}">update</a> <a href="/emp/deleteByEid/${e.eid}">delete</a></td>
            </tr>
        </c:forEach>
    </table>
</c:if>

</body>
</html>

updateEmp.jsp

<%--
Created by IntelliJ IDEA.
User: james
Date: 2020/3/3
Time: 4:39 PM
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>update Emp</title>
</head>
<body>
<h1>this is emp update page.</h1>

<form method="post" action="/emp/updateEmp">
    eid:<input type="text" name="eid" value="${emp.eid}" readonly="readonly" /><br />
    name:<input type="text" name="name" value="${emp.name}" /><br />
    salary:<input type="text" name="salary" value="${emp.salary}" /><br />
    <%--salary:<input type="text" name="birth.year" value="${emp.salary}" /><br />--%>
    <input type="submit" value="submit" /><br />
</form>

</body>
</html>

spring-mvc.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">

<!--
    配置SpringMVC的视图解析器
        可以分别指定前缀和后缀
            prefix: /WEB-INF/view/,那么控制器那边会在虚拟视图前拼接该字符串
            suffix:.jsp .html,那么控制器那边会在虚拟视图后面拼接该字符串

            拼接完字符串的效果
                /WEB-INF/view/index.html
                /WEB-INF/view/detail.jsp
    -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix" value="/WEB-INF/view/" />
    <!--<property name="suffix" value=".jsp" />-->
</bean>

<!--配置缺省的servlet处理器,静态资源可以直接被访问-->
<mvc:default-servlet-handler />

<!--
    上下文的组件扫描
-->
<context:component-scan base-package="com.qfedu.controller" />

<!--
    配置注解驱动
-->
<mvc:annotation-driven />

<!--
    bean的id属性值不能包含特殊字符
    name可以,所以路径需要使用name来标识一个控制器的路径
        指定name对应路径交给哪个控制器来进行具体的处理
-->
<bean name="/ProductInput" class="com.qfedu.controller.ProductInputController" />
<bean name="/SaveProductController" class="com.qfedu.controller.SaveProductController" />

</beans>

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,976评论 6 513
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,249评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 167,449评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,433评论 1 296
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,460评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,132评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,721评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,641评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,180评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,267评论 3 339
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,408评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,076评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,767评论 3 332
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,255评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,386评论 1 271
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,764评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,413评论 2 358

推荐阅读更多精彩内容