专栏首页Danny的专栏给你的项目添加一个灵活的“开关”

给你的项目添加一个灵活的“开关”

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/huyuyang6688/article/details/62438278

  年后项目提测了两次,每次提测都是通宵达旦完成~第二次通宵的原因主要可以用一个字来形容:等。

  项目中对接了一个代付通道,每次测试代付功能都是发起代付请求之后,需要等十几到二十几分钟才能返回代付结果,甚至期间通道偶尔会出现一些问题,更尴尬的是等了好长时间,返回的结果是代付失败(代付通道测试环境返回的代付结果都是随机的)。

  这时候就找到一个办法就是在代付的位置加上一个开关,需要模拟代付成功的时候可以打开,走正常流程的时候就关闭,类似于Mock,可以自由控制我们测试自己的代码的时候不受第三方的影响。

这好办,我在代码里是这么干的:

public class PayServiceImpl implements PayService{
    protected final static boolean isOpenMockPaySuccess = true; // 模拟代付成功的开关

    /**
     * 代付请求
     * @return
     */
    public boolean payRequest(){
        if(isOpenMockPaySuccess){
            return true;//如果开关打开,模拟代付请求成功
        }else{
            //执行正常的代付请求逻辑
        }
    }

    /**
     * 代付结果查询
     * @return
     */
    public boolean payQuery(){
        if(isOpenMockPaySuccess){
            return true;//如果开关打开,模拟代付结果成功
        }else{
            //执行正常的代付结果查询逻辑
        }
    }
}

  这样就能实现上面说的效果了,无论代付通道需要多长的处理时间,有没有挂掉,我们都不需要关注,只需要专注于测试自己的逻辑。

  看到这里您可能以为这就OK了,但是这么做有一个致命的缺点,就是安全性。

  测试无误的代码都是随时可以上线的,假如上面的代码测试无误,那上线之后如果忘记关上开关,那是不是每一笔代付都默认成功啦(其实都没有提交)?

  所以为项目加一个开关的想法是好的,但是这个开关最好是关闭状态的,不影响正常逻辑,只有在开关需要打开的时候才去打开,并且可以动态关闭并且不修改代码。

  这时就可以使用读取自定义环境变量的形式来设置开关,比如:

protected final static boolean isOpenMockPaySuccess = Boolean.parseBoolean(System.getProperty("isOpenMockPaySuccess", "false")); // 模拟代付成功的开关

  默认是关闭(false),如果需要打开开关,则需要在jvm启动参数中添加isOpenMockPaySuccess参数,值为true:

-Xmx128 -Xms64 -Xmn32m -Xss16m -DisOpenMockPaySuccess=true

  这样,测试的时候可以在测试环境打开开关,生产环境也不会执行威胁生产环境安全的代码,保证程序在测试环境顺利测试,在生产环境安全运行。


【 转载请注明出处——胡玉洋《给你的项目添加一个灵活的“开关”》】

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 【MyBatis框架点滴】——初识+环境搭建

    版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/huyuyang6688/article/...

    DannyHoo
  • 【SSH快速进阶】——Hibernate 多对多映射

    版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/huyuyang6688/article/...

    DannyHoo
  • 【SSH快速进阶】——Hibernate继承映射:每个具体类映射一张表

    版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/huyuyang6688/article/...

    DannyHoo
  • 一脸懵逼学习HBase的搭建(注意HBase的版本)

    1:Hdfs分布式文件系统存的文件,文件存储。 2:Hbase是存储的数据,海量数据存储,作用是缓存的数据,将缓存的数据满后写入到Hdfs中。 3:hbase集...

    别先生
  • Hive on spark的搭建记录 原

        注:Hadoop-2.7.7、Hive-2.1.1、spark-1.6.0-bin-hadoop2.6,操作系统是Ubuntu18  64bit。最近做...

    克虏伯
  • 基于Yarn的Spark环境,统计哈姆雷特词频(1)

    说明:本地的hadoop目录会挂载到docker中hadoop/etc/hadoop配置文件目录。

    birdskyws
  • 看到猎豹这款机械臂,你有没有产生什么大胆的想法?

    猎豹移动CEO@傅盛 发了一条微博,配了一个超级未来感的视频,结果激发了微博众粉丝连同各品牌的联合狂欢。先来瞅瞅这个视频,真第一次看到这么酷炫的机械臂。

    IT派
  • Android 极光推送与 WebView 日常问题小结

    极光推送在日常的应用中应用广泛,集成简单送达率较高,和尚刚开始集成时很方便,但是随着项目的逐渐变大,分包和组件化等应用比较多,此时单独出 push ...

    阿策
  • 【干货】如何建立网站数据分析模型

    网站分析方案能否彻底实施,最关键的在于是否有严密的方案,方案应该包括哪些内容呢?主要框架包括商业目标,围绕商业目标要解决的问题,需要什么数据来回答这些问题...

    机器学习AI算法工程
  • Json海量数据解析Json海量数据解析

    ​ 在android开发中,app和服务器进行数据传输时大多数会用到json。在解析json中通常会用到以下几种主流的解析库:jackson、gson、fa...

    用户2929716

扫码关注云+社区

领取腾讯云代金券