当前位置: 首页 > news >正文

符合网络营销的网站关键词搜索查询

符合网络营销的网站,关键词搜索查询,橙 建网站,网站建设和优化文章目录 1、缓存2、用HashMap模拟自定义缓存3、SpringBoot提供缓存的使用4、手机验证码案例完善 1、缓存 缓存是一种介于数据永久存储介质与数据应用之间的数据临时存储介质使用缓存可以有效的减少低速数据读取过程的次数(例如磁盘IO),提高…

文章目录

  • 1、缓存
  • 2、用HashMap模拟自定义缓存
  • 3、SpringBoot提供缓存的使用
  • 4、手机验证码案例完善

1、缓存

  • 缓存是一种介于数据永久存储介质与数据应用之间的数据临时存储介质
  • 使用缓存可以有效的减少低速数据读取过程的次数(例如磁盘IO),提高系统性能
  • 缓存不仅可以用于提高永久性存储介质的数据读取效率,还可以提供临时的数据存储空间

在这里插入图片描述

注意最后这条,缓存的不一定就是从持久层数据库来的数据,也可以是程序运行的临时数据,理解别太狭义,如手机验证码,对应于下图的Cache1:

在这里插入图片描述

2、用HashMap模拟自定义缓存

传统的一个查询接口,每次都查需要去和数据库交互,数据库压力大且容易产生性能瓶颈:

在这里插入图片描述
在这里插入图片描述

在Service层引入一个Map类型的非局部变量,来模拟缓存:(这种使用一个Map来充当临时缓冲池的思想需要学习

private HashMap<Integer,Book> cache = new HashMap<>();@Override
public Book getBookById(Integer id){Book book = cache.get(id);if(book == null){book = bookDao.selectById(id);cache.put(id,book);}return book;
}

此时调用之前的接口,除了第一次需要查数据库,后面直到服务重启,变量被回收,都不用再去查数据库。同理,写个手机验证码的demo代码:

在这里插入图片描述

看下效果:

在这里插入图片描述
在这里插入图片描述

3、SpringBoot提供缓存的使用

首先导入缓存技术对应的starter:

<dependency>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-cache</artifactId>
</dependency>

配置配或者直接启动类上加@EnableCaching启动缓存

@SpringBootApplication@EnableCaching  //!!!!public class SpringbootApplication {    public static void main(String[] args) {SpringApplication.run(SpringbootApplication.class, args);    }
}

此时,上面用HashMap模拟缓存的Service码就可改为:

@Cacheable(value="cacheSpace",key="#id")public Book getById(Integer id) {    return bookDao.selectById(id);}

即先从cacheSpace这块缓存空间查看,有则返回,没有再查持久层。@Cacheable注解,即以属性里的key值为键,以方法的返回值为value,既存又取,有则取,无则查后存。 以上是背后使用的缓存技术是SpringBoot默认的Simple。SpringBoot提供的缓存技术除了提供默认的缓存方案外,还可以对其他缓存技术进行整合,统一接口,方便缓存技术的开发与管理:

  • Generic
  • JCache
  • Ehcache
  • Hazelcast
  • Infinispan
  • Couchbase
  • Redis
  • Caffeine
  • Simple(默认)
  • memcached

4、手机验证码案例完善

引入@Cacheable注解后,重写并完善下这个验证码的案例。先写个工具类来生成验证码,这个工具类写的不优雅,重点备份下补0串的这种思想吧:

public class CodeUtil {private static final String[] patch = {"000000","00000","0000","000","00","0",""};public static String generatorCode(String tel){int hash = tel.hashCode();int encryption = 20230927;  //加密常量码long result = hash ^ encryption;  //第一次加密,此时,我加密码写死,同一个电话号码的验证码会一直不变long nowTime = System.currentTimeMillis();result = result ^ nowTime;  //引入时间,二次加密long code = Math.abs(result % 1000000);  //取后六位String codeStr = code + "";  //也可能不够6位,比如000147,则上面的long code就是147return patch[codeStr.length()] + codeStr;  //加一个补0数组,根据字符串长度来取对应的补0串,最多补5个0,最少不补,这里为了适配数组下标从0开始,给array[0]给个值}
}

注意根据字符串长度来取数组中对应的补0串时,长度为6,则取array[6],但数组下标从0开始,会越界:

在这里插入图片描述

此时有两种思路处理,一种是上面的,给数组加个下标为0的值,此时str.length()就和数组下标对应上了,也可以直接让str.length()-1:

return patch[codeStr.length() -1 ] + codeStr;

Service层,生成验证码,并存缓存,不能用@Cacheable,它既存又取,这样验证码在缓存失效前都一样,可改为@CachePut只存不取

@Service
@Slf4j
public class MsgServiceImpl implements MsgService {@Resource@Lazy  //解决下循环以来的问题MsgService msgService;/*** 返回验证码* @param tel* @return*/@Override//@Cacheable(value = "telCode",key = "#tel")@CachePut(value = "telCode",key = "#tel")public String getCheckCode(String tel) {String checkCode = CodeUtil.generatorCode(tel);return checkCode;}/*** 校验验证码* @param tel* @param checkCode* @return*/@Overridepublic boolean verify(String tel, String checkCode) {return checkCode.equals(msgService.getCode(tel));}@Override@Cacheable(value = "telCode",key = "#tel")public String getCode(String tel){return null;}
}

关于校验方法里的取验证码,之前写需求用redis,直接redisTemplate.get了,但这里底层缓存技术是Simple,可单独写个方法,上面加@Caceable注解,然后校验方法里调用这个获取缓存值的方法即可实现(此时会有@Cacheable注解失效问题,注意出去绕一圈拿代理对象来调用)。还是利用了@Cacheable注解的特点,先查有无这个key,有就把value当作这个方法的返回值,没有再执行代码方法体。

@Cacheable(value = "telCode",key = "#tel")
public String getCode(String tel){return null;
}

Controller层随便写就行:

@RestController
@RequestMapping("/msg")
public class MsgController {@ResourceMsgService msgService;@GetMapping("{tel}")public String getCode(@PathVariable String tel){return msgService.getCheckCode(tel);}@PostMappingpublic Boolean verifyCode(@RequestParam String tel,String code){return msgService.verify(tel,code);}
}

重点关注:

  • 工具类中加密使用了一个补0数组的思想
  • @Cacheable既存又取,这样验证码在缓存失效前都一样,可改为@CachePut只存不取
  • @Cacheable注解因方法内部调用而失效的解决
  • 不用Redis,再取数据时,引入了一个方法,加@Cacheable注解并返回null,即查到这个key的值就返回,否则返回方法的返回值,即null
http://www.dinnco.com/news/27420.html

相关文章:

  • 学网站建设前途企业网站设计与实现论文
  • 专业网站建设搭建网络营销有什么特点
  • 做兼职网站哪个靠谱加强服务保障满足群众急需m
  • 免费建立手机网站营销型网站和普通网站
  • 宁波专业网站制作服务网络营销和电子商务区别
  • wordpress incategory网站排名优化多少钱
  • 威海做网站的公司有哪些网站页面seo
  • 建网站建设最近的新闻大事20条
  • 营销型网站建设特点恢复正常百度
  • 购物网站排名2016考研比较厉害的培训机构
  • 做照片书的模板下载网站好全国最好的广告公司加盟
  • 怎样做网站推广啊百度竞价什么时候开始的
  • 网站打开时的客户引导页深圳营销型网站
  • 珠海网站建设排名友情链接交换软件
  • 网站开发费用税网络营销主要做些什么工作
  • 怎样接做网站的活百度商城
  • 搜维斯网站建设seo任务平台
  • 哪家网站荥阳网站优化公司
  • 深圳燃气公司电话95511中国十大seo公司
  • 用商标做网站名字优化百度seo
  • 做细胞激活的母液网站国家新闻最新消息今天
  • 图片网站 模板如何提高网站的自然排名
  • ecshop怎么做网站推广手段和渠道有哪些
  • 微信小程序怎么写seo怎么做整站排名
  • 东莞专业全网推广建站公司种子搜索引擎
  • 响应式网站文字大小seo技术网
  • java做的网站怎么调试郑州seo团队
  • 德尔普网站建设长沙网站优化推广
  • 目前网站在初级建设阶段 需要大量数据丰富2022年最新新闻播报稿件
  • 那个比特币网站可以做杠杆品牌词优化