ICAT技术 阅读:702评论: 5 2018-07-12

简介:springboot是现在非常流行微服务框架。

        现在教大家如何创建一个微服务的框架


eclipse开发springboot项目需要先安装sts插件

安装STS

打开Eclipse,菜单栏点击Help —> Eclipse Marketplce –> 搜索框输入STS,如图:

image.png

第一步  创建项目

右键new project搜索spring并选择Spring Starter Project

image.png

点击next下一步点击Finish。


image.png




等待右下角Maven依赖包下载完成


image.png

项目结构如上


第二步  启动项目的其中2种简单方式

由于SpringBoot有内嵌的Tomcat,可以不需要在Tomcat里面部署,直接启动。


第一种:找到Application启动类,鼠标右键启动Run as =》 选择启动方式:Spring Boot App


image.png


控制台启动并打印日志,发现无法启动,停止,需要在pom.xml添加web依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>


第二种:用cmd知道项目根路径执行命令:mvn spring-boot:run


第三步   调用接口或调整页面

项目启动完成后,进行http://localhost:8080访问

image.png


提示错误页面,那我们接下来写个静态调整页面:

(1)在src下面建立一个webApp提供放前端文件的地方

(2)在此目录下建立一个page文件夹,提供放静态页面的地方,在page下建立html页面。

(3)新建一个IndexController类。(目录结构如下)

image.png

(4)在IndexController的类名上加上@Controller注解标示这是一个控制组件,添加下面方法:

  @RequestMapping为请求映射

  return返回的需要跳转的页面

@RequestMapping(value = "/index")
public String helloworld() {
	return "/page/index.html";
}

(5)访问http://localhost:8080/index跳转到刚刚新建的页面上了,效果如下。

image.png

(6)接下来怎么让他返回对象数据呢?

@ResponseBody
@RequestMapping(value = "/data")
public Map<String, String> data() {
    Map<String, String> map = new HashMap<>();
    map.put("data", "success");
    return map;
}

注解@ResponseBody解释

@responseBody注解的作用是将controller的方法返回的对象通过适当的转换器转换为指定的格式之后,写入到response对象的body区,通常用来返回JSON数据或者是XML数据,需要注意的呢,在使用此注解之后不会再走视图处理器,而是直接将数据写入到输入流中,他的效果等同于通过response对象输出指定格式的数据。

返回的结果就是这样的。

image.png


第四步  使用jpa操作数据库

(1)添加配置

<!-- 添加对jpa的支持,包含spring-data和Hibernate -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

<!-- mysql连接的jar包 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>

<!-- 模板引擎 Thymeleaf 依赖 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>

需要加入jpa支持和mysql连接依赖

在application.properties文件内添加连接池及相关配置

spring.datasource.url=jdbc:mysql://127.0.0.1:3306/test
spring.datasource.username=root
spring.datasource.password=1234
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

#配置页面的前缀
#配置页面的后缀
spring.mvc.view.prefix=/page/
spring.mvc.view.suffix=.html

#配置关闭缓存,实现热部署。也就是修改了html后不用重启,刷新页面就能看到效果。
spring.thymeleaf.cache=false

#启用MVC Thymeleaf视图分辨率
spring.thymeleaf.enabled=true

#validate加载hibernate时,验证创建数据库表结构
#create每次加载hibernate,重新创建数据库表结构,这就是导致数据库表数据丢失的原因。
#create-drop加载hibernate时创建,退出时候删除表结构
#update加载hibernate自动更新数据库结构
spring.jpa.hibernate.ddl-auto=none

spring.jpa.show-sql=true

配置了前缀和后缀后,可以在控制器中直接输入页面的名字也可以跳转

image.png


(2)操作数据库(添加)

创建实体类

@Entity定义为实体类

@Id定义主键

@GeneratedValue自动增长策略

@Column(length=10,nullable=false,name="username")

length字段长度

nullable不许为空

name数据库字段

package com.example.model;

import java.io.Serializable;
import java.sql.Timestamp;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.Table;

@Entity
@Table(name = "sys_user")
public class SysUser implements Serializable {
	private static final long serialVersionUID = 1L;
	@Id
	@GeneratedValue
	private Integer id;
	private String userid;
	private String username;
	private String password;
	private String role;
	private String permission;
	private String status;
	private String description;
	private Timestamp create_date;
	private String salt;

	public String getPermission() {
		return permission;
	}

	public void setPermission(String permission) {
		this.permission = permission;
	}

	public String getSalt() {
		return salt;
	}

	public void setSalt(String salt) {
		this.salt = salt;
	}

	public Integer getId() {
		return id;
	}

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

	public String getUserid() {
		return userid;
	}

	public void setUserid(String userid) {
		this.userid = userid;
	}

	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 getRole() {
		return role;
	}

	public void setRole(String role) {
		this.role = role;
	}

	public String getStatus() {
		return status;
	}

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

	public String getDescription() {
		return description;
	}

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

	public Timestamp getCreate_date() {
		return create_date;
	}

	public void setCreate_date(Timestamp create_date) {
		this.create_date = create_date;
	}
}

如果数据库没有创建表初始化的时候,可以将application.properties配置中的

spring.jpa.hibernate.ddl-auto=create

 none改为create可以自动将实体类的字段创建到数据库表中

启动项目,启动完成后,数据库会自动创建和实体类一样的字段。

image.png

****注意****

数据库字段添加完成后,将其修改为none,不然以后数据库有数据会重启丢失

新增一个添加页面

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>添加</title>
</head>
<body>
<form action="/add" method="post">
	名称:<input type="text" name="username" >
	角色:<input type="text" name="role">
	权限:<input type="text" name="permission">
	<input type="submit" value="提交">
</form>
</body>
</html>


定义接口跳转添加页面

@RequestMapping(value = "/create")
	public String create() {
		return "add";
	}

访问http://localhost:8080/create到添加页面

image.png

接下来写接口SysUserRepository类

image.png


接下来添加写新增接口


@Autowired
private SysUserRepository sysUserRepository;
@ResponseBody
@RequestMapping(value = "add", method = RequestMethod.POST)
	public String add(@RequestParam(value = "username") String username, @RequestParam(value = "role") String role,
			@RequestParam(value = "permission") String permission, RedirectAttributes redirectAttributes) {
		try {
			SysUser sysUser = new SysUser();
			sysUser.setPermission(permission);
			sysUser.setRole(role);
			sysUser.setUsername(username);
			sysUserRepository.save(sysUser);
			return "success";
		} catch (Exception e) {
			return "error";
		}
	}

@Autowired spring自动注入SysUserRepository

@RequestParam是要传入的参数

value和页面name对应


参数接受的另外一种方式

@RequestMapping(value="/addUser4/{username}/{password}",method=RequestMethod.GET)    public String addUser4(@PathVariable String username,@PathVariable String password) {        System.out.println("username is:"+username);        System.out.println("password is:"+password);        

    return "demo/index";    }


image.png

点击提交,返回成功提示

image.png

查看数据库添加成功

image.png


(3)操作数据库(查询操作)

写sql语句查询

image.png

@Query放在定义的接口上

nativeQuery原生sql

value需要执行的sql语句

@ResponseBody
	@RequestMapping(value = "/index")
	public List<SysUser> helloworld(Model model) {
		return sysUserRepository.findAll();
	}

访问接口出现对象数据结果。

image.png

(4)删除

@ResponseBody
	@RequestMapping(value = "delete", method = RequestMethod.GET)
	public String delete(@RequestParam(value = "id") int id) {
		try {
			sysUserRepository.delete(id);
			return "success";
		} catch (Exception e) {
			return "error";
		}

	}

访问地址http://localhost:8080/delete?id=9成功删除

image.png

转载请注明来源:

评论