项目-CMS第一天(搭建项目的环境)

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());
	}
	
}

测试结果如下:

在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值