结论

.NET Core项目(.NET Framework没出现)在阿拉伯语(即语言名称是ar-开头的语言)环境下,将负数字符串转成数字,即int.Parse("-1")Convert.ToInt32("-1")时,会抛出异常“Input string was not in a correct format.”

解决办法

使用重载方法,int.Parse("-1",CultureInfo.InvariantCulture)Convert.ToInt32("-1",CultureInfo.InvariantCulture)

========================= 分界线 ======================

下面记录一下踩坑的经过

事情起因

基于ABP框架开发的项目,测试服切换多语言时报500错误,当切到阿拉伯语相关语言(即ar-开头的语言)时报错,但是本地跑正常的

问题排查

  1. 看日志



    通过日志不难发现,是获取缓存时,CSRedis抛出的异常,而本地调试时,未连接redis服务器,初步猜测,是redis出了问题
  2. 校验redis
  • 本地连接redis(和测试服同一台redis服务器)调试,当切到阿拉伯语时,果然出现了同样的错误。说明就是切换了语言,导致了redis的报错,但是很不解,多语言跟redis有啥关系呢?
  • 猜测是缓存的数据问题,尝试清空redis缓存,但问题依旧;
  • 猜测是key的问题,校验时有所发现,再次说明就是阿拉伯语导致的
    • 当切换成阿拉伯语时,redis中存在的key可以正常查出,不存在的key报错
    • 当切换成非阿拉伯语时,一切正常,不存在的key会返回null
  • 此时猜测可能是CSRedis的代码有问题,看日志中的"Input string was not in a correct format."就是CSRedis抛出的,CSRedis是一个开源项目,CSRedis源码地址
  1. 矛头指向CSRedis
  • 找到项目引用对应CSRedis源码,本地新建一个控制台项目,连接测试的redis服务器,开始调试CSRedis源码,一切正常
  • 此时CultureInfo.CurrentCultureCultureInfo.CurrentUICulture获取到的是zh-hans,猜测如果把zh-hans改成ar-ER(阿拉伯语的一种)是不是就会报错?
  1. 胜利在望
  • CultureInfo.CurrentCultureCultureInfo.CurrentUICulture改成ar-ER之后,果然报错出现了(终于看到了胜利的曙光,此时我已经被这个问题搞了3-4天了。。。)
  • 初步结论:就是CSRedis的代码有问题,当语言环境是阿拉伯语的时候,CSRedis就会报错(内心想:写得什么 ** 玩意儿,害得我搞了几天,但是最终结果证明,我还是年轻了。。。)
  1. 最终揭秘
  • 开始一步步F11调试,最终发现在Int64.Parse(line.Tostring())时报错"Input string was not in a correct format.",并且是微软报出来的(给CSRedis道歉,立刻,马上。。。),此时line.Tostring()的值是"-1"(下面是CSRedis源码中的片段)

  • 立马在阿拉伯语的环境下,测试了一下Int64.Parse("-1"),果不其然,除此之外Int16.Parse("-1")Int32.Parse("-1")Convert.ToInt64("-1")Convert.ToInt32("-1")等,将负数字符串转成数字的方法,都会报错,这个就是最终结论
  1. 解决办法
  • 现在问题找到了,怎么去解决呢?难道是微软在制裁阿拉伯语人?为啥会有这么的大的bug呢?找了一圈资料,没啥说法
  • 于是请教了杨中科老师,解决办法就是开头说的,使用重载方法加上CultureInfo.InvariantCulture参数,即不匹配任何文化信息,参考官方文档

  1. 探究根本
  • 还是要从CultureInfo说起,其中有一个属性NumberFormat,包含了当前语言的数字格式,可参考官方文档NumberFormatInfo类型中NegativeSign用于定义负号

  • 调试时,发现在阿拉伯语环境下,负号并不是"-",而是"?-",但是又不是中/英文输入法下的问号,应该是有个什么特殊字符,总之,感觉是"-1"在阿拉伯语里面并不是表示-1(如果有学过阿拉伯语的朋友可以解答下)

踩坑总结

  • 表面上看似毫不相关的两个东西,有时候确实能相互影响
  • 问题排查不能停留在表面,要进去
  • 排除法和控制变量法yyds,多用

.NET Core中关于阿拉伯语环境下的坑:Input string was not in a correct format.的更多相关文章

  1. Android简易项目--傻瓜式阿拉伯语输入法(Dummy Arabic Input)

    一.应用名称 Android简易项目--傻瓜式阿拉伯语输入法(Dummy Arabic Input) 二.应用图标 三.应用说明 现在通行的阿拉伯语键盘布局并无规律可循,阿拉伯语使用者需要花费较多时间 ...

  2. java中HashMap在多线程环境下引起CPU100%的问题解决(转)

    最近项目中出现了Tomcat占用CPU100%的情况,原以为是代码中出现死循环,后台使用jstack做了dump,发现是系统中不合理使用HashMap导致出现了死循环(注意不是死锁). 产生这个死循环 ...

  3. java中HashMap在多线程环境下引起CPU100%的问题解决

    最近项目中出现了Tomcat占用CPU100%的情况,原以为是代码中出现死循环,后台使用jstack做了dump,发现是系统中不合理使用HashMap导致出现了死循环(注意不是死锁). 产生这个死循环 ...

  4. Python中logging在多进程环境下打印日志

    因为涉及到进程间互斥与通信问题,因此默认情况下Python中的logging无法在多进程环境下打印日志.但是查询了官方文档可以发现,推荐了一种利用logging.SocketHandler的方案来实现 ...

  5. .NET Core 图片操作在 Linux/Docker 下的坑

    一.前言 .NET Core 目前更新到2.2了,但是直到现在在 .NET Core 本身依然不包括和图片有关的 Image.Bitmap 等类型.对于图片的操作在我们开发中很常见,比如:生成验证码. ...

  6. HttpClient在多线程环境下踩坑总结

    问题现场 在多线程环境下使用HttpClient组件对某个HTTP服务发起请求,运行一段时间之后发现客户端主机CPU利用率呈现出下降趋势,而不是一个稳定的状态. 而且,从程序日志中判断有线程处于han ...

  7. 利用n 升级工具升级Node.js版本及在mac环境下的坑

    一.利用n 升级Node.js 最近在用NPM安装一个nodejs工具时发现,我的nodejs的版本有些旧了.这不是大问题,只要升级就可以了,当然,重新从nodejs.org最新版本是一种方法,但我想 ...

  8. 嵌入式中 动态阿拉伯语字符串 转换 LCD显示字符串【感谢建国雄心】

    本文参考CSDBN:建国雄心 的博客,这里找不到该帖子,放一个类似的仅供参考https://blog.csdn.net/qiaojiongzeng6321/article/details/748572 ...

  9. windows环境vagrant修改静态资源文件,centos虚拟机中nginx的web环境下不生效

    最近上手krpano,本地修改了krpano.html文件或者xml文件,在虚拟机环境打开文件是修改过来了,在nginx中就是不生效. 修改nginx.conf中http{}中的 sendfile  ...

  10. ASP.NET Core中如影随形的”依赖注入”[下]: 历数依赖注入的N种玩法

    在对ASP.NET Core管道中关于依赖注入的两个核心对象(ServiceCollection和ServiceProvider)有了足够的认识之后,我们将关注的目光转移到编程层面.在ASP.NET ...

随机推荐

  1. 用PHPstudy nginx 配置tp6 隐藏访问链接中的index.php

    在server 里面加上如下这个判断就好了 if (!-e $request_filename){ rewrite ^(.*)$ /index.php?s=$1 last; break; 配置在对应网 ...

  2. shell基本命令与参数

    1:一行可以有多个命令,用";"分开 如: cd ..; ls -l 2:先项用"-"开始,多个连接可连在一起,如:ls -lh, 3:"--&quo ...

  3. 大米cms爆破后台及支付逻辑漏洞

    又找到个网站挖洞,我来康康. 大米手机是个什么鬼手机??看一下吧 这个支付页面好熟悉,可能存在支付逻辑漏洞,咱们用burp改个包看看. 先支付一个看看 把包里那个=1改成0试试~ 证实确实存在支付逻辑 ...

  4. Django4全栈进阶之路8 createsuperuser创建超级管理员账号

    在 Django 4 中,可以使用 createsuperuser 命令来创建超级管理员账号.超级管理员拥有管理后台的所有权限,包括创建.编辑和删除用户.组.权限等操作. 下面是创建超级管理员账号的步 ...

  5. Jan 2023-Prioritizing Samples in Reinforcement Learning with Reducible Loss

    1 Introduction 本文建议根据样本的可学习性进行抽样,而不是从经验回放中随机抽样.如果有可能减少代理对该样本的损失,则认为该样本是可学习的.我们将可以减少样本损失的数量称为其可减少损失(R ...

  6. lec-1-Deep Reinforcement Learning, Decision Making, and Control

    What is RL 基于学习的决策的数学形式 从经验中学习决策和控制的方法 Why should we study this now 深度神经网络特征方法 强化学习的提升 计算能力的提升 我们还需要 ...

  7. 企业研发效能度量利器,华为云发布CodeArts Board看板服务

    摘要:华为云CodeArts Board正式上线,欢迎体验. 本文分享自华为云社区<企业研发效能度量利器,华为云发布CodeArts Board看板服务>,作者:华为云头条. 数字化时代, ...

  8. vue项目连接socket.io跨域及400异常处理

    最近看人家用socket.io聊天,于是自己也想打个服务试试,不试不知道,一试吓一跳,原来这里吗还有这么多坑,下面就是所遇的坑,记录一哈,但愿可以帮助到遇到同样的坑的小伙伴 文章目录 一.服务端配置 ...

  9. qq飞车端游最全按键指法教学

    目录 起步篇 超级起步 弹射起步 段位起步 基础篇 点飘 撞墙漂移 撞墙点喷 进阶篇 双喷 叠喷 断位漂移 段位双喷 侧身漂移 快速出弯 CW WCW CWW 牵引 甩尾点飘 甩尾漂移 右侧卡 左侧卡 ...

  10. 在asp.net core web api中添加efcore使用codefirst

    首先创建webapi项目,我这里使用的版本是.net6 在nuget中添加对应的工具包 红框标出来的是对应的数据库扩展包,mysql用mysql版,sqlserver用sqlserver版,选择正确的 ...