给eladmin提的PR终于合进去了

       起因还是因为腾飞学给我下发的任务,让我把eladmin的持久层框架jpa换成我们熟悉的mybatis/mybatis plus,这可谓是一个比较庞大的工程,因为要保证eladmin前端在接口不变的情况下可以直接登录使用,这就要求你要掌握整个eladmin源码的运行流程。
       就在第二天转化security模块中的获取验证码接口时,发现了一个比较奇怪的情况,当输入验证码结果为0的情况时,提示输入验证码错误,例如:0+00x9等。起初我以为我只是自己看错了,也没在意,其他的验证码结果可以通过是正确的,但是之后却发现确实在结果为0的时候提示了验证码输入错误,而其他结果输入就显示正确。

image.png

       第一时间先是和小桑学长提出这个问题,经排查后发现redis里存入的验证码结果是“0.0”,是一个浮点型数据,难怪前端输入0会报错,我刷新了几次验证码又找到一个结果为0的验证码,这次输入0.0就成功了,看来是验证码放入redis的问题,那就是在获取验证码接口中出了问题。
       eladmin引入的验证码为:

<dependency>
            <groupId>com.github.whvcse</groupId>
            <artifactId>easy-captcha</artifactId>
            <version>1.6.2</version>
</dependency>

       最新的版本1.6.2也是1年前的了。eladmin中获取验证码的接口是在security模块下的rest/AuthorizationController中的/code接口。eladmin默认使用的是算数型验证码,放入缓存中的值为captcha.text()Captcha是验证码类,text()方法是将验证码的结果以字符形式输出,那问题就出现在这里了,经测试,当验证码类型为 arithmetic时且长度 >= 2 时,captcha.text()的结果有几率为浮点型,那么根本的问题其实不在于eladmin,而是easy-captcha的问题,不过可以先治标,解决方法就是对captcha.text()的结果以"."分割,取第一部分,这样就可以把数据的小数部分去掉,鲁棒性也比较高。

String captchaValue = captcha.text();
        if (captcha.getCharType() - 1 == LoginCodeEnum.arithmetic.ordinal() & captchaValue.contains(".")) {
            captchaValue = captchaValue.split("\\.")[0];
        }

       修改之后便给github eladmin提了一个pr,等待着管理员elunez的审核通过,毕竟这是第一次给人家大的开源项目提pr,还是比较紧张的。
       学长鼓励我追寻根本原因,之后又把easy-captcha的源码给拉了下来,经一段时间的排查定位到根本问题是在算数型验证码抽象类中的问题,在ArithmeticCaptchaAbstract中一串代码:

 ScriptEngineManager manager = new ScriptEngineManager();
 ScriptEngine engine = manager.getEngineByName("javascript");
        try {
            chars = String.valueOf(engine.eval(sb.toString().replaceAll("x", "*")));
        } catch (ScriptException e) {
            e.printStackTrace();
        }

       其中关键问题就是在engine.eval中,这个方法可以计算出一个算数式的结果并输出,但是返回值类型Object,而实际有一部分为整形,一部分为浮点型,而easy-captcha并未对其处理,而是直接转成字符串,而text()方法输出的就是这个。由于强转也比较麻烦,最后也是用了比较粗暴的办法就是直接分割字符串——split("\.")[0];
       顺便也提了一个pr,但是这个可能审批过的概率不大,毕竟上次更新都是7个月之前的事了。而我给eladmin提的pr也是一天天过去,其中有看到比我提交的早的分支被关闭,我还是比较恐慌的。
       之后小桑学长在测试部门的时候又发现了一个bug,但是eladmin官方在几天前最新的一次分支就是这个bug的修复,但是小桑学长说可以简化写法,我就根据小桑学长的写法又提了个pr,不料这次过了一会就被关闭了,并不是没被采纳,而是eladmin自己根据小桑学长的的方法改了代码。

image.png

       这个关了就关了吧,还剩一个pr。终于,9天过后,我的邮箱收到了一封邮件,显示 Merged #464 into master. 功夫不负有心人,提的pr总算是合进去了。
image.png

image.png

       最后还要感谢小桑学长的帮助。

image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342