import javax.servlet.http.HttpServletRequest;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.QueryParam;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response; import org.apache.commons.lang3.StringUtils;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger; import com.zzc.bl.util.ConfigMgr;
import com.zzc.bl.util.StringEncryptUtil; @Path("/loadConfig")
@Produces(MediaType.APPLICATION_JSON)
public class LoadConfig {
private static final Logger logger = LogManager.getLogger(LoadConfig.class.getName()); // private static final String token = UUID.randomUUID().toString() + System.currentTimeMillis();
// private static final String token = "c2d4f7e8e001486114862926";
// private static final String single = "1fc54ecc9c6f4dfd9799b7baec1b0de6";
private static final String salt = "3f73c5fafaf13f160670b59025745889";
@GET
@Path("/loading")
public Response loading(@QueryParam("token") String token,@QueryParam("single") String single,@Context HttpServletRequest request) {
final String requestPath = request.getPathInfo();
logger.info("[entrance: " + requestPath + "] [params: { \"token\": \"" + token + "\", \"single\": \"" + single + "\" } ]");
// 检测请求合法性
if(StringUtils.isEmpty(token)){
logger.info("[entrance: " + requestPath + "] [response_status: 400] [response_body: { \"errors\": \"token is empty !!!\" } ]");
return Response.status(400).entity("{\"errors\": \"token is empty !!!\"}").build();
}
if(StringUtils.isEmpty(single)){
logger.info("[entrance: " + requestPath + "] [response_status: 400] [response_body: { \"errors\": \"single is empty !!!\" } ]");
return Response.status(400).entity("{\"errors\": \"single is empty !!!\"}").build();
}
String content = salt + StringEncryptUtil.md5(token);
String mdStr = StringEncryptUtil.md5(content);
if(!mdStr.equals(single)){
logger.info("[entrance: " + requestPath + "] [response_status: 400] [response_body: { \"errors\": \"single is invalid !!!\" } ]");
return Response.status(400).entity("{\"errors\": \"single is invalid !!!\"}").build();
}
// 加载Properties属性文件
ConfigMgr.init("config.properties");
logger.info("[entrance: " + requestPath + "] [response_status: 200] [response_body: {\"success\": \"properties files has been loaded !!!\"} ]");
return Response.status(200).entity("{\"success\": \"properties files has been loaded !!!\"}").build();
} }

加载Properties文件工具类:LoadConfig的更多相关文章

  1. Java加载Properties配置文件工具类

    Java加载Properties配置文件工具类 import org.apache.commons.lang3.StringUtils; import org.apache.log4j.Logger; ...

  2. JavaEE互联网轻量级框架整合开发(书籍)阅读笔记(12):XML配置自动扫描包,自动加载*.properties文件

    一.XML和注解组合使用 前几篇的测试案例都是在Java类中配置,现在换一种使用方式,在XML中配置,使Spring IoC容器在启动之后自动去扫描配置的包路径,扫描加载指定路径下的propertie ...

  3. spring入门(二)【加载properties文件】

    在开发过程当中需要用到配置信息,这些信息不能进行硬编码,这时配置文件是一个比较好的方式,java提供了properties格式的文件,以键值对的方式保存信息,在读取的时候通过键获得键对应的值,spri ...

  4. java加载properties文件的六中基本方式实现

    java加载properties文件的方式主要分为两大类:一种是通过import java.util.Properties类中的load(InputStream in)方法加载: 另一种是通过impo ...

  5. 加载properties文件的三种方法

    源代码: package a.one; import java.io.FileInputStream; import java.io.InputStream; import java.util.Pro ...

  6. Spring加载properties文件的两种方式

    在项目中如果有些参数经常需要修改,或者后期可能需要修改,那我们最好把这些参数放到properties文件中,源代码中读取properties里面的配置,这样后期只需要改动properties文件即可, ...

  7. java加载properties文件的六种方法总结

    java加载properties文件的六种方法总结 java加载properties文件的六中基本方式实现 java加载properties文件的方式主要分为两大类:一种是通过import java. ...

  8. Java开发学习(八)----IOC/DI配置管理第三方bean、加载properties文件

    前面的博客都是基于我们自己写的类,现在如果有需求让我们去管理第三方jar包中的类,该如何管理? 一.案例:数据源对象管理 本次案例将使用数据源Druid和C3P0来配置学习下. 1.1 环境准备 学习 ...

  9. android html 图片处理类--加载富文本工具类

    在android开发中,一些资讯类页面,里面有html标签和图片,html 标签一般通过Html.fromHtml方法,即可以解决,但是如果html 有图片标签,那么,Html.fromHtml 好像 ...

随机推荐

  1. C++的基本输入输出

    参考:http://www.runoob.com/cplusplus/cpp-basic-input-output.html

  2. Hyperledger Fabric 2.1 搭建教程

    Hyperledger Fabric 2.1 搭建教程 环境准备 版本 Ubuntu 18.04 go 1.14.4 fabric 2.1 fabric-sample v1.4.4 nodejs 12 ...

  3. day08总结

    集合常用操作# 一.关系运算firends1 = {"zero", "kevin", "jason", "egon"}f ...

  4. day39 进程

    目录 一.进程对象的其他方法 二.僵尸进程与孤儿进程(了解) 1 僵尸进程 2 孤儿进程 三.守护进程 四.互斥锁 五.进程间通信 六.IPC机制 七.生产者消费者模型 八.线程理论 一.进程对象的其 ...

  5. MATLAB GUI之ABC

    GUIDE 属性设置 name 更改名字 logo 在GUI的".m"文件中的OpeningFcn函数或者OutputFcn函数中添加以下代码: % 设置页面左上角的 LogoI ...

  6. JVM 专题十八:垃圾回收(二)垃圾回收相关算法

    1. 标记阶段 1.1 引用计数算法 1.1.1 对象存活判断 在堆里存放着几乎所有的Java对象实例,在GC执行垃圾回收之前,首先需要区分出内存中哪些是存活对象,哪些是已经死亡的对象.只有被标记为己 ...

  7. 02 drf源码剖析之快速了解drf

    02 drf源码剖析之快速了解drf 目录 02 drf源码剖析之快速了解drf 1. 什么是drf 2. 安装 3. 使用 3. DRF的应用场景 1. 什么是drf drf是一个基于django开 ...

  8. Python之class面向对象(基础篇)

    概述 面向过程:根据业务逻辑从上到下写垒代码 函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可 面向对象:对函数进行分类和封装,让开发“更快更好更强...” 面向过程编程最易被初学 ...

  9. 保存与恢复变量和模型,tensorflow官方文档阅读笔记

    官方中文文档的网址先贴出来:https://tensorflow.google.cn/programmers_guide/saved_model tf.train.Saver 类别提供了保存和恢复模型 ...

  10. Knn和K-means

    先开个标题,以后慢慢填充. k近邻算法(knn)属于监督学习 一. 三个关键点:1.k的取值,当k值较小时,选取点较少,相当于会有在较小的范围内进行学习预测,学习误差会减小,但是估计误差会增大,因为训 ...