首页 > 代码库 > Servlet数据缓存

Servlet数据缓存

 缓存是提高数据访问能力,降低服务器压力的一种必要的方式,今天我要说的数据缓存方式有两种,1-->session对单个数据访问接口页面的数据进行缓存,2-->单例模式对整个servlet页面一个公用的数据缓存。 3-->cookie本地缓存

一、什么是缓存

                  什么是缓存,为了让看者更好的理解,我这里就用自己的理解来举例说明,例如当前我们正在做一个商城类的app,app首页要加载显示很多商品,数据量比较大,像这样的数据接口最适合给其加一个缓存了,因为这样的数据接口反馈的数据都是公用的(所有人都是用它,不会根据不同用户判断,加载不同的数据) 。在我们没有增加缓存之前,每当用户在app上点击对应的调用接口页面之后,servlet都会去访问数据库,从数据库中取得数据。但是当我们加了缓存后,只要有一个用户访问了这个接口数据库之后,我们就会将这份数据保存到缓存中,那么下次只要有用户调用该接口,servlet就会从缓存中读取保存的数据,然后反馈给用户。

二、session

               session对点缓存,它保存的缓存,无法在其他页面进行访问,数据保存在服务器内存中,下面我来代码。               

 1 //查询出游戏表当前所有数据 2         else if(Type.equals("3")) 3         { 4              5               6               HttpSession session = request.getSession();  7               // 判断session中 allGamesDataList的值是否为空,由于下面的代码对session设置了过期时间,所以只要过期了,servlet 8               //这个值也会自动设置为空 9               if (session.getAttribute("allGamesDataList") != null) {  10                   11                   returnJsonObject=(JSONObject) session.getAttribute("allGamesDataList");12                    response.getWriter().println(returnJsonObject.toString());13                    return;14               } else{  15                   16                   17               18               }19          20              mysqlParameter=new String[]{"account"};23            returnData=http://www.mamicode.com/MySqlHepler.executeQueryT("select __ from __ where __!=?", mysqlParameter);24                       25             try {26                    returnJsonObject =new JSONObject();27                    returnJsonArray=ResultToJsonTool.resultSetToJsonArry(returnData);28                     returnJsonObject.put("Rows", returnJsonArray);31                    returnJsonObject.put("GetType", "0");32                    returnJsonObject.put("Success", "1");33                     //缓存5分钟过期,5分钟内有人调用该接口,会直接从缓存中获得数据,5分钟后必须再访问一次数据库获得数据并保存到缓存中37                    session.setMaxInactiveInterval(5 * 60);38                    session.setAttribute("allGamesDataList", returnJsonObject);39                   response.getWriter().println(returnJsonObject.toString());40                   41             } catch (SQLException | JSONException e1) {42                  43                 44                 e1.printStackTrace();45             }46             47         }

二、单例模式

               这里用单例来做缓存,是因为session保存的缓存无法跨页访问,所以就想到了单例,当然肯定还有其它更好的方法。我这里使用单例保存的是用户的token,当用户登录时生成的一个随机token反馈给用户,然后已用户的登录id为key,将toke保存在servlet的单例中, 这里将token保存到缓存中,是因为token在所有的数据加密验证页面中都会使用到, 如果不保存那么所有加密接口请求时都会去数据库中查询一次token,这样肯定就影响效率了,遇到这样的数据, 也必须做缓存的。

单例代码

 1 package Helper; 2 import org.json.JSONObject; 3 public class ShareSingleton      4 {      5   public     JSONObject UsrTokenDictionary;  6   public   static ShareSingleton instance=null;  7   public static      ShareSingleton getInstance(){      8         if(instance == null){   9             instance = new ShareSingleton();  10               instance.UsrTokenDictionary=new JSONObject();11              return instance;12             13         }else{     14             return instance;     15         }     16     }    17    18   public void VerifyTokenForInterface(String RequestToken)19   {20       21      22   }23 }   

 

保存token到单例中

 1     //使用uuid生成用户唯一token 2                  ecryptToKenUUID = UUID.randomUUID().toString(); 3                   mysqlParameter=new String[]{ecryptToKenUUID,LoginId}; 4                 if(    MySqlHepler.executeUpdate("update  _ set _=?  where _=?", mysqlParameter)>0) 5                 { 6                       7                         UserInfoObject =array.getJSONObject(0); 8                        UserInfoObject.put("encryptToken",ecryptToKenUUID); 9                        /*AddicationDictionary:这里的取值:为用户需要保存到app defaultusr里面的*/10                        returnJsonObject.put("AddicationDictionary", UserInfoObject);11                        returnJsonObject.put("GetType", "1");12                        returnJsonObject.put("Success", "1");13                        14                         //再servlet返回操作结果前将 生成的token保存到单例模式中15                        ShareSingleton.getInstance().UsrTokenDictionary.put(LoginId,ecryptToKenUUID);16                        17                        response.getWriter().println(returnJsonObject.toString());18                 }

 

Servlet数据缓存