spring与jndi(数据库连接)SpringBoot打war包并整合jsp,这里的jndi指的是jdbc连接,不是其他的。有传统servlet+spring和springboot的jndi连接操作,并整合jsp和thymeleaf。下面我以他们两个为例子演示。

一、servlet+spring下的jndi

一个普通servlet项目整合spring 5.14后,在运行的tomcat/conf/context.xml的Context标签里配置jndi:

	<Resource name="localhostJndiName"
validationQuery="select 1"
auth="Container"
type="javax.sql.DataSource"
driverClassName="com.mysql.jdbc.Driver"
url=" jdbc:mysql://localhost:3306/test?useSSL=false&amp;useUnicode=true&amp;characterEncoding=utf8&amp;serverTimezone=GMT"
username="root"
password="123456" maxActive="60" maxIdle="1"/>

注入xml中配置jndi的bean

    <bean id="jndiObjectFactoryBean" class="org.springframework.jndi.JndiObjectFactoryBean">
<property name="jndiName">
<!-- Weblogic数据源配置格式
<value>jndi_name</value> -->
<!-- Tomcat数据源配置格式 -->
<value>java:comp/env/localhostJndiName</value>
</property>
</bean>

获取DataSource进行数据操作

@Configuration
@Controller
public class WebController {
@Autowired
private JndiObjectFactoryBean jndiObjectFactoryBean; @Bean
public DataSource dataSource() {
return (DataSource) jndiObjectFactoryBean.getObject();
} @GetMapping(value = {"/index", ""})
public String index() {
try {
Connection connection = dataSource().getConnection();
PreparedStatement preparedStatement = connection.prepareStatement("select * from opr_cluster limit 1");
ResultSet resultSet = preparedStatement.executeQuery();
while (resultSet.next()) {
System.out.println(
resultSet.getString(1) + " " +
// resultSet.getString(2) + " " +
resultSet.getString(3) + " " +
resultSet.getString(4) + " " +
resultSet.getString(5) + " " +
resultSet.getString(6)
);
}
} catch (SQLException throwables) {
throwables.printStackTrace();
}
return "index";
}
}

效果:

可进一步对DataSource注入mybatis、hibernate等框架进行SQL操作!

二、在springboot中进行jndi操作

是不是有点奇怪?不奇怪,我就遇到甲方要求springboot打包war进行部署,数据源要求使用jndi。爸爸最大,我们得搞出来呢。
首先创建一个普通的springboot项目,重写springboot servlet的初始化SpringBootServletInitializer

@SpringBootApplication
public class DemoApplication extends SpringBootServletInitializer {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
} @Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
return builder.sources(DemoApplication.class);
}
}

修改pom.xml,主要是把打包改为war,插件设置无xml,引入数据库。

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>top.lingkang</groupId>
<artifactId>demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>demo</name>
<description>Demo project for Spring Boot</description>
<packaging>war</packaging> <properties>
<java.version>1.8</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<spring-boot.version>2.3.7.RELEASE</spring-boot.version>
</properties> <dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
</dependencies> <dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring-boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement> <build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>2.3.7.RELEASE</version>
<configuration>
<mainClass>top.lingkang.demo.DemoApplication</mainClass>
</configuration>
<executions>
<execution>
<id>repackage</id>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<configuration>
<warName>springboot-jndi</warName>
<!-- 不外部打包 web.xml -->
<failOnMissingWebXml>false</failOnMissingWebXml>
</configuration>
</plugin>
</plugins>
</build>
</project>

编写一个controller

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.jndi.JndiObjectFactoryBean;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController; import javax.sql.DataSource;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet; /**
* @author lingkang
* Created by 2021/12/20
*/
@Configuration
@RestController
public class WebController {
@Bean
public JndiObjectFactoryBean jndiObjectFactoryBean() {
JndiObjectFactoryBean bean = new JndiObjectFactoryBean();
// tomcat一定要配置这个数据源
bean.setJndiName("java:comp/env/localhostJndiName");
return bean;
} @Autowired
private JndiObjectFactoryBean jndiObjectFactoryBean; @Bean
public DataSource dataSource() {
return (DataSource) jndiObjectFactoryBean.getObject();
} @Autowired
private DataSource dataSource; @GetMapping()
public Object index() {
try {
Connection connection = dataSource.getConnection();
PreparedStatement preparedStatement = connection.prepareStatement("select * from opr_cluster limit 1");
ResultSet resultSet = preparedStatement.executeQuery();
String result = "empty";
while (resultSet.next()) {
result = String.format("%s--%s--%s--%s",
resultSet.getString(1),
resultSet.getString(3),
resultSet.getString(4),
resultSet.getString(5)
);
System.out.println(result);
}
return result;
} catch (Exception e) {
e.printStackTrace();
return e.getMessage();
}
}
}

然后选择配置了jndi数据源的tomcat来运行它,数据库配置参考第一节的配置内容。



效果:

mvn package能够正常打war包,并且丢war能正常运行。

2.1 添加jsp测试

我们添加jsp测试会如何:
先添加jsp需要的依赖

<!--用于jsp页面 jstl表达式-->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<!--用于编译jsp-->
<dependency>
<groupId>org.apache.tomcat.embed</groupId>
<artifactId>tomcat-embed-jasper</artifactId>
</dependency>

application.properties

spring.mvc.view.prefix=/WEB-INF/
spring.mvc.view.suffix=.jsp

改造控制类

	// 将类注解改为@Controller
@Configuration
@Controller
public class WebController {
// ...
@Autowired
private HttpServletRequest request; @GetMapping()
public Object index() {
String result = "empty";
try {
Connection connection = dataSource.getConnection();
PreparedStatement preparedStatement = connection.prepareStatement("select * from opr_cluster limit 1");
ResultSet resultSet = preparedStatement.executeQuery();
while (resultSet.next()) {
result = String.format("%s--%s--%s--%s",
resultSet.getString(1),
resultSet.getString(3),
resultSet.getString(4),
resultSet.getString(5)
);
System.out.println(result);
}
} catch (Exception e) {
e.printStackTrace();
}
request.setAttribute("result",result);
return "index";
}

webapps/WEB-INF/index.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>lingkang</title>
</head>
<body>
查询结果:<br>
<%
out.println(request.getAttribute("result"));
%>
</body>
</html>

设置一下jsp解析路径,否则找不到解析的template

运行它,效果如下:

2.2 使用thymeleaf

基于2.1,将依赖改为

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

application.properties

# 应用名称
spring.application.name=demo
# 应用服务 WEB 访问端口
server.port=8080 spring.thymeleaf.prefix=classpath:/templates/

添加resources/templates/index.html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
查询结果:[[${result}]]
</body>
</html>


tomcat运行项目查看

至此,spring常见整合完毕,特别是整合jsp,jsp挺经典的emm,可以在jsp里写java代码666,觉得不错就点个赞吧!

spring与jndi(数据库连接)SpringBoot打war包并整合jsp的更多相关文章

  1. Springboot解决war包放到Tomcat服务器上404的特殊情况

    Springboot解决war包放到Tomcat服务器上404的特殊情况 原文链接:https://www.cnblogs.com/blog5277/p/9330577.html 原文作者:博客园-- ...

  2. springboot打war包后部署到tomcat后访问返回404错误

    springboot打war包后部署到tomcat后访问返回404错误 1.正常情况下,修改打包方式为war <packaging>war</packaging> 2.启动类继 ...

  3. SpringBoot读取war包jar包Resource资源文件解决办法

    SpringBoot读取war包jar包Resource资源文件解决办法 场景描述 在开发过程中我们经常会碰到要在代码中获取资源文件的情况,而我在最近在SpringBoot项目中时碰到一个问题,就是在 ...

  4. springBoot 项目war包部署及改为war包后资源路径错误问题

    参考资料: https://blog.csdn.net/rico_zhou/article/details/83415114 https://blog.csdn.net/pz641/article/d ...

  5. springboot 的war包在Tomcat中启动失败

    springboot 默认是通常是打包成jar的,里面会内置一个tomcat容器 有时候我们需要使用以前打成war包的方式部署到对应的tomcat中, 具体springboot 怎么从jar改成war ...

  6. IntelliJ idea SpringBoot打war包

    简单易用的使用idea 将SpringBoot工程打war包的方法 pom.xml中添加标签 1. 声明打包格式 <packaging>war</packaging> 2.  ...

  7. SpringBoot以WAR包部署遇到的坑---集合贴

    ⒈忽略tomcat的context-path 方式一: 停止tomcat服务,删除tomcat安装目录的webapps目录下的ROOT目录,将打成的WAR包重命名为ROOT.war,重启tomcat服 ...

  8. springboot打war包部署tomcat服务器,以及表单提交数据乱码处理

    小白觉得springboot打成jar包直接使用内嵌的tomcat或jetty容器(java -jar xxx.jar)运行项目不利于定位问题,我还是习惯于查看tomcat或nginx的日志来定位问题 ...

  9. springboot项目war包部署及出现的问题Failed to bind properties under 'mybatis.configuration.mapped-statements[0].

    1.修改pom文件 修改打包方式 为war: 添加tomcat使用范围,provided的意思即在发布的时候有外部提供,内置的tomcat就不会打包进去 <groupId>com.scho ...

  10. SpringBoot项目war包部署

    服务部署 记录原因 将本地SpringBoot项目通过war包部署到虚拟机中,验证服务器部署. 使用war包是为了方便替换配置文件等. 工具 对象 版本 Spring Boot 2.4.0 VMwar ...

随机推荐

  1. Update 1.82.1: The update addresses this security issue.

    August 2023 (version 1.82) 更新后显示发行说明 Update 1.82.1: The update addresses this security issue. Welcom ...

  2. SpringBoot整合XXLJob

    目录 XXLJob简介 特性 模块 安装调度中心 初始化数据库 配置 启动 整合执行器 pom yml XxlJobConfig 启动执行器 实践 简单的定时任务 在执行器创建任务 在调度中心创建执行 ...

  3. 【Dotnet 工具箱】基于 .NET 6 和 Angular 构建项目任务管理平台

    1.Reha 时间管理大师 Rhea 是一个基于 C# 和 .NET 6 开发的在线任务管理平台,类似于 禅道.Jira.Redmine, 滴答清单等. 支持多视图多维度统一管理任务.多级结构,工作区 ...

  4. 04-华为HyperReplication中的多时间片技术

    简介 多时间片技术,是应用于HyperReplication的异步远程复制:提高效率, 在同步远程复制中,没有这个概念: 时间片:在Cache中管理一段时间内写入数据的逻辑空间(数据大小没有限定): ...

  5. 轻巧的批量图片压缩工具imgfast

    现在的手机拍照动辄2M3M,还有7M8m的,如果要把这些文件上传到网上应用,浪费网络,占用资源 所以2022年中秋写了这个小工具,可以批量进行图片文件压缩,支持jpg和png. 文件下载链接https ...

  6. Java内部类与匿名类

    内部类 定义: 一个类的内部又完整的嵌套了另一个类结构,被嵌套的类就被我们称为内部类,嵌套内部类的类被我们称为外部类 //外部类 class Outer { //内部类 class Inner { } ...

  7. svn的常规使用

    svn的常规使用 svn的常规使用 1 客户端 2 svn server 3 qt使用svn 4 svn项目迁移 Ubuntu上使用svn 1 安装 2 使用 svn的常规使用 1 客户端 下载地址: ...

  8. DHorse(K8S的CICD平台)的实现原理

    综述 首先,本篇文章所介绍的内容,已经有完整的实现,可以参考这里. 在微服务.DevOps和云平台流行的当下,使用一个高效的持续集成工具也是一个非常重要的事情.虽然市面上目前已经存在了比较成熟的自动化 ...

  9. easyxor

    怎么都写不出脚本,看了题解还是蒙蒙的,不过以后遇到这种题也可以根据提示了解他到底怎么出题的,题目明面说了xor 那就主要关注xor以后的结果和xor的对象.方法就好了,其他的就不要去管了 然后对于汇编 ...

  10. GitHub Universe 2023:AI 技术引领软件开发创新浪潮

    GitHub 是全球领先的软件开发和协作平台,数百万开发者和企业在此分享.学习和创建卓越的软件.同时 GitHub 处在 AI 技术前沿,通过其先进的 AI 技术增强开发者体验并赋能未来软件开发的使命 ...