6

当我尝试对用户进行身份验证时,我经常遇到以下错误:

ERROR [HY000] [Informix .NET provider]Inexact character conversion during translation.

 public static int IsValidPortalUser(string p_u, string p_p)
        {
            int ret = 0;
            using (IfxConnection conn = new IfxConnection(connectionString))
            {
                IfxCommand DBCmd = new IfxCommand();
                String p = My_Decryption_2(p_p);
                try
                {
                    if (conn.State == ConnectionState.Closed)
                        conn.Open();
                    DBCmd = new IfxCommand();
                    DBCmd.Connection = conn;
                    DBCmd.CommandText = "SELECT nvl(emp_num,0) FROM emp_mas_queue WHERE username = ? AND DECRYPT_CHAR(password, 'XXXXXX') = ? ";
                    DBCmd.Parameters.Add("user_name", p_u);
                    DBCmd.Parameters.Add("password", p);
                    using (IfxDataReader dataReader = DBCmd.ExecuteReader())
                    {
                        if (dataReader.Read())
                        {
                            if (dataReader[0] != null && !string.IsNullOrEmpty(dataReader[0].ToString()))
                            {
                                ret = int.Parse(dataReader[0].ToString());
                            }
                        }
                        dataReader.Close();

                    }
                }
                catch (ThreadAbortException e)
                {

                }
                catch (ApplicationException e)
                {

                }
                conn.Close();

                return ret;
            }
        }
4

2 回答 2

3

我相信这可能是编码的问题。

我找到了这篇文章(通过谷歌翻译翻译)

关联

它通常是由人们从具有不同编码的来源复制+粘贴他们的详细信息引起的。在处理之前尝试将字符串转换为您正在使用的任何代码页。

于 2012-08-29T21:00:00.570 回答
2

由于这是 stackoverflow 中唯一提到此错误的地方,我将补充说,我通过在连接字符串级别指定 DB_LOCALE 和 CLIENT_LOCALE 解决了类似的问题,确保两者相同并且对应于数据库 DB_LOCALE。

修改环境变量不起作用。

我必须说它是在具有以下客户端版本的 Windows 10 系统上:clientsdk.4.10.TC6DE.WIN

于 2016-07-20T11:20:44.157 回答