1. 功能分析
 
1.1 login.html中的header.html
 
- 发送ajax请求,访问服务器,加载真正的分类数据
- 遍历数组,完成展示
1.2 web层
 
 
1.3 service层
 
- 先在redis缓存查询,没有则访问mysql查询,并加入redis,有则不需要访问mysql
2. header.html
 
$.get("/ssm-travel/user/findName", {}, function (data) {......});
$.get("/ssm-travel/category/selectCategoryAll", {}, function (data) {
            
            var lis = '<li class="nav-active"><a href="index.html">首页</a></li>';
            
            for (var i = 0; i < data.length; i++) {
                var li = '<li><a href="route_list.html?cid=' + data[i].cid + '">' + data[i].cname + '</a></li>'
                lis += li
            }
            
            lis += '<li><a href="favoriterank.html">收藏排行榜</a></li>'
            console.log(lis)
            $("#category").html(lis);
        })
 
3. mapper层
 
 
 
package com.ssmtravel.mapper;
import com.ssmtravel.domain.Category;
import org.apache.ibatis.annotations.Select;
import java.util.List;
public interface CategoryMapper {
    
    @Select("select * from tab_category")
    List<Category> CategoryData();
}
 
3. service层
 
 
package com.ssmtravel.service;
import com.ssmtravel.domain.Category;
import java.util.List;
public interface CategoryService {
    
    List<Category> CategoryData();
}
 
- 实现 CategoryServiceImpl.java
package com.ssmtravel.service.Impl;
import com.ssmtravel.domain.Category;
import com.ssmtravel.mapper.CategoryMapper;
import com.ssmtravel.service.CategoryService;
import com.ssmtravel.utils.JedisUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.Tuple;
import java.util.ArrayList;
import java.util.List;
import java.util.Set;
@Service("categoryService")
public class CategoryServiceImpl implements CategoryService {
    @Autowired
    private CategoryMapper categoryMapper;
    @Override
    public List<Category> CategoryData() {
        
        
        
        Jedis jedis = JedisUtil.getJedis();
        
        Set<Tuple> categorys = jedis.zrangeWithScores("category", 0, -1);
        List<Category> cs = null;
        
        if (categorys == null || categorys.size() == 0) {
              
            
            
            cs = categoryMapper.CategoryData();
            
            for (int i = 0; i < cs.size(); i++) {
                jedis.zadd("category", cs.get(i).getCid(), cs.get(i).getCname());
            }
        } else {
            
            
            cs = new ArrayList<Category>();
            for (Tuple tuple : categorys) {
                Category category = new Category();
                category.setCname(tuple.getElement());
                category.setCid((int) tuple.getScore());
                cs.add(category);
            }
        }
        return cs;
    }
}
 
4.web层
 
 
package com.ssmtravel.controller;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.ssmtravel.domain.Category;
import com.ssmtravel.service.CategoryService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import javax.servlet.http.HttpSession;
import java.io.IOException;
import java.util.List;
@Controller
@RequestMapping("/category")
public class CategoryContorller {
    private String err_msg = null;
    @Autowired
    private CategoryService categoryService;
    
    @RequestMapping(value = "/selectCategoryAll",produces = "application/json;charset=utf-8")
    @ResponseBody
    public String exitLogin(HttpSession session) throws IOException {
        List<Category> categories = categoryService.CategoryData();
        ObjectMapper objectMapper = new ObjectMapper();
        return objectMapper.writeValueAsString(categories);
    }
}
 
5. 工具类
 
 
package com.ssmtravel.utils;
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;
public final class JedisUtil {
    private static JedisPool jedisPool;
    private static String AUTH;
    static {
        
        InputStream is = JedisPool.class.getClassLoader().getResourceAsStream("jedis.properties");
        
        Properties pro = new Properties();
        
        try {
            pro.load(is);
        } catch (IOException e) {
            e.printStackTrace();
        }
        
        AUTH=pro.getProperty("auth");
        
        JedisPoolConfig config = new JedisPoolConfig();
        config.setMaxTotal(Integer.parseInt(pro.getProperty("maxTotal")));
        config.setMaxIdle(Integer.parseInt(pro.getProperty("maxIdle")));
        
        jedisPool = new JedisPool(config, pro.getProperty("host"), Integer.parseInt(pro.getProperty("port")));
    }
    
    public static Jedis getJedis() {
        Jedis jedis = jedisPool.getResource();
        jedis.auth(AUTH);
        return jedis;
    }
    
    public static void close(Jedis jedis) {
        if (jedis != null) {
            jedis.close();
        }
    }
}
 
- redis配置文件:jedis.properties
host=127.0.0.1
port=6379
auth=123456
maxTotal=50
maxIdle=10