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

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”);
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

读者福利

秋招我借这份PDF的复习思路,收获美团,小米,京东等Java岗offer

更多笔记分享

秋招我借这份PDF的复习思路,收获美团,小米,京东等Java岗offer

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
1)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

读者福利

[外链图片转存中…(img-dKGwmcLu-1713317212252)]

更多笔记分享

[外链图片转存中…(img-NVG3bBiR-1713317212252)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值