基于spring boot + MySQL 的简单网页查询 源码详解及服务器部署

声明:源码是在原有代码中截取,没有实际跑,有问题请私信或者评论。
有不明白的也请留言,大家一起学习
(¬‿¬)

α 环境配置

  1. 在eclipse中spring boot(框架)的环境搭建
    spring boot环境搭博客链接

控制台出现spring表示环境搭建完成

表示该spring boot程序正确启动在这里插入图片描述

关于二次启动报错问题,端口被前一程序占用,将程序关闭后再次重启即可
在这里插入图片描述

  1. win10环境Mysql的安装
    Mysql安装教程链接
    注意在Linux服务器上改用MySQL的分支MariaDB
  1. 需要的jar
    jdbc --链接数据库
    选择平台不依赖的驱动 - - - jdbc下载地址

json --数据传输
从maven下载的教程

β 代码详解

  1. 项目结构

项目结构
com.test包下
Data_fData 为对象的类封装 , Database 为具体的逻辑实现 , SpringTestApplication 为程序入口

index.html是前端页面

pom.xmlapplication.properties 都是spring boot的配置文件

  1. 执行流程

前端获取用户输入信息 , 将其传向后端 , 后台接收信息后进行处理 , 生成相应的SQL语句 , 在数据库进行查询并返回所查信息 , 对信息进行封装 , 将数据提交给前端 , 由前端进行数据展示.

  1. 核心部分代码解释
  • 前端获取用户输入
<input type="text" id="01">				//用户通过文本框输入
<input type="button" value="search" onclick="a()">	//点击事件 ,调用js函数
  • 前端发送请求及接收返回数据
    在html文件中使用js需使用 <script type=“text/javascript”></script> 标签
    使用ajax需使用 <script src=“https://code.jquery.com/jquery-3.1.1.min.js”></script> 标签
function a()
{
 var words = document.getElementById("01").value    //通过id得到文本框的值,转为js变量
 alert(words);					    //验证js变量是否正确
 $.ajax({
  url:"/precise",				    //ajax发起请求的地址
  data:{"msg":words},				    //发送的请求信息,msg为信息名,可随意
  type:"POST",					    //请求方式
  dataType:"json",		      		    //传输数据格式(返回的)
  contentType:"application/json",		    //传输数据格式(发送的)
  success:function(da)				    //接收数据的函数(默认),da为接收的变量
  {
   var json = JSON.parse(da);
   document.write(json[0].id+"  "+json[0].author);
  }
 })
}
  • 后端依赖及配置
    pom.xml中需添加的依赖
<dependencies>
 
 <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-jdbc</artifactId>
  </dependency>
                
   <dependency>
       <groupId>mysql</groupId>
       <artifactId>mysql-connector-java</artifactId>
   </dependency>
   
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
   </dependency>
    
  <dependency>
  	 <groupId>org.springframework.boot</groupId>
  	 <artifactId>spring-boot-starter-web</artifactId>
  </dependency>
    
  <dependency>
   	<groupId>org.springframework.boot</groupId>
  	 <artifactId>spring-boot-starter-web-services</artifactId>
  </dependency>
  
  <dependency>
 	  <groupId>org.springframework.boot</groupId>
  	 <artifactId>spring-boot-starter-test</artifactId>
  	 <scope>test</scope>
  </dependency>
  
 </dependencies>

application.properties中对于数据库和前端文件的配置

spring.mvc.view.prefix=/
spring.mvc.view.suffix=.html		//告诉spring前端是 任意开头 .html结尾的文件
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost/要用的库名?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone==UTC
	//此为新版jdbc驱动程序,即mysql-connector-java-6及以上版本
spring.datasource.username=数据库的用户名
spring.datasource.password=用户密码
spring.jpa.show-sql=true
  • 数据库操作
  private String JDBC_DRIVE = "com.mysql.cj.jdbc.Driver";
  private String DB_URL = "jdbc:mysql://localhost/要用的库名?useSSL=false&serverTimezone=UTC";
  private String user = "数据库的用户名";
  private String pw = "用户密码";

  //进行连接,并返回连接实例
  public void getStatement() throws ClassNotFoundException, SQLException
  {
	   Class.forName(JDBC_DRIVE);
	   conn = DriverManager.getConnection(DB_URL, user, pw);
	   stmt = conn.createStatement();
  }
  
  //获取查询的对象列表
  public List<Data_f> getList_f() throws SQLException, ClassNotFoundException
  {
	   String sql = this.sql2;
	   List<Data_f> list = new ArrayList<Data_f>();
	   ResultSet resultSet = stmt.executeQuery(sql);
	
	   while(resultSet.next())
	   {
		    Data_f data_f =new Data_f();
		    String rec = resultSet.getString("msg");
		    data_f.setMsg(rec);
		    list.add(data_f);
	    }
  	    return list;
  }
  • 前后端数据交互
  @RequestMapping("precise")				//路由,即前端提交的地址
public String getMsg(@RequestBody String msg0)		//接收前端提交的数据
{ 
 this.msg = msg0;
 System.out.println(msg);
 return msg0;						//后台返回的数据
}

  • 数据处理
    根据实际进行个性化处理

γ 源码

  1. Data.java
package com.test;

public class Data_f {
 private String msg;
 public void setMsg(String msg0) {this.msg = msg0;}
 public String getMsg() {return msg;}
}
  1. Database.java
package com.test;

import com.test.*;
import java.math.BigDecimal;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;

import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class Database {
private String JDBC_DRIVE = "com.mysql.cj.jdbc.Driver";
private String DB_URL = "jdbc:mysql://localhost:3306/要用的库名?useSSL=false&serverTimezone=UTC";
private String user = "数据库的用户名";
private String pw = "用户密码";
private String msg;
private String sql0;

private Connection conn = null;
public Statement stmt = null;

//返回模糊查询信息
@RequestMapping("fuzzy")
public List<Data_f> getMsg0(@RequestBody String msg0) throws ClassNotFoundException, SQLException
{ 
     this.msg = msg0;
     System.out.println(msg0);
     getStatement();
     getSql_f();
     List<Data_f> list = new ArrayList<Data_f>();
     list = getList_f();
     return list;
    }

//进行连接,并返回连接
public void getStatement() throws ClassNotFoundException, SQLException
{
Class.forName(JDBC_DRIVE);
conn = DriverManager.getConnection(DB_URL, user, pw);
stmt = conn.createStatement();
}

//确定模糊查询语句
public void getSql_f() throws SQLException
{
String msg = this.msg;
   
String regex = "(.{1})";
     msg = msg.replaceAll (regex, "$1%");
     msg = '%'+msg;

   sql0 = "select * from books0 where msg like "+"'"+msg+"'";
   System.out.println("查询语句"+sql0);
}

//获取模糊查询的对象列表
public List<Data_f> getList_f() throws SQLException, ClassNotFoundException
{
String sql = this.sql0;
List<Data_f> list = new ArrayList<Data_f>();
ResultSet resultSet = stmt.executeQuery(sql);

while(resultSet.next())
{
 Data_f data_f =new Data_f();
 String rec = resultSet.getString("msg");
 data_f.setMsg(rec);
 list.add(data_f);
}
return list;
}
  1. SpringTestApplication.java
package com.test;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class SpringTestApplication {

	public static void main(String[] args) {
	  SpringApplication.run(SpringTestApplication.class, args);
	  }
}

  1. index.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>

<script src="https://code.jquery.com/jquery-3.1.1.min.js"></script>
<script type="text/javascript">

function b()
{
 var words = document.getElementById("02").value
 alert(words);
 //var json=json.stringify({"msg":"asdfsdfs"});
 $.ajax({
  //url:"/data/getjson",
  url:"/fuzzy",
  data:{"msg":words},
  type:"POST",
  dataType:"text",
  contentType:"application/json",
  success:function(daa)
  {
	  var json = JSON.parse(daa);
	   document.write(json[0].msg);
  }
 })
}
</script>
</head>

<body>
<input type="text" id="02">
<input type="button" value="search_f" onclick="b()">
</body>
</html>
  1. application.properties
spring.mvc.view.prefix=/
spring.mvc.view.suffix=.html  //告诉spring前端是 任意开头 .html结尾的文件
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost/要用的库名?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone==UTC
 //此为新版jdbc驱动程序,即mysql-connector-java-6及以上版本
spring.datasource.username=数据库的用户名
spring.datasource.password=用户密码
spring.jpa.show-sql=true
  1. pom.xml须修改处
<dependencies>
 
 <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-jdbc</artifactId>
  </dependency>
                
   <dependency>
       <groupId>mysql</groupId>
       <artifactId>mysql-connector-java</artifactId>
   </dependency>
   
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
   </dependency>
    
  <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
  </dependency>
    
  <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web-services</artifactId>
  </dependency>
  
  <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-test</artifactId>
    <scope>test</scope>
  </dependency>
  
 </dependencies>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,以下是基于 Spring Cloud+Spring Boot+Nacos+Dubbo+mybatis plus+RocketMQ+Sentinel+Seata+mysql 搭建一个项目的步骤: 1. 首先,你需要安装并启动 Nacos 作为服务注册中心和配置中心。可以去官网下载最新版本的 Nacos,然后解压并启动即可。 2. 接下来,使用 Spring Initializr 创建一个基于 Spring Boot 的项目,并添加以下依赖: ``` <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-dubbo</artifactId> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-logging</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-alibaba-seata</artifactId> </dependency> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-sentinel</artifactId> </dependency> <dependency> <groupId>org.apache.rocketmq</groupId> <artifactId>rocketmq-spring-boot-starter</artifactId> </dependency> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> ``` 3. 配置 Nacos 作为服务注册中心和配置中心: ``` spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848 spring.cloud.nacos.config.server-addr=127.0.0.1:8848 spring.cloud.nacos.config.prefix=/config spring.cloud.nacos.config.file-extension=properties ``` 4. 配置 Dubbo: ``` spring.application.name=provider-service spring.dubbo.application.name=provider-service spring.dubbo.registry.address=nacos://127.0.0.1:8848 spring.dubbo.protocol.name=dubbo spring.dubbo.protocol.port=20880 ``` 5. 配置 RocketMQ: ``` spring.rocketmq.name-server=127.0.0.1:9876 spring.rocketmq.producer.group=producer-group spring.rocketmq.consumer.group=consumer-group ``` 6. 配置 Sentinel: ``` spring.cloud.sentinel.transport.dashboard=127.0.0.1:8080 ``` 7. 配置 Seata: ``` spring.cloud.alibaba.seata.tx-service-group=my_seata_tx_group spring.cloud.alibaba.seata.tx-service-mode=AT spring.cloud.alibaba.seata.config.type=nacos spring.cloud.alibaba.seata.config.nacos.server-addr=127.0.0.1:8848 spring.cloud.alibaba.seata.config.nacos.namespace=seata-dev ``` 8. 配置 MySQL 数据源: ``` spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&useSSL=false spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.jdbc.Driver ``` 9. 编写 Dubbo 服务接口和实现类: ``` public interface UserService { User getUserById(Long id); } @Service public class UserServiceImpl implements UserService { @Autowired private UserDao userDao; @Override public User getUserById(Long id) { return userDao.selectById(id); } } ``` 10. 配置 Dubbo 服务提供者: ``` @Configuration public class DubboConfig { @Reference private UserService userService; @Bean public ApplicationRunner runner() { return args -> { User user = userService.getUserById(1L); System.out.println(user); }; } } ``` 11. 编写 RocketMQ 生产者和消费者: ``` @Component public class MessageProducer { @Autowired private RocketMQTemplate rocketMQTemplate; public void send(String message) { rocketMQTemplate.convertAndSend("test-topic", message); } } @Component @RocketMQMessageListener(topic = "test-topic", consumerGroup = "test-consumer-group") public class MessageConsumer implements RocketMQListener<String> { @Override public void onMessage(String message) { System.out.println("Received message: " + message); } } ``` 12. 编写 MySQL 数据访问层: ``` @Mapper public interface UserDao extends BaseMapper<User> { } ``` 13. 使用 Seata 进行分布式事务控制: ``` @Service public class OrderServiceImpl implements OrderService { @Autowired private OrderDao orderDao; @GlobalTransactional @Override public void createOrder(Order order) { orderDao.insert(order); // 调用其他服务,可能会涉及到分布式事务操作 // ... } } ``` 14. 使用 Sentinel 进行服务限流和熔断: ``` @GetMapping("/hello") @SentinelResource(value = "hello", blockHandler = "helloBlockHandler") public String hello() { return "Hello World!"; } public String helloBlockHandler(BlockException ex) { return "Blocked by Sentinel: " + ex.getClass().getSimpleName(); } ``` 15. 最后,启动项目并测试各个功能是否正常运行。 以上就是基于 Spring Cloud+Spring Boot+Nacos+Dubbo+mybatis plus+RocketMQ+Sentinel+Seata+mysql 搭建一个项目的步骤。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值