当前位置: 首页 > wzjs >正文

网站付费推广方式陕西网站建设报价

网站付费推广方式,陕西网站建设报价,未央免费做网站,公司网站建设注意事项这段代码使用了 C# 的 字符串插值($) 和 逐字字符串() 功能,并在 SQL 语句中动态拼接变量。下面详细解释它们的用法: 1. $(字符串插值) $ 是 C# 的 字符串插值 符号,允许…

这段代码使用了 C# 的 字符串插值($逐字字符串(@ 功能,并在 SQL 语句中动态拼接变量。下面详细解释它们的用法:


1. $(字符串插值)

$ 是 C# 的 字符串插值 符号,允许在字符串中直接嵌入表达式(用 {} 包裹),例如:

string name = "Alice";
string message = $"Hello, {name}!"; // 输出:Hello, Alice!

在 SQL 语句中,$ 用于动态插入变量值,如 {level}{GetNextSortOrder(parentId)} 等。


2. @(逐字字符串)

@ 是 C# 的 逐字字符串 符号,它会:

  • 忽略转义字符(如 \n\t 等)
  • 允许字符串跨多行(适合 SQL 语句)
  • 保留所有空格和换行

例如:

string sql = @"SELECT *FROM UsersWHERE Id = 1";

如果不加 @,换行符需要用 \n 表示,而加了 @ 后可以直接换行。


3. $@(同时使用)

$@ 结合了两种功能:

  • @ 允许 SQL 语句跨多行
  • $ 允许在字符串中插入变量

所以:

string strsql = $@"INSERT INTO System (PID, Level, SortOrder, Name, remark, CreatedTime, ModifiedTime)VALUES (...)
";

这样既保持了 SQL 语句的可读性,又能动态插入变量。


4. {(level == 3 ? $"'{editForm.Target.Replace("'", "''")}'" : "NULL")} 解释

这段代码是一个 嵌套的三元运算符 + 字符串插值,用于动态生成 SQL 语句中的 remark 字段值:

  • level == 3:检查当前节点是否是第 3 级(可能是菜单项)
    • 如果是,则:
      • editForm.remark.Replace("'", "''"):对 remark 字符串进行 SQL 转义(单引号 ' 替换成 '',防止 SQL 注入)
      • $"'{...}'":用单引号包裹(因为 SQL 字符串需要用 ' 括起来)
    • 如果不是(level != 3),则直接插入 NULL(SQL 的 NULL 值,不加引号)

示例

假设:

  • level = 3
  • editForm.remark= "admin/home"

则生成的 SQL 部分:

remark= 'admin/home'

如果 level = 2,则:

remark= NULL

5. 完整 SQL 拼接示例

假设:

  • parentId = 1
  • level = 3
  • editForm.NodeName = "Admin Page"
  • editForm.remark = "admin/home"

生成的 SQL 语句:

INSERT INTO System
(PID, Level, SortOrder, Name, remark, CreatedTime, ModifiedTime)
VALUES (1,3,1,  -- 假设 GetNextSortOrder(parentId) 返回 1'Admin Page','admin/home',GETDATE(),GETDATE()
)

6. 安全性注意事项

虽然这种拼接方式方便,但存在 SQL 注入风险(如果 NodeNameTarget 等来自用户输入)。更安全的方式是使用 参数化查询(如 SqlCommand.Parameters):

using (var cmd = new SqlCommand(@"INSERT INTO System (PID, Level, SortOrder, Name, remark, CreatedTime, ModifiedTime)VALUES (@PID, @Level, @SortOrder, @Name, @remark, GETDATE(), GETDATE())", connection))
{cmd.Parameters.AddWithValue("@PID", parentId ?? (object)DBNull.Value);cmd.Parameters.AddWithValue("@Level", level);cmd.Parameters.AddWithValue("@SortOrder", GetNextSortOrder(parentId));cmd.Parameters.AddWithValue("@Name", editForm.NodeName);cmd.Parameters.AddWithValue("@remark", level == 3 ? editForm.Target : (object)DBNull.Value);cmd.ExecuteNonQuery();
}

这样可以有效防止 SQL 注入攻击。


文章转载自:

http://ywLSN1jR.zsrdp.cn
http://XlkKXlAZ.zsrdp.cn
http://AtRTfc1P.zsrdp.cn
http://D309t7bM.zsrdp.cn
http://fR7ISDZ4.zsrdp.cn
http://xFWuw79D.zsrdp.cn
http://jzw4AUk9.zsrdp.cn
http://i7Jxy3ti.zsrdp.cn
http://7UlZ5Tqc.zsrdp.cn
http://IdL1vjgp.zsrdp.cn
http://zab7phIO.zsrdp.cn
http://HyECeODY.zsrdp.cn
http://3dCRIxVk.zsrdp.cn
http://W39oSaTk.zsrdp.cn
http://rKiIzjjT.zsrdp.cn
http://1EUykUzd.zsrdp.cn
http://Z2YGg5Zw.zsrdp.cn
http://6b3JGtHX.zsrdp.cn
http://IzIwiBL6.zsrdp.cn
http://fdILrLxq.zsrdp.cn
http://9Tp2nJ15.zsrdp.cn
http://Tk2MVeK6.zsrdp.cn
http://bn5yW2vV.zsrdp.cn
http://waHVI3ee.zsrdp.cn
http://60GmRa7a.zsrdp.cn
http://Bdv0mogi.zsrdp.cn
http://jZy1IyQV.zsrdp.cn
http://dCJoix3S.zsrdp.cn
http://URhJkXoN.zsrdp.cn
http://f4KAaiuv.zsrdp.cn
http://www.dtcms.com/wzjs/767653.html

相关文章:

  • 奉贤做网站价格服务平台管理系统
  • 用别人的二级域名做网站wordpress导航图标代码
  • 哪些网站是php做的品牌网站建设十小蝌蚪
  • 有什么好的免费网站做教育宣传网络哪里能接活做网站
  • 怎么做淘宝网站深圳营销型网站建设优化
  • wordpress怎么搭建分享网站怎样解除拦截网站设置
  • 网站建设推广工资盗墓笔记wordpress小说主题
  • 团支部智慧团建网站湖南长沙有什么好玩的地方
  • 电子商务网站建设思维导图环球军事最新消息
  • 东莞网站建设报价方案做流量网站
  • 电商网站设计网络服务创意设计app
  • 巫山做网站那家好免费的微商城平台
  • 拼多多网站建设框架图权重6网站怎么做
  • 网站做301好不好想自己做一个网站应该怎么弄
  • 光谷做网站推广做棋牌辅助网站
  • 电话做网站的推广宿迁手机网站开发公司电话
  • 大型网站建设建站模板旅游软件排行榜前十名
  • 泉州网站建设优化公司wordpress 分类 php
  • 优秀品牌网站案例分析胶州国际网站建设效果
  • 什么叫网站地图网站一键收录
  • 百度手机模板网站张家界商城网站开发设计
  • 织梦做的网站后台怎么进wordpress邮件验证码
  • 影院网站怎么做学校建设服务网网站建设方案项目书
  • 襄樊网站开发深圳经济最新新闻
  • 孟津网站开发公明网站制作
  • 网站空间租用有哪些服务软件推广赚钱一个30
  • 网站透明导航代码关键词优化排名易下拉系统
  • 微信注册网站专业网站设计制作
  • 漳州正规网站建设wordpress的mvc
  • 网站建设服务器一般多少钱设计 网站 现状