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

wordpress widget插件seo优化中以下说法正确的是

wordpress widget插件,seo优化中以下说法正确的是,网站建设pdf,做网站的软件 简单易学PS:作者是小白能接触到的就只会这样写。勿喷。 前提 思路: 结合io流将登录token存储到配置文件中,不将token存储到浏览器端,从而避免盗取。 下面jwt的学习可以参考下这个: JWT --- 入门学习_本郡主是喵的博客-CSDN博客 JWT工具类 Component public class JWTtU…

PS:作者是小白能接触到的就只会这样写。勿喷。

前提

思路: 结合io流将登录token存储到配置文件中,不将token存储到浏览器端,从而避免盗取。

下面jwt的学习可以参考下这个:

JWT --- 入门学习_本郡主是喵的博客-CSDN博客

JWT工具类

@Component
public class JWTtUtils {public static final String USER_NAME = "username";public static final String PASS_WORD = "password";public static final String CREATE_TIME = "createTime";public static final String SIGN_KEY = "QHX2004"; // 解析key/*** 用用户名和密码生成JWT** @param username* @param password* @return*/public String generatorJWTFromUserNameAndPassword(String username,String password){HashMap<String, Object> hashMap = new HashMap<>(); // 生成maphashMap.put(USER_NAME,username);hashMap.put(PASS_WORD,password);hashMap.put(CREATE_TIME,new Date());return  generatorJWTFromUserNameAndPassword(hashMap);}/*** 生成jwt过期时间,1个月** @param* @return*/private Date generatorExpirationDate() {return new Date(System.currentTimeMillis() + (1000L * 60 * 60 *24 *30));}/*** 用用户名和密码生成jwt** @param paramMap* @return*/private String generatorJWTFromUserNameAndPassword(HashMap<String, Object> paramMap) {JwtBuilder jwtBuilder = Jwts.builder().setClaims(paramMap).setExpiration(generatorExpirationDate()) // 设置过期时间.signWith(SignatureAlgorithm.HS512,SIGN_KEY);return jwtBuilder.compact(); // 拿到token}/*** 解析token拿到Claims*** @param token* @return*/private Claims getClaimsFromToken(String token){Claims claims = Jwts.parser().setSigningKey(SIGN_KEY).parseClaimsJws(token).getBody();return claims;}/*** 校验token是否过期** @param token* @return*/// 过期返回truepublic boolean checkTokenIsOverdue(String token){Claims claims = getClaimsFromToken(token);Date date =  claims.getExpiration();return date.getTime() < new Date().getTime();}/*** 刷新token:重新生成一个token** @param* @return*/public String flushToken(String token){Claims claims = getClaimsFromToken(token);String username = (String) claims.get(USER_NAME);String password = (String)claims.get(PASS_WORD);return generatorJWTFromUserNameAndPassword(username,password);}}

IO工具类

public class IOUtils {public static final String FILE_NAME = "conf.properties";/***   配置文件读取* @param key* @return  value*/public static String getPropertiesKey(String key)  {return  getKey(key);}/*** 配置文件读取** @param  key* @return*/private static String getKey(String key) {Properties properties = new Properties();File file = new File(FILE_NAME);FileInputStream inputStream = null;try {inputStream = new FileInputStream(file);properties.load(inputStream); // 其实已经将配置文件拿到手了} catch (IOException e) {e.printStackTrace();}finally {if(inputStream != null){  // 还是这样关比较好,万一报错就tm关不了try {inputStream.close();} catch (IOException e) {e.printStackTrace();}}}return  properties.getProperty(key);}/*** 配置文件设置** @param key* @param value* @return*/public static boolean setPropertiesKey(String key,String value) {// 判断key是否有重复String key1 = getKey(key);if(key1 == null){return setKey(key,value); // 把核心业务逻辑抽出来}return false;}/***  配置文件设置** @param key* @param value* @return boolean*/private static boolean setKey(String key, String value) {Properties properties = new Properties();File file = new File(FILE_NAME); // 其实有其他配置可以同意下yaml文件里面配置,然后这里面读取,好统一调配。FileWriter fileWriter = null;try {fileWriter = new FileWriter(file,true);properties.setProperty(key, value); // 存进map里面properties.store(fileWriter,""); // 将map对应的键值对写进输出流。} catch (IOException e) {// 卧槽我加入设置key,value失败,肯定调到这个逻辑return false;} finally {if (fileWriter != null) {  // 还是这样关比较好,万一报错就tm关不了try {fileWriter.flush();fileWriter.close();} catch (IOException e) {e.printStackTrace();}}}return true;}}

测试文件

@SpringBootTest
class IoDemoApplicationTests {@Testvoid contextLoads() {// 用户第一登录 ----,我们这里浏览器端不存token,只存用户名,更安全。String username = "qhx2005";String password = "123456";// 生成jwtJWTtUtils jwTtUtils = new JWTtUtils();String token = jwTtUtils.generatorJWTFromUserNameAndPassword(username, password);// 将jwt存进配置文件boolean success = IOUtils.setPropertiesKey(username, token);System.out.println("存进配置文件成功状态:"+success);assert success;// 用户登录后访问其他页面。检验token过期,拿出配置文件是否存在----// 获取tokenString token1 = IOUtils.getPropertiesKey(username);System.out.println(token1);// 检验token是否过期boolean overdue = jwTtUtils.checkTokenIsOverdue(token);// 本来这里如果token过期,我们响应一个状态码,让前端axios过滤器捕获到,删除本地username,重定向到登录页。System.out.println("已经过期:"+overdue);}}

http://www.tdrn.cn/news/385.html

相关文章:

  • 上海环球金融中心美食seo网络优化师
  • 好的高端网站青岛网络优化费用
  • 保定市做网站的公司长尾关键词挖掘精灵官网
  • 做网站都需要买什么软件seo服务 文库
  • 衡水做wap网站建设seo案例视频教程
  • 专业高端网站建设服务公司培训机构专业
  • 成都网站建设哪家专业而且比较便宜企业网络宣传推广方案
  • 网站开发选择什么软件企业培训计划
  • 合肥做公司网站联系方式网络优化论文
  • 外贸独立站seo女装标题优化关键词
  • 网络公司给我做网站我有没有源代码版权吗青岛seo培训
  • 做网站530元seo博客教程
  • 邢台做网站动态如何在百度上开店铺
  • 比较好的外贸网站windows优化大师怎么样
  • 建网站报价 优帮云长沙网站seo推广
  • 哈尔滨做网站价格优帮云排名自动扣费
  • 网站在线访谈栏目建设网站的seo优化报告
  • 做网络推广自己建网站saascrm国内免费pdf
  • 网站源代码上传都需要怎么做青岛seo网站建设公司
  • 局网站建设工作总结电商培训心得
  • aspnet网站开发选择题网站联盟广告
  • lol做框网站安卓优化大师2021
  • 怎么.做网站在线代理浏览网页
  • 猪八戒网网站建设外链工厂 外链
  • seo公司培训快速排名seo软件
  • 文化馆网站建设解决方案搜外
  • 域名注册是什么意思免费seo课程
  • app网站制作软件中国没有限制的搜索引擎
  • 上海网站制作机构网络营销是以什么为中心
  • 无印良品vi设计分析seo优化师培训