zoukankan      html  css  js  c++  java
  • 防sql注入

    Oracle防sql注入的方法:

    public JsonResult Query(string data)
    {

    OracleParameter
    //定义sql语句
    string sql =“SELECT * FROM TABLE  ”;
    //定义条件
    string where = " 1=1";

    List<OracleParameter> paList = new List<OracleParameter>();

    where += " AND BILL_NO=:BILL_NO";
    OracleParameter p = new OracleParameter(":BILL_NO", BILL_NO);
    paList.Add(p);

    OracleParameter[] paras = paList.ToArray();

    //查询方法
    DataSet ds = DbHelperOra.Query(sql, paras);

    }

            // DbHelperOra:数据访问基础类(基于Oracle)  用户可以修改满足自己项目的需要。

            //数据库连接字符串(web.config来配置),可以动态更改connectionString支持多数据库.        
            public static string connectionString = ConfigurationManager.ConnectionStrings["ConnectionHK"].ToString();
            // 执行查询语句,返回DataSet
            public static DataSet Query(string SQLString,params OracleParameter[] cmdParms)
            {
                LoggerHelper.waitLog(SQLString, cmdParms, "select");
                using (OracleConnection connection = new OracleConnection(connectionString))//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)
                        {
                            LoggerHelper.waitLog(ex.Message + SQLString, null, "Error");
                            throw new Exception(ex.Message);
                        }            
                        return ds;
                    }                
                }            
            }

            private static void PrepareCommand(OracleCommand cmd,OracleConnection conn,OracleTransaction trans, string cmdText, OracleParameter[] cmdParms)
            {
                if (conn.State != ConnectionState.Open)//ConnectionState(枚举):描述与数据源的连接的当前状态。
                    conn.Open();
                cmd.Connection = conn;
                cmd.CommandText = cmdText;
                if (trans != null)
                    cmd.Transaction = trans;
                cmd.CommandType = CommandType.Text;//cmdType;CommandType(枚举)指定如何解释命令字符串。
                if (cmdParms != null)
                {
                    foreach (OracleParameter parm in cmdParms)
                        cmd.Parameters.Add(parm);
                }
            }

  • 相关阅读:
    (五)串口通讯方式设置
    (四)计算机上电自启动
    (三)磁盘分区
    (一)老毛桃U盘启动盘制作
    (二)操作系统安装
    计算机常见问题1:计算机网口问题
    Java日志打印方法
    MySQL数据库常见问题1:关于 “ MySQL Installer is running in Community mode ” 的解决办法
    窥见云技术未来大势,腾讯云Techo开发者大会即将在京召开
    揭秘国庆阅兵直播背后的黑科技,腾讯云提供技术支持
  • 原文地址:https://www.cnblogs.com/guangfangxiaokeai/p/12674362.html
Copyright © 2011-2022 走看看