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

本文详细解析了一线大厂Java面试中的常见问题,涉及JDBC模板、Druid数据库连接池、SpringJDBC、Redis缓存以及实战项目的源码。作者分享了学习笔记和面试准备策略,强调Java知识体系复习的重要性。
摘要由CSDN通过智能技术生成

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

package dao.impl;

import dao.ProvinceDao;

import domain.Province;

import org.springframework.jdbc.core.BeanPropertyRowMapper;

import org.springframework.jdbc.core.JdbcTemplate;

import util.JDBCUtils;

import java.util.List;

public class ProvinceDaoImpl implements ProvinceDao{

private JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());

@Override

public List findAll() {

String sql = “select * from province”;

List list = template.query(sql, new BeanPropertyRowMapper<>(Province.class));

return list;

}

}

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”);

总结

就写到这了,也算是给这段时间的面试做一个总结,查漏补缺,祝自己好运吧,也希望正在求职或者打算跳槽的 程序员看到这个文章能有一点点帮助或收获,我就心满意足了。多思考,多问为什么。希望小伙伴们早点收到满意的offer! 越努力越幸运!

金九银十已经过了,就目前国内的面试模式来讲,在面试前积极的准备面试,复习整个 Java 知识体系将变得非常重要,可以很负责任的说一句,复习准备的是否充分,将直接影响你入职的成功率。但很多小伙伴却苦于没有合适的资料来回顾整个 Java 知识体系,或者有的小伙伴可能都不知道该从哪里开始复习。我偶然得到一份整理的资料,不论是从整个 Java 知识体系,还是从面试的角度来看,都是一份含技术量很高的资料。

三面蚂蚁核心金融部,Java开发岗(缓存+一致性哈希+分布式)

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

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

总结

就写到这了,也算是给这段时间的面试做一个总结,查漏补缺,祝自己好运吧,也希望正在求职或者打算跳槽的 程序员看到这个文章能有一点点帮助或收获,我就心满意足了。多思考,多问为什么。希望小伙伴们早点收到满意的offer! 越努力越幸运!

金九银十已经过了,就目前国内的面试模式来讲,在面试前积极的准备面试,复习整个 Java 知识体系将变得非常重要,可以很负责任的说一句,复习准备的是否充分,将直接影响你入职的成功率。但很多小伙伴却苦于没有合适的资料来回顾整个 Java 知识体系,或者有的小伙伴可能都不知道该从哪里开始复习。我偶然得到一份整理的资料,不论是从整个 Java 知识体系,还是从面试的角度来看,都是一份含技术量很高的资料。

[外链图片转存中…(img-HojU8g3s-1714647699870)]

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

  • 28
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值