主页 > 知识库 > 数据库SqlParameter 的插入操作,防止sql注入的实现代码

数据库SqlParameter 的插入操作,防止sql注入的实现代码

热门标签:科大讯飞语音识别系统 电子围栏 阿里云 团购网站 银行业务 Linux服务器 Mysql连接数设置 服务器配置

例子:  点击Button1按钮的时候就把数据插入数据库中。

复制代码 代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Text;
using System.Data.SqlClient;
using System.Data;
using System.Configuration;

namespace ParaMeter
{
    public partial class Test : System.Web.UI.Page
    {
        private string connectionStr;  //链接数据库的字符串
        private SqlConnection conDB;   //数据库的链接
        private SqlTransaction _trans; //事务对象

        protected void Page_Load(object sender, EventArgs e)
        {
            //connectionStr = ConfigurationSettings.AppSettings["constr"];
            connectionStr = "server=10.11.43.189\\SQL2008;database=OA_WEB_DB;uid=sa;pwd=123456";
            conDB = new SqlConnection(connectionStr);
        }

        protected void Button1_Click(object sender, EventArgs e)
        {
            StringBuilder strSql = new StringBuilder();
            strSql.Append("INSERT INTO [OA_WEB_DB].[dbo].[OA_RT_FileType]([FileTypeName],[Deleted])");
            strSql.Append("VALUES(@fileName,@delete)");
            SqlParameter[] parameters = {
                                 new SqlParameter("@fileName", SqlDbType.NVarChar,100),
                                 new SqlParameter("@delete",SqlDbType.Bit),

                             };
            parameters[0].Value = "文件类型";
            parameters[1].Value = false;
          bool IsSucc =   ExecUpdateSql(strSql.ToString(), parameters);
          if (IsSucc)
          {
             Label1.Text =  "插入成功";
          }
          else
          {
              Label1.Text = "插入失败";
          }

        }
        /// 执行一条更新语句
        /// /summary>
        /// param name="SQLString">需要执行的SQL语句。/param>
        /// param name="cmdParms">执行参数数组/param>
        /// returns>成功返回True,失败返回False。/returns>
        private bool ExecUpdateSql(string SQLString, params SqlParameter[] cmdParms)
        {
            using (SqlCommand cmd = new SqlCommand())
            {
                try
                {
                    PrepareCommand(cmd, conDB, _trans, SQLString, cmdParms);
                    int iret = cmd.ExecuteNonQuery();
                    return true;
                }
                catch (System.Data.SqlClient.SqlException e)
                {
                    return false;
                }
            }
        }
        private void PrepareCommand(SqlCommand cmd, SqlConnection conn, SqlTransaction trans, string cmdText, SqlParameter[] cmdParms)
        {
            if (conn.State != ConnectionState.Open)
                conn.Open();
            cmd.Connection = conn;
            cmd.CommandText = cmdText;
            if (trans != null)
                cmd.Transaction = trans;
            cmd.CommandType = CommandType.Text;//cmdType;
            if (cmdParms != null)
            {
                foreach (SqlParameter parameter in cmdParms)
                {
                    if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input)
                        (parameter.Value == null))
                    {
                        parameter.Value = DBNull.Value;
                    }
                    cmd.Parameters.Add(parameter);
                }
            }
        }

    }
}

您可能感兴趣的文章:
  • asp.net 防止SQL注入攻击
  • SQL注入中绕过 单引号 限制继续注入
  • asp.net下检测SQL注入式攻击代码
  • asp.net 预防SQL注入攻击之我见
  • asp.net利用HttpModule实现防sql注入
  • asp.net(C#)防sql注入组件的实现代码
  • SQL数据库的高级sql注入的一些知识
  • 在Global.asax文件里实现通用防SQL注入漏洞程序(适应于post/get请求)
  • c#.net全站防止SQL注入类的代码
  • C#防SQL注入代码的三种方法
  • 防御SQL注入的方法总结
  • ASP.NET过滤类SqlFilter,防止SQL注入

标签:江苏 大理 衢州 广元 衡水 枣庄 萍乡 蚌埠

巨人网络通讯声明:本文标题《数据库SqlParameter 的插入操作,防止sql注入的实现代码》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266