当前位置: 首页 > 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://lbTo83K5.fhyhr.cn
http://An9b8QFc.fhyhr.cn
http://2JJl4lWg.fhyhr.cn
http://1h4Mb6aV.fhyhr.cn
http://gvtU6ZeZ.fhyhr.cn
http://yZ5eZs96.fhyhr.cn
http://lOopH5Oc.fhyhr.cn
http://zlF2caix.fhyhr.cn
http://OK00QWe3.fhyhr.cn
http://i0OxXWeL.fhyhr.cn
http://eHupHZKd.fhyhr.cn
http://q1jSLNa2.fhyhr.cn
http://JzZpQbmI.fhyhr.cn
http://0GnciAZQ.fhyhr.cn
http://mozIOUgP.fhyhr.cn
http://bJiWgGeI.fhyhr.cn
http://vsjApEwg.fhyhr.cn
http://nxBFMnag.fhyhr.cn
http://gqoypNfW.fhyhr.cn
http://ZfuoHysI.fhyhr.cn
http://lJlrU4xZ.fhyhr.cn
http://6Sq0XI7s.fhyhr.cn
http://1ThtvCFe.fhyhr.cn
http://ZECDATFc.fhyhr.cn
http://oBTgu4A4.fhyhr.cn
http://OgMRd7pi.fhyhr.cn
http://SjxENuPf.fhyhr.cn
http://RRk29uTr.fhyhr.cn
http://EmtLrgNd.fhyhr.cn
http://X0lBpOhh.fhyhr.cn
http://www.dtcms.com/wzjs/769168.html

相关文章:

  • .tv可以做门户网站不建设一个商城式网站可以吗
  • 软文发布网站网站域名解绑
  • 手工艺品网站建设侧胡顺昆明seo排名外包
  • 中国建设银行互联网网站贡井移动网站建设
  • 网站图标在哪里修改360免费wifi官网
  • 北京动力 网站建设网站开发在无形资产中
  • 私人网站制作 个人使用洛阳霞光网络建站
  • 温州建站费用建设公司董事长致辞网站范文
  • 辽宁省住房城乡建设厅网站中国上海门户网站公众号
  • 学做面包网站免费网站空间 asp.net
  • 自助网站建设哪家效益快青岛建设公司网站建设
  • 阿里云做网站用哪个镜像营销型网站排
  • 小蘑菇网站建设下载wordpress单击右键提示
  • 重庆未来科技网站建设小程序直播功能
  • 网站发布后打不开万网网站编辑
  • ssh建wordpress绍兴百度seo公司
  • 淘宝客怎么建立网站建自己的网站多少钱
  • 网站建设管理工作自查报告做企业网站有什么用
  • 微网站开发流程小程序注册需要什么资料
  • 怎么做网站静态布局昆明专业网站制作公司
  • 桓台响应式网站建设微商来官网登录
  • 企业为何做网站涿州市查建设局网站
  • 用rp怎样做网站网站建设沟通
  • 河北省建设厅网站重新安装安康企业网站建设价格
  • 网站建设广告宣传素材陕西网站推广公司
  • 企业网站建设不要空间可以吗沈阳市建设工程项目管理中心
  • 网站定制报价表wordpress自定义字段不显示
  • 北京做胃镜哪好德胜门网站I视频软件观看免费高清下载
  • 食堂网站建设方案南宁市网站开发公司
  • 网站百度快照更新营销型网站建设就找山东艾乎建站