Drupal专业开发指南 第20章 动态查询语句

g089h515r806 的头像
Submitted by g089h515r806 on 星期四, 2009-08-27 13:15

如果在你的SQL中,有多个只有在运行时才能确定的变量,这并不妨碍让你使用占位符。你将需要使用占位符比如'%s' 或者 %d,通过编程来创建你的SQL,接着你需要传递一组值来填充这些占位符。如果你自己直接调用db_escape_string(),那么你就做错了。下面的例子展示了占位符的使用,这里假定我们想取出,匹配特定节点类型的已发布节点的ID和标题:

Drupal版本:

Drupal专业开发指南 第20章 安全的处理URLs

g089h515r806 的头像
Submitted by g089h515r806 on 星期四, 2009-08-27 13:08

模块常常处理用户提交的URLs并显示它们。我们需要一些机制来确保用户提供的值确实是一个合法的URL。Drupal提供了函数check_url(),它实际上是仅仅对filter_xss_bad_protocol()做了封装。它通过检查来确保URL中的协议是该Drupal站点所允许的协议(参看“使用filter_xss()阻止跨站点脚本攻击”部分的第5步),并使用check_plain()来处理URL。

Drupal版本:

Drupal专业开发指南 第20章 使用filter_xss_admin()

g089h515r806 的头像
Submitted by g089h515r806 on 星期四, 2009-08-27 13:06

有时你想让你的模块为后台管理页面生成HTML。由于我们对后台管理页面进行了访问控制,所以我们可以假定这些可以访问后台管理页面的用户比普通用户更可信。你可以为后台管理页面建立一个特定的过滤器并使用过滤器系统,但是这有点麻烦。因此,Drupal提供了函数filter_xss_admin()。它使用一组更加自由的可用标签列表,简单的对filter_xss()做了封装,除了<script> 和 <style>标签以外,它包含了所有的其它标签。使用它的一个例子是在主题中展示站点的宗旨(mission):

Drupal版本:

页面

Subscribe to Think in Drupal RSS