VS运行程序正常,发布后查询中文不能正常使用

-----------------------2016年3月3日更新---------------------------------------

发布服务器后,若各层(bll、dal等)传值时使用拼接在方法名上传递,而非使用实体时,出现中文变成“???”乱码。

 环境变量修改:NLS_LANG=SIMPLIFIED CHINESE_CHINA.ZHS16GBK


--------分隔线-----------------------------

首先保证数据库连接等全部正确,但发布后一个查询功能不正常。

在论坛提问后,谢谢回答的前辈

在此留个印记

http://bbs.csdn.net/topics/390885633?page=1#post-398186586

我的是oracle啦,如果是sql server用@哦微笑

原来的程序在接收浏览器传递的参数的时候很有可能出问题,而且转换字符串的时候也有可能出问题,最严重的一个问题是不能防止sql注入。



顺便贴一下改后的全部代码

aspx.cs

protected void Button1_Click(object sender, EventArgs e)
        {
            try
            {
                string name = TextBox1.Text.ToString().Trim();
                DataSet ds = bll.GetAdminRole2(name); 
                if (ds.Tables[0].Rows.Count < 1)
                {             
                    ScriptManager.RegisterStartupScript(this.Page, this.GetType(), "", "alert('无数据!')", true);
                }
                this.RP_Main.DataSource = ds;
                this.RP_Main.DataBind();
                AspNetPager1.Visible = false;

            }
            catch(Exception ex)
            {
                Response.Write("<script language='javascript'>alert(\"" + ex.Message.Replace("\r\n", "") + "\");</script>"); 
            }
        }


BLL.DUser.cs

       public DataSet GetAdminRole2(string lastname)
        {
            return dal.GetAdminRole2(lastname);
        }

DAL.DUser.cs(顺便学习了模糊查找在这里的显示方法)

public DataSet GetAdminRole2(string lastname)
        {
            StringBuilder strSql = new StringBuilder();
            strSql.Append("select u.id,u.loginid,u.lastname,d.departmentname,d.supdepid from oa_user u inner join oa_department d on u.departmentid = d.id ");
            strSql.Append(" where lastname like :lastname");
            OracleParameter[] parameters ={
                       new OracleParameter(":lastname",OracleType.VarChar,60)
                   };
            parameters[0].Value = "%" + lastname + "%";

            return DbHelperOra.Query(strSql.ToString(), parameters);
        }


DBUtility.DbHelperOra

 public static DataSet Query(string SQLString, params OracleParameter[] cmdParms)
        {
            using (OracleConnection connection = new OracleConnection(connectionString))
            {
                OracleCommand cmd = new OracleCommand();
                PrepareCommand(cmd, connection, null, SQLString, cmdParms);
                using (OracleDataAdapter da = new OracleDataAdapter(cmd))
                {
                    DataSet ds = new DataSet();
                    try
                    {
                        da.Fill(ds, "ds");
                        cmd.Parameters.Clear();
                    }
                    catch (System.Data.OracleClient.OracleException ex)
                    {
                        throw new Exception(ex.Message);
                    }
                    return ds;
                }
            }
        }



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值