编程中那些防转义和转义的技巧汇总

1. 防止转义的技巧

1.1. XML中的CDATA块

1.2. JSON字符串拼接

1.3. SQL查询拼接

1.4. HTML模板处理

2. 转义的技巧

2.1. URL参数传递

2.2. HTML字符转义

2.3. 正则表达式转义

头条篇幅有限,小编展示部分内容截图,完整版有感兴趣的可以见文末

1.1. XML中的CDATA块

在XML文档中,使用<![CDATA[...]]>块来将特殊字符视为纯文本,防止其被解析为XML标签或实体。这在处理包含代码片段、标签或特殊字符的文本时特别有用。

示例代码1:

 

 

CDATA块以<![CDATA[开头,以]]>结尾,其中的文本内容可以包含任意字符,包括特殊字符如<、>和&等。在CDATA块中,这些特殊字符不会被解析为标签或实体,而是作为纯文本进行处理。

示例代码2:

 

 

这种写法是一种结合了Freemarker模板语法和CDATA块的表达方式。

  1. <![CDATA[...]]>: 这部分是CDATA块的开始和结束标记,用于将其包裹起来。

  2. ${(data.entity)!}:这是Freemarker模板语法的一部分。在模板中,${...}用于插入变量或表达式的值。在这里,data.entity是一个变量或表达式,它的值将被插入到CDATA块中。

  3. ${"]>"}:这也是Freemarker模板语法的一部分。在这里,它插入了一个特殊字符序列">",用于表示CDATA块的结束标记]]>。

综合起来,这个写法的目的是将data.entity的值插入到CDATA块中,并以]]>作为结束标记。这样做的目的可能是确保data.entity的值在XML或XHTML文档中作为纯文本处理,并避免其中的特殊字符被解析为XML标签或实体。

1.2. JSON字符串拼接

在拼接JSON字符串时,使用转义字符,如反斜杠\,来处理特殊字符。例如,使用"来表示双引号,确保其作为字符串的一部分而不是终止符号。

示例代码:

 

 

1.3. SQL查询拼接

在构建SQL查询语句时,使用双单引号''来表示单引号,确保其作为字符串的一部分。这样可以避免SQL解析错误或注入攻击。

示例代码:

 

 

1.4. HTML模板处理

在处理HTML模板时,使用HTML实体编码来转义特殊字符,如<、>、&等。例如,使用<来表示<,确保特殊字符在浏览器中正确显示。

示例代码:

 

 

2. 转义的技巧

2.1. URL参数传递

在将参数作为URL的一部分进行传递时,使用URL编码来转义特殊字符。常见的URL编码方式是使用百分号%加上十六进制表示的字符编码,确保参数值在URL中正确传递。

示例代码:

 

 

2.2. HTML字符转义

在生成HTML内容时,使用特定的字符转义来表示特殊字符,如<、>、&等。这样可以确保生成的HTML文档在浏览器中正确渲染,而不会被解析为HTML标签。

示例代码:

 

 

2.3. 正则表达式转义

在处理正则表达式时,需要对一些特殊字符进行转义,以确保正则表达式能够按预期工作。常见的转义字符包括反斜杠\和方括号[]等。

示例代码:

 

 

小结

在编程中,正确处理特殊字符和特定上下文是至关重要的。防止转义和转义都有各自的应用场景和技巧。在处理XML、JSON、SQL、HTML、URL以及正则表达式等方面,我们需要了解相应的转义规则,并根据实际需求进行处理。这样可以确保生成的内容在目标环境中能够被正确解析、显示和处理,提高代码的可读性、可维护性和安全性。

希望本文提供的示例代码能够帮助读者更好地理解和应用防止转义和转义的编程技巧,在实际开发中处理特殊字符和特定上下文时能够做出准确的决策和处理。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
目录 前言 第1部分 介绍数据库、SQL和JDBC 第1章 关系型数据库 1.1 理解关系型数据库管理系统 1.1.1 关系模型 1.1.2 Codd法则 1.1.3 表、行、列和关键字 1.1.4 主键 1.1.5 外键 1.1.6 关系 1.1.7 视图 1.1.6 范式化 1.2 高级语言 1.2.1 结构化查询语言 1.2.2 数据定义语言 1.2.3 数据处理语言 1.2.4 数据查询语言 1.3 事务管理和事务控制命令 1.3.1 ACID测试 1.3.2 SQL的事务管理 1.4 数据库安全和数据控制语言 1.4.1 管理数据库用户 1.4.2 用户权限 1.4.3 用户组和角色 1.5 数据库体系结构 1.5.1 Java数据对象 1.5.2 两层模型 1.5.3 三层模型 1.6 小结 第2章 设计数据库 2.1 数据库设计应考虑的事项 2.1.1 项目规范 2.1.2 设计表 2.1.3 生成发票 2.2 引用完整性 2.2.1 通用完整性规则 2.2.2 特定于数据库的完整性规则 2.3 小结 第3章 SQL基础 3.1 SQL语言 3.2 SQL数据类型 3.3 数据定义语言 3.3.1 创建、取消、更改数据库和表 3.3.2 创建、更改和取消视图 3.4 数据处理语言 3.4.1 INSERT语句 3.4.2 UPDATE语句 3.4.3 DELETE语句 3.5 数据查询语言 3.5.1 SELECT语句 3.5.2 WHERE子句 3.5.3 SQL运算符 3.5.4 使用子查询 3.6 对查询结果排序 3.7 将查询结果进行汇总 3.7.1 集合函数 3.7.2 使用HAVING子句来筛选组 3.7.3 使用索引提高SQL查询效率 3.7.4 格式化SQL命令 3.7.5 使用SQL连接 3.7.6 编写SQL的JOIN命令 3.7.7 使用UNION运算符进行组合查询 3.8 数据控制语言 3.8.1 管理用户 3.8.2 授予和取消用户权限 3.9 创建和使用存储过程 3.9.1 在存储过程使用输入参数 3.9.2 存储过程使用输出参数 3.10 小结 第4章 JDBC入门 4.1 什么是JDBC 4.2 两层和三层模型 4.2.1 两层模型 4.2.2 三层模型 4.3 SQL的一致性 4.4 JDBC兼容性 4.5 JDBC如何工作 4.5.1 DriverManager 4.5.2 JDBC DataSource 4.5.3 DataSource对象和JNDI 4.5.4 部署和使用DataSource的基本实现 4.6 连接池 4.7 分布式事务处理 4.7.1 分布式事务管理 4.7.2 Connection对象 4.8 SQL语句 4.8.1 Statement对象 4.8.2 PreparedStatement语句 4.8.3 CallableStatement 4.9 事务 4.9.1 事务独立性等级 4.9.2 事务存储点 4.9.3 多线程 4.10 批更新 4.11 ResultSet 4.12 可滚动的ResultSet 4.12.1 创建可滚动的ResultSet 4.12.2 游标控制 4.12.3 将游标移动到指定行 4.12.4 获得游标位置 4.13 可更新的ResultSet 4.13.1 更新ResultSet 4.13.2 插入一新行 4.13.3 删除行 4.14 观察ResultSet的变化 4.15 RowSet对象 4.16 创建RowSet和设置属性 4.16.1 RowSet事件 4.17 元数据 4.17.1 DatabaseMetaData 4.17.2 ResultSetMetaData 4.17.3 ParameterMetaData方法 4.18 SQL数据类型的JDBC映射 4.19 SQL3数据类型 4.19.1 对象关系型数据库 4.19.2 使用SQL3数据类型 4.19.3 创建用户定义的数据类型 4.20 异常和日志 4.20.1 SQLException 4.20.2 SQLWarning 4.20.3 BatchUpdateException 4.20.4 日志 4.21 小结 第2部分 在两层客户/服务器结构使用JDBC和SQL 第5章 使用JDBC和SQL创建表 5.1 创建数据库 5.2 使用表 5.2.1 记录和字段、行和列 5.2.2 SQL数据类型 5.2.3 完整性约束 5.3 创建表 5.4 使用JDBC创建表 5.4.1 DriverManager 5.4.2 驱动程序 5.4.3 连接 5.4.4 Statement 5.5 使用ALTER TABLE改变表 5.6 删除或取消表 5.7 创建基于Swing的表构建器 5.7.1 控制程序 5.7.2 视图 5.7.3 模型 5.8 小结 第6章 插入、更新和删除数据 6.1 使用SQL INSERT插入数据 6.1.1 INSERT语句 6.1.2 使用带有JDBC的INSERT 6.1.3 使用INSERT SELECT 6.2 UPDATE语句 6.2.1 在UPDATE使用经计算的值 6.2.2 UPDATE的常见问题 6.3 带有提交和回滚的事务管理 6.4 DELETE语句 6.5 基于Swing的表编辑器 6.5.1 TableEditFrame 6.5.2 Controller类 6.6 JDBC ResultSetMetaData 6.7 小结 第7章 使用SQL查询检索数据 7.1 SELECT语句 7.1.1 使用WHERE子句 7.1.2 格式化SQL命令 7.2 在较复杂的WHRER子句使用运算符 7.2.1 DISTINCT运算符 7.2.2 TOP运算符 7.2.3 比较运算符 7.2.4 CHAR和VARCHAR运算符 7.2.5 逻辑运算符 7.2.6 算术运算符 7.2.7 混合运算符:IN和BETWEEN 7.2.8 集合运算符 7.3 转义序列 7.4 子查询 7.4.1 使用ANY,SOME和ALL谓词 7.4.2 使用IN和NOT IN谓词 7.4.3 使用EXISTS和NOT EXISTS谓词 7.4.4 嵌套子查询 7.4.5 测试子查询 7.5 子查询的额外用途 7.5.1 在SELECT列表使用子查询 7.5.2 使用带有INSERT命令的子查询 7.5.3 使用带有UPDATE命令的子查询 7.5.4 使用带有DELETE命令的子查询 7.5.5 关联子查询 7.6 JDBC ResultSet 7.6.1 ResultSetMetaData 7.6.2 使用具有JDBC的SELECT来返回RecordSet 7.7 基于Swing的SQL查询面板 7.7.1 View菜单 7.7.2 TableQueryFrame 7.8 JDBC代码 7.9 小结 第8章 组织查询结果和使用索引 8.1 使用ORDER BY对查询结果进行排序 8.2 GROUP BY子句 8.3 聚合函数 8.4 使用HAVING子句筛选组 8.5 使用索引来提高SQL查询的性能 8.6 视图 8.7 小结 第9章 连接和组合查询 9.1 连接表 9.1.1 连接的类型 9.2 键 9.2.1 主键 9.2.2 外键 9.3 使用内连接 9.3.1 使用等连接 9.3.2 使用非等连接 9.4 使用外连接 9.4.1 左外连接 9.4.2 右外连接 9.4.3 全外连接 9.4.4 使用NOT EXISTS 9.5 使用自连接 9.6 使用UNION运算符合并查询 9.6.1 EXCEPT运算符 9.6.2 INTERSECT运算符 9.7 小结 第10章 构建一个客户/服务器应用程序 10.1 使用不同的数据库和驱动程序 10.1.1 扩展的DBManager类 10.2 使用DatabaseMetaData 10.3 检索与数据库相关的信息 10.3.1 在JTree显示DatabaseMetaData 10.4 检索有关RDBMS功能性的信息 10.5 使用ResultSetMetaData 10.6 小结 第3部分 三层Web站点与JDBC 第11章 构建会员Web站点 11.1 设计一个多层系统 11.2 功能性需求 11.3 设计数据库 11.3.1 处理会员登录 11.3.2 会员注册 11.3.3 数据输入 11.3.4 搜索数据库 11.3.5 数据库驱动的电子邮件 11.4 小结 第12章 通过servlet和JSP使用JDBC DataSource 12.1 使用JDBC DataSource 12.2 使用servlet创建动态Web页面 12.2.1 创建一个简单的servlet 12.3 创建和配置Lo9in servlet 12.3.1 实现会员Web站点 12.3.2 创建Login页面 12.3.3 创建servlet 12.3.4 部署 12.4 使用JSP 12.4.1 在JSP使用JavaBean 12.4.2 自动类型转换 12.4.3 创建和部署JDBC LoginBean 12.5 小结 第13章 使用PreparedStatement和CallableStatement 13.1 创建和使用PreparedStatement 13.1.1 创建PreparedStatement对象 13.1.2 在循环使用PrenaredStatement 13.1.3 PreparedStatement返回的值 13.2 创建和使用CallableStatement 13.2.1 创建存储过程 13.2.2 调用存储过程 13.2.3 使用JSP Bean的存储过程 13.2.4 ProcessNABean的作用 13.2.5 错误处理 13.2.6 使用存储过程作为输入和输出参数 13.3 小结 第14章 使用Blob和Clob管理图像和文档 14.1 大对象 14.1.1 使用Blob存储二进制数据 14.1.2 使用Clob存储文本数据 14.2 从浏览器上载图像或文档 14.2.1 用于从DBMS下载大对象的servlet 14.3 小结 第15章 使用JSP,XSL和可滚动的ResultSet显示数据 15.1 可滚动的ResultSet 15.1.1 创建一个可滚动ResultSet 15.1.2 在可滚动ResultSet移动游标 15.1.3 使用可滚动ResultSet创建一个搜索页面 15.2 使用XSL从SQL查询创建网页 15.2.1 XSLT如何工作 15.2.2 从数据库检索的数据作为XML文档 15.2.3 使用XSL样式表转换XML 15.2.4 在JSP页面使用XSL转换 15.3 使用具有XSL样式表的可更新ResultSet 15.4 小结 第16章 使用JDBC驱动的JavaMail API 16.1 使用电子邮件协议 16.1.1 MIME协议 16.1.2 SMTP协议 16.1.3 POP协议 16.2 使用JavaMail API 16.3 使用JDBC驱动的JavaMail发送电子邮件信息 16.3.1 使用JSP页面和JavaMail发送电子邮件 16.3.2 使用有SendMailBean的JSP页面 16.3.3 部署 16.4 使用JavaMail API接收电子邮件 16.5 小结 第4部分 数据库、JDBC和XML 第17章 XML文档对象模型和JDBC 17.1 XML与HTML 17.2 XML和文档对象模型 17.2.1 XML标题 17.2.2 标记和属性 17.2.3 元素和节点 17.3 使用Java XML API——Xerces和JDOM 17.4 将Xbean作为可插入的XML处理模块 17.5 查询数据库创建XML文档 17.6 XML数据源填充数据库 17.7 小结 第18章 用RowSet显示数据 18.1 理解RowSet 18.1.1 创建和应用RowSet 18.1.2 使RowSet可滚动和可更新 18.1.3 更新RowSet 18.1.4 插入新行 18.1.5 删除行 18.1.6 查看可更新RowSet所做的修改 18.1.7 RowSet事件 18.2 未连接的RowSet 18.2.1 在PDA使用CachedRowSet 18.2.2 客户端代码 18.3 根据RowSet生成XML 18.4 小结 第19章 用SQL访问XML文档 19.1 用SQL访问XML文档的原因 19.2 创建可访问JDBC的XML DBMS 19.2.1 实现基类 19.2.2 实现JDBC类 19.2.3 XMLResultSet 19.2.4 实现SQL引擎 19.2.5 测试JDBC/XML数据库 19.3 小结 第5部分 EJB、数据库和持久性 第20章 EJB 20.1 EJB简述 20.2 会话bean 20.2.1 无状态会话Bean 20.2.2 无状态会话Bean 20.3 实体Bean 20.3.1 主键 20.3.2 持久性存储 20.4 消息驱动bean 20.5 EJB事务 20.5.1 容器管理的事务 20.5.2 bean管理的事务 20.6 小结 第21章 bean管理的持久性 21.1 实体对象持久性 21.2 bean管理的持久性 21.2.1 主键 21.2.2 通过实体bean创建和删除实体对象 Z1.2.3 查找实体对象 21.2.4 bean实例变量的同步和持久性对象的状态 Z1.2.5 业务方法 21.3 BMP实体bean示例——MemberEJB 21.4 使用值对象获得更佳性能 21.5 小结 第22章 容器管理的持久性 22.1 CMP实体bean——EJB 2.0之后的新生品 22.2 CMP EJB开发 22.2.1 主接口和远程接口 22.2.2 用最少的代码实现类 22.3 EJB查询语言 22.4 运行示例应用程序 22.5 容器管理的关系 22.5.1 关系字段 22.5.2 关系的基数和方向 22.5.3 访问关系字段 22.6 小结 第23章 Java数据对象和透明持久性 23.1 JDO的透明持久性 23.2 什么使JDO成为独特的持久性机制 23.3 主要的JDO API 23.3.1 PersistenceCapable接口 23.3.2 PersistenceManagerFactory接口 23.3.3 PersistenceManager接口 23.3.4 Query接口 23.3.5 Transaction接口 23.4 测试客户示例 23.5 对复杂域对象模型的支持 23.6 JDO应用程序开发过程 23.7 JDO与J2EE框架集成 23.8 小结 第6部分 数据库管理 第24章 用户管理和数据库的安全性 24.1 组、用户和角色 24.1.1 对组进行操作 24.1.2 对用户进行操作 24.2 理解数据库模式 24.3 管理模式 24.4 用户权限 24.5 用户角色 24.5.1 所有权限 24.5.2 GRANT命令 24.5.3 REVOKE命令 24.6 小结 第25章 性能调整 25.1 数据库调整 25.1.1 语句调整 25.1.2 调整连接 25.1.3 调整索引 25.2 修改数据库方案 25.2.1 范式化 25.2.2 反向范式化 25.2.3 多数据表 25.3 产生冗余数据 25.4 使用导出列和导出表 25.5 数据划分 25.5.1 水平划分 25.5.2 垂直划分 25.6 使用视图 25.7 持续监控 25.8 小结 附录A SQL语法简明指南 附录B 安装Apache和Tomcat

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值