codecamp

CodeIgniter4 创建新闻项目

你现在知道如何使用CodeIgniter从数据库读取数据,但你尚未向数据库写入任何信息。在本节中,你将扩展之前创建新的控制器和模型以包含此功能。

创建表格

要将数据输入数据库,你需要创建一个表格,你可以在其中输入要存储的信息。这意味着你将需要一个包含两个字段的表格,一个用于标题,另一个用于文本。你将从模型中的标题中获得slug。在application / Views / news / create.php创建新视图

  <h2><?= esc($title); ?></h2>


  <?= \Config\Services::validation()->listErrors(); ?>


  <?= form_open('news/create'); ?>


      <label for="title">Title</label>
      <input type="input" name="title" /><br />


      <label for="text">Text</label>
      <textarea name="text"></textarea><br />


      <input type="submit" name="submit" value="Create news item" />


  </form>

这里只有两个函数你可能不熟悉:form_open()函数和ConfigServices::validation()->listErrors()函数。 第一个函数由form helper提供,并呈现表格元素并添加额外的功能,例如添加一个隐藏的CSRF prevention field。后者用于报告与表格验证相关的错误。

回到你的新闻控制器。你将在此处执行两项操作,检查表格是否已提交以及提交的数据是否通过了验证规则。你将使用form validation库来执行此操作。

  public function create()
  {
      helper('form');
      $model = new NewsModel();


      if (! $this->validate($this->request, [
          'title' => 'required|min[3]|max[255]',
          'text'  => 'required'
      ]))
      {
          echo view('templates/header', ['title' => 'Create a news item']);
          echo view('news/create');
          echo view('templates/footer');


      }
      else
      {
          $model->save([
              'title' => $this->request->getVar('title'),
              'slug'  => url_title($this->request->getVar('title')),
              'text'  => $this->request->getVar('text'),
          ]);
          echo view('news/success');
      }
  }

上面的代码添加了很多功能。前几行加载表格helper和NewsModel。之后,Controller提供的辅助函数用于验证$_POST字段。在这种情况下,标题和文本字段是必需的。

接下来,你可以看到检查表格验证是否成功运行的条件。如果没有,则显示表格,如果提交并传递了所有规则,则调用模型。这将负责将新闻项传递到模型中。这包含一个新函数url_title()。这个函数由URL helper提供, 它将你传递的字符串剥离出来,用短划线(-)替换所有空格,并确保所有内容都是小写字符。这给你留下了一个漂亮的slug,非常适合创建URI。

在此之后,加载视图以显示成功消息。在application/Views/news/success.php创建一个视图 并写一条成功消息。

模型

最适合剩下的就是确保你的模型设置为允许正确保存数据。使用的save()方法将根据主键的存在来确定是否应插入信息,或者行是否已存在且应更新。在这种情况下,没有id传递给它的字段,所以它会在它的表中插入一个新行,即news

但是,默认情况下,模型中的插入和更新方法实际上不会保存任何数据,因为它不知道哪些字段可以安全更新。编辑模型以在$allowedFields属性中为其提供可更新字段的列表。

  <?php
  class NewsModel extends \CodeIgniter\Model
  {
      protected $table = 'news';


      protected $allowedFields = ['title', 'slug', 'text'];
  }

此新属性现在包含我们允许保存到数据库的字段。请注意,我们遗漏了id?那是因为你几乎不需要这样做,因为它是数据库中的自动递增字段。这有助于防止批量分配漏洞。如果你的模型正在处理你的时间戳,你也可以将其保留。

路由

在开始将新闻项添加到CodeIgniter应用程序之前,必须向Config/Routes.php文件添加额外的规则。确保你的文件包含以下内容。这可以确保CodeIgniter将’create’视为一种方法,而不是新闻项目的slug。

  $routes->post('news/create', 'News::create');
  $routes->add('news/(:segment)', 'News::view/$1');
  $routes->get('news', 'News::index');
  $routes->add('(:any)', 'Pages::view/$1');

现在将浏览器指向安装CodeIgniter的本地开发环境,并将index.php/news/create添加到URL。恭喜,你刚刚创建了第一个CodeIgniter应用程序!添加一些新闻并查看你制作的不同页面。

CodeIgniter4 新闻展示功能
CodeIgniter4 结束语
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }