CMS项目环境的搭建
CMS:看点资讯项目
项目搭建:在springboot中进行项目搭建(maven项目)
采用单体架构前后端分离版,使用插件Swagger插件
前端:jsp
后端: java rpc rest json
技术选型:spring boot,springmvc,mybatis-generator 根据数据库表自动的生成映射文件,映射接口,pojo类,让开发人员不再去关心dao层开发,mysql,腾讯云
框架:三层框架结构
Dao(数据持久化层,进行增删改查)
Service(业务层,处理业务逻辑)
Web(controller层)
maven结构
在数据库中创建表:
首先,构建maven项目:导入相应的配置文件
配置 pom.xml文件
在resources文件下导入Config.xml配置文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<!-- mybatis-generator的核心配置文件 -->
<generatorConfiguration>
<classPathEntry location="E:/repository/mysql/mysql-connector- java/5.1.47/mysql-connector-java-5.1.47.jar" />
<context id="DB2Tables" targetRuntime="MyBatis3">
<plugin type="org.mybatis.generator.plugins.SerializablePlugin"></plugin>
<plugin type="org.mybatis.generator.plugins.ToStringPlugin"></plugin>
<commentGenerator>
<property name="suppressDate" value="true"/>
<property name="suppressAllComments" value="true"/>
</commentGenerator>
<!-- 注意!如果要重新生成pojo类,务必改成项目组数据库,用户名密码 -->
<jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://127.0.0.1:3306/cms"
userId="root"
password="root">
</jdbcConnection>
<!--指定生成的类型为java类型,避免数据库中number等类型字段 -->
<javaTypeResolver >
<property name="forceBigDecimals" value="false" />
</javaTypeResolver>
<!--自动生成的实体的存放包路径 -->
<javaModelGenerator targetPackage="com.briup.cms.bean" targetProject="./src/main/java">
<property name="enableSubPackages" value="true" />
<property name="trimStrings" value="true" />
</javaModelGenerator>
<!--自动生成的*Mapper.xml文件存放路径 -->
<sqlMapGenerator targetPackage="mapper" targetProject="./src/main/resources">
<property name="enableSubPackages" value="true" />
</sqlMapGenerator>
<!--自动生成的*Mapper.java存放路径 -->
<javaClientGenerator type="XMLMAPPER" targetPackage="com.briup.cms.mapper" targetProject="./src/main/java">
<property name="enableSubPackages" value="true" />
</javaClientGenerator>
<!-- 映射配置 -->
<table tableName="cms_link" domainObjectName="Link"></table>
<table tableName="cms_customer" domainObjectName="Customer"></table>
<table tableName="cms_category" domainObjectName="Category"></table>
<table tableName="cms_article" domainObjectName="Article">
<columnOverride column="content" javaType="java.lang.String" jdbcType="VARCHAR"></columnOverride>
</table>
采用逆向生成的方式生成bean包下的pojo类,mapper对象
导入插件Swagger,用于进行前端后端数据的交互。
访问网页:http://localhost:8081/swagger-ui.html
测试spring boot与swagger整合是否成功。
列举链接的增删改查
编写程序LinkService接口,与LinkServiceImpl与webcontroller层的Controller类;
LinkService接口类;
package com.briup.cms.service;
import java.util.List;
import com.briup.cms.bean.Link;
import com.briup.cms.util.LinkException;
/**
* 链接接口
* @author
*
*/
public interface LinkService {
/**
* 保存或更新链接
*/
void saveOrUpdateLink(Link link)throws LinkException;
//根据id删除用户
void removeLinkById(int id)throws LinkException;
//根据ID查找用户
Link findLinkById(int id)throws LinkException;
//查找所有用户
List<Link> getAllLink()throws LinkException;
}
LinkServiceImpl类,实现了LinkService接口
package com.briup.cms.service.Impl;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import com.briup.cms.bean.Link;
import com.briup.cms.bean.LinkExample;
import com.briup.cms.conf.StatusCodeUtil;
import com.briup.cms.mapper.LinkMapper;
import com.briup.cms.service.LinkService;
import com.briup.cms.util.LinkException;
/**
* 链接的实现类
* @author
*
*/
@Service
@Transactional
public class LinkServiceImpl implements LinkService{
@Autowired
private LinkMapper linkMapper;
@Override
public void saveOrUpdateLink(Link link) throws LinkException{
if(link==null) {
//向上抛异常
throw new LinkException(StatusCodeUtil.EXCEPTION_CODE, "参数为空");
}
if(link.getId()==null) {
//当id为空,执行插入操作
linkMapper.insert(link);
}else {
//当id不为空,执行更新操作
linkMapper.updateByPrimaryKey(link);
}
}
@Override
public void removeLinkById(int id) throws LinkException {
linkMapper.deleteByPrimaryKey(id);
}
@Override
public Link findLinkById(int id) throws LinkException {
Link link = linkMapper.selectByPrimaryKey(id);
return link;
}
@Override
public List<Link> getAllLink() throws LinkException {
LinkExample example = new LinkExample();
List<Link> list = linkMapper.selectByExample(example);
return list;
}
}
controller类:
public class LinkController {
@Autowired
private LinkService linkServcie;
@PostMapping("/addLink")
@ApiOperation("新增链接")
public Message<String> addLink(Link link){
try {
linkServcie.saveOrUpdateLink(link);
return MessageUtil.success();
}catch(LinkException e){
return MessageUtil.
error(StatusCodeUtil.EXCEPTION_CODE, "系统错误:"+e.getMessage());
}
}
@GetMapping("/deleteLink")
@ApiOperation("删除链接")
public Message<String> deleteLink(int id){
linkServcie.removeLinkById(id);
return MessageUtil.success();
}
@GetMapping("/findLinkById")
@ApiOperation("查找链接")
public Link findLinkById(int id){
Link link = linkServcie.findLinkById(id);
return link;
}
@GetMapping("/findAllLink")
@ApiOperation("查找所有链接")
public List<Link> findAllLink(){
List<Link> list = linkServcie.getAllLink();
for(Link l:list) {
System.out.println(l);
}
return list;
}
@PostMapping("/updateLink")
@ApiOperation("更新链接")
public Message<String> updateLink(Link link){
try {
linkServcie.saveOrUpdateLink(link);
return MessageUtil.success();
}catch(LinkException e){
return MessageUtil.
error(StatusCodeUtil.EXCEPTION_CODE, "系统错误:"+e.getMessage());
}
}
测试结果如下: