redis + ajax实现异步下拉列表加载(2)

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!
JdbcTemplate对象创建时需要传入一个datasource,这里封装工具类JDBCUtils,使用druid数据库连接池技术,提供get方法来获取datasource

package util;

import com.alibaba.druid.pool.DruidDataSourceFactory;

import javax.sql.DataSource;

import java.io.IOException;

import java.io.InputStream;

import java.sql.Connection;

import java.sql.SQLException;

import java.util.Properties;

/**

  • JDBC工具类 使用Durid连接池

*/

public class JDBCUtils {

private static DataSource ds ;

static {

System.out.println(“JDBCUtils”);

try {

//1.加载配置文件

Properties pro = new Properties();

//使用ClassLoader加载配置文件,获取字节输入流

InputStream is = JDBCUtils.class.getClassLoader().getResourceAsStream(“druid.properties”);

pro.load(is);

//2.初始化连接池对象

ds = DruidDataSourceFactory.createDataSource(pro);

} catch (IOException e) {

e.printStackTrace();

} catch (Exception e) {

e.printStackTrace();

}

}

/**

  • 获取连接池对象

*/

public static DataSource getDataSource(){

return ds;

}

/**

  • 获取连接Connection对象

*/

public static Connection getConnection() throws SQLException {

return ds.getConnection();

}

}

service层:

只用直接调用dao层的查询数据库方法即可

package service;

import domain.Province;

import java.util.List;

public interface ProvinceService {

public List findAll();

}

package service.impl;

import dao.ProvinceDao;

import dao.impl.ProvinceDaoImpl;

import domain.Province;

import service.ProvinceService;

import java.util.List;

public class ProvinceServiceImpl implements ProvinceService{

private ProvinceDao dao = new ProvinceDaoImpl();

@Override

public List findAll() {

return dao.findAll();

}

}

servlet:

根据第一部分【分析】中描述的servlet的三个步骤,代码编写如下:

其中reponse中设置内容格式为json

package web.servlet;

import com.fasterxml.jackson.databind.ObjectMapper;

import domain.Province;

import service.ProvinceService;

import service.impl.ProvinceServiceImpl;

import javax.servlet.ServletException;

import javax.servlet.annotation.WebServlet;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import java.io.IOException;

import java.util.List;

@WebServlet(“/provinceServlet”)

public class ProvinceServlet extends HttpServlet {

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

ProvinceService service = new ProvinceServiceImpl();

List list = service.findAll();

// 序列化list为json

ObjectMapper mapper = new ObjectMapper();

String json = mapper.writeValueAsString(list);

// 响应结果

response.setContentType(“application/json;charset=utf-8”);

response.getWriter().write(json);

}

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

this.doPost(request, response);

}

}

页面:

html部分实现一个简单的下拉列表即可,js部分发送ajax请求来加载所有省份的数据,循环遍历服务器返回的数据,将每一条记录包装成一个option标签append如下拉列表中

Title --请选择省份--

4 使用redis


JedisPool连接池工具类用于加载配置文件并提供get方法获取resource

package jedis.util;

import redis.clients.jedis.Jedis;

import redis.clients.jedis.JedisPool;

import redis.clients.jedis.JedisPoolConfig;

import java.io.IOException;

import java.io.InputStream;

import java.util.Properties;

/**

  • JedisPool连接池工具类

  •  加载配置文件
    
  •  提供获取连接的方法
    

*/

public class JedisPoolUtils {

private static JedisPool jedisPool;

static {

InputStream is = JedisPoolUtils.class.getClassLoader().getResourceAsStream(“jedis.properties”);

Properties pro = new Properties();

try {

pro.load(is);

} catch (IOException e) {

e.printStackTrace();

}

// 获取数据,设置到JedisPoolConfig中

JedisPoolConfig config = new JedisPoolConfig();

config.setMaxTotal(Integer.parseInt(pro.getProperty(“maxTotal”)));

config.setMaxIdle(Integer.parseInt(pro.getProperty(“maxIdle”)));

// 初始化JedisPool

jedisPool = new JedisPool(config, pro.getProperty(“host”), Integer.parseInt(pro.getProperty(“port”)));

}

/**

  • 获取连接的方法

*/

public static Jedis getJedis(){

return jedisPool.getResource();

}

}

至此在service层的ProvinceServiceImpl.java 中新创建添加使用redis的方法:

在redis中直接存储数据的json格式

/**

  • 使用redis缓存

*/

@Override

public String findAllJson() {

// 先从redis中查询数据

Jedis jedis = JedisPoolUtils.getJedis();

String province_json = jedis.get(“province”);

// 判断redis里是否有记录,没有则查询数据库

if (province_json == null || province_json.length() == 0){

System.out.println(“redis中没数据,查询数据库”);

List ps = dao.findAll();

ObjectMapper mapper = new ObjectMapper();

try {

province_json = mapper.writeValueAsString(ps);

} catch (JsonProcessingException e) {

e.printStackTrace();

}

// 存json到redis

jedis.set(“province”,province_json);

jedis.close();

}else {

System.out.println(“redis中有数据,查询缓存”);

}

return province_json;

}

修改servlet直接调用新添加的方法:

最后

金三银四马上就到了,希望大家能好好学习一下这些技术点

学习视频:

大厂面试真题:

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!
eAsString(ps);

} catch (JsonProcessingException e) {

e.printStackTrace();

}

// 存json到redis

jedis.set(“province”,province_json);

jedis.close();

}else {

System.out.println(“redis中有数据,查询缓存”);

}

return province_json;

}

修改servlet直接调用新添加的方法:

最后

金三银四马上就到了,希望大家能好好学习一下这些技术点

学习视频:

[外链图片转存中…(img-Cmaxd6AJ-1714647731564)]

大厂面试真题:

[外链图片转存中…(img-tskTFtDp-1714647731564)]

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门,即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值