123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235 |
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8">
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=0" />
- <title>引用通告类 - CodeIgniter 中文手册|用户手册|用户指南|Wiki文档</title>
- <link rel="shortcut icon" href="http://codeigniter.org.cn/user_guide/../images/design/favicon.ico" type="image/x-icon" />
- <link rel="stylesheet" type="text/css" media="all" href="../userguide.css" />
- <link rel="search" href="http://codeigniter.org.cn/user_guide/../CodeIgniterSearch.xml" type="application/opensearchdescription+xml" title="CodeIgniter 搜索"/>
- <link rel="canonical" href="http://codeigniter.org.cn/user_guide/libraries/trackback.html" />
- <script type="text/javascript" src="../nav/mootools.js-ver=20130324.js"></script>
- <script type="text/javascript" src="../nav/mootools-more.js-ver=20130324.js"></script>
- <script type="text/javascript" src="../nav/nav.js-ver=20130324.js"></script>
- <script type="text/javascript" src="../nav/user_guide_menu.js-ver=20130324.js"></script>
- <meta name="robots" content="all" />
- <meta name="author" content="ExpressionEngine Dev Team" />
- <meta name="description" content="CodeIgniter 中文手册, CodeIgniter 用户指南, CodeIgniter User Guide, Wiki 文档" />
- </head>
- <body>
- <!-- START NAVIGATION -->
- <div id="nav">
- <div id="nav_inner">
- <script type="text/javascript">create_menu('../');</script>
- </div>
- </div>
- <script type="text/javascript">_setNavigation();</script>
- <div id="nav2"><a name="top"></a><a href="javascript:void(0);" onclick="myHeight.toggle();"><img src="../images/nav_toggle_darker.jpg" width="154" height="43" border="0" title="切换目录" alt="切换目录" /></a></div>
- <div id="masthead" class="clearfix">
- <div class="topbar-hd"><h1>CodeIgniter 用户指南 版本 2.2.0</h1></div>
- <div class="topbar-tip">编辑文档、查看近期更改请 <a href="#">登录</a> 或 <a href="#">注册</a> <a href="#">找回密码</a></div> <div id="breadcrumb_right"><a href="../toc.html">目录页</a></div>
- </div>
- <!-- END NAVIGATION -->
- <!-- START BREADCRUMB -->
- <table cellpadding="0" cellspacing="0" border="0" style="width:100%">
- <tr>
- <td id="breadcrumb">
- <a href="#" target="_blank">CodeIgniter 中国首页</a> ›
- <a href="../index.html">用户指南首页</a> › 引用通告类 </td>
- <td id="searchbox">
- <form method="get" action="http://www.google.com.hk/search" target="google_window">
- <input type="hidden" name="client" value="pub-0176846097796333"></input>
- <input type="hidden" name="forid" value="1"></input>
- <input type="hidden" name="ie" value="UTF-8"></input>
- <input type="hidden" name="oe" value="UTF-8"></input>
- <input type="hidden" name="as_sitesearch" id="as_sitesearch" value="codeigniter.org.cn/user_guide/" />
- 搜索用户指南
- <input type="text" class="input" style="width:200px;" name="q" id="q" size="31" maxlength="255" value="" />
-
- <input type="submit" class="submit" name="sa" value="Go" />
- </form>
- </td>
- </tr>
- </table>
- <!-- END BREADCRUMB -->
- <div style="clear:both;text-align:right;padding: 6px 40px 0 0;">
- <a href="#" target="_blank">查看原文</a>
- </div>
- <!--<br clear="all" />--><!-- START CONTENT -->
- <div id="content">
- <h1>引用通告类</h1>
- <p>这个类提供了一组函数使你能够发送和接收引用通告的数据.</p>
- <p>如果你对引用通告不太熟悉的话可以在<a href="#">这里</a>查看更多的信息.</p>
- <h2>初始化类</h2>
- <p>和其它大多数类一样,Trackback 类 也是使用<dfn>$this->load->library</dfn> function:</p>
- <code>$this->load->library('trackback');</code>
- <p>加载完毕后,Trackback 对象就能够用: <dfn>$this->trackback</dfn>方式使用.</p>
- <h2>发送引用通告(Trackbacks)</h2>
- <p>引用通告可以从任何控制器函数中使用与示例相似的代码来发送:</p>
- <code>$this->load->library('trackback');<br />
- <br />
- $tb_data = array(<br />
- 'ping_url' => 'http://example.com/trackback/456',<br />
- 'url' => 'http://www.my-example.com/blog/entry/123',<br />
- 'title' => 'The Title of My Entry',<br />
- 'excerpt' => 'The entry content.',<br />
- 'blog_name' => 'My Blog Name',<br />
- 'charset' => 'utf-8'<br />
- );<br />
- <br />
- if ( ! $this->trackback->send($tb_data))<br />
- {<br />
- echo $this->trackback->display_errors();<br />
- }<br />
- else<br />
- {<br />
- echo 'Trackback was sent!';<br />
- }</code>
- <p>数组数据说明:</p>
- <ul>
- <li><strong>ping_url</strong> - 你想要发送引用通告的站点的URL。要把引用通告发送至多个URL,请将这些URL用逗号分隔开来。</li>
- <li><strong>url</strong> - 能够浏览到你站点上的博客日志的URL。</li>
- <li><strong>title</strong> - 你的博客日志的标题。</li>
- <li><strong>excerpt</strong> - 你的博客日志的内容。说明:引用通告类只会自动地发送日志内容的前500个字符。它还会去除所有的HTML。</li>
- <li><strong>blog_name</strong> - 你的博客的名称。</li>
- <li><strong>charset</strong> - 你的博客所使用的字符编码。如果省略,将会默认使用UTF-8。</li>
- </ul>
- <p>根据发送的成功与否,引用通告发送函数将分别返回 TRUE/FALSE(布尔值)。如果发送失败,你可以通过下面的方式获取到错误信息:</p>
- <code>$this->trackback->display_errors();</code>
- <h2>接收引用通告</h2>
- <p>在接收引用通告之前你必须得创建一个博客。如果你连博客都没有,那就没有必要继续下去了。</p>
- <p>接收引用通告要比发送复杂一点,这仅仅是因为你将需要一个数据表来存储它们,而且你还得验证发送过来的引用通告数据。我们鼓励你去实现一个完整的验证过程,目的是防范垃圾信息和重复数据。你也许还想限制某个给定的时间范围内某个特定IP所能发送给你的引用通告数量,这样可以防范今后的垃圾邮件。接收引用通告的处理过程是很简单的;只不过验证过程占用了大部分的工作量。</p>
- <h2>你的 Ping URL</h2>
- <p>为了接受引用通告,你必须在每个博客日志旁边显示一个引用通告URL。这就是人们向你发送引用通告时用到的URL(我们把这个称为你的"Ping URL")。</p>
- <p>你的Ping URL必须指向一个包含了引用通告接收代码的控制器,而且URL也必须包含每个特定的日志条目的ID,因此当你接收到引用通告的时候,你就能够将它与某篇日志关联起来。</p>
- <p>例如,如果你的控制器类叫做 <dfn>Trackback</dfn>,接收函数叫做 <dfn>receive</dfn>,那么你的Ping URL看起来应该是这样的:</p>
- <code>http://example.com/index.php/trackback/receive/<samp>entry_id</samp></code>
- <p>其中 <samp>entry_id</samp> 代表了你的每篇日志单独的ID号。</p>
- <h2>创建一个引用通告表</h2>
- <p>在接收引用通告之前你必须创建一个表来存储它们。 下面是表的基础原型:</p>
- <textarea class="textarea" style="width:100%" cols="50" rows="13">
- CREATE TABLE trackbacks (
- tb_id int(10) unsigned NOT NULL auto_increment,
- entry_id int(10) unsigned NOT NULL default 0,
- url varchar(200) NOT NULL,
- title varchar(100) NOT NULL,
- excerpt text NOT NULL,
- blog_name varchar(100) NOT NULL,
- tb_date int(10) NOT NULL,
- ip_address varchar(16) NOT NULL,
- PRIMARY KEY `tb_id` (`tb_id`),
- KEY `entry_id` (`entry_id`)
- );</textarea>
- <p>引用通告规范只需要发送四部分信息(url,title,excerpt,blog_name)到引用通告,但是为了使数据更有用,我们在上面的数据表架构中添加了一些字段(日期、IP地址等等)。</p>
- <h2>处理一个引用通告</h2>
- <p>这里有一个关于如何接收和处理引用通告的范例。下面这些代码应该被用在你要接收引用通告的控制器函数里面。</p>
- <code>$this->load->library('trackback');<br />
- $this->load->database();<br />
- <br />
- if ($this->uri->segment(3) == FALSE)<br />
- {<br />
- $this->trackback->send_error("Unable to determine the entry ID");<br />
- }<br />
- <br />
- if ( ! $this->trackback->receive())<br />
- {<br />
- $this->trackback->send_error("The Trackback did not contain valid data");<br />
- }<br />
- <br />
- $data = array(<br />
- 'tb_id' => '',<br />
- 'entry_id' => $this->uri->segment(3),<br />
- 'url' => $this->trackback->data('url'),<br />
- 'title' => $this->trackback->data('title'),<br />
- 'excerpt' => $this->trackback->data('excerpt'),<br />
- 'blog_name' => $this->trackback->data('blog_name'),<br />
- 'tb_date' => time(),<br />
- 'ip_address' => $this->input->ip_address()<br />
- );<br />
- <br />
- $sql = $this->db->insert_string('trackbacks', $data);<br />
- $this->db->query($sql);<br />
- <br />
- $this->trackback->send_success();</code>
- <h4>说明:</h4>
- <p>条目ID号应该出现在你的URL的第三段中。这个的依据是我们之前给出的URI范例:</p>
- <code>http://example.com/index.php/trackback/receive/<samp>entry_id</samp></code>
- <p>注意 entry_id 位于URI的第三段,这样你就可以通过下面这种方式获取到它:</p>
- <code>$this->uri->segment(3);</code>
- <p>在上面的引用通告接收代码中,如果缺少第三段,我们将发出错误警告。缺少有效的条目ID,也就没有理由继续下去了。</p>
- <p> <dfn>$this->trackback->receive()</dfn> 函数只是一个简单的验证函数,作用是检查输入的数据以确保其中包含了必需的四部分数据(url, title, excerpt, blog_name)。如果成功则返回 TRUE,失败则返回 FALSE。如果失败,你将看到一条错误信息。</p>
- <p>可以使用下面的函数获取输入的引用通告数据:</p>
- <code>$this->trackback->data('<var>item</var>')</code>
- <p>其中 <var>item</var> 代表这四部分信息中的一部分: url, title, excerpt, 或者 blog_name。</p>
- <p>如果引用通告数据被成功地接收,你将可以使用下面的方式获取到一条成功信息:</p>
- <code>$this->trackback->send_success();</code>
- <p class="important"><strong>注意:</strong> 上面的代码不包含数据验证,那正是我们鼓励你去添加的。</p><p> </p>
- <div id="Contributors">
- 翻译贡献者:
- Drice, Hex, shnwqshnwq, yinzhili</div>
- <div id="DocDate">
- 最后修改: 2010-11-10 11:48:26</div>
- </div>
- <!-- END CONTENT -->
- <div id="footer">
- <p>
- 上一个主题: <a href="sessions.html">Session 类</a> · <a href="#top">页首</a>
- · <a href="../index.html">用户指南首页</a> · 下一个主题: <a href="parser.html">模板解析器类</a> </p>
- <p><a href="#">CodeIgniter</a> · 版权所有 © 2006-2013 · <a href="#">Ellislab, Inc.</a></p>
- <p>中文化: <a href="#">CodeIgniter 中国</a> · 制作: Hex · 版本: 1.30 · 鸣谢: 子非鱼</p>
- </div>
- </body>
- </html>
|