簡體   English   中英

如何在CodeIgniter上上傳圖像並將其顯示在另一頁上

[英]How to upload an image on CodeIgniter and display it on another page

我仍在學習codeigniter框架,並且剛剛完成了新聞應用程序教程,該教程使您可以創建一個帶有標題和故事文字的新聞項目。 我如何使用戶能夠上載新聞項的圖像,並在查看相應新聞項時顯示每個圖像。

PS。 對不起,如果我有任何錯誤,這是我的第一個問題

create.php

<h2>Create a news item</h2>

<?php echo validation_errors(); ?>

<?php echo form_open('news/create') ?>

<?php echo form_open_multipart('upload/do_upload');?>

<input type="file" name="userfile" size="20" />

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

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

    <input style="margin-left: 18%; margin-right: 20%;" type="submit" name="submit" value="PUBLISH" />

</form>

news_model.php

    <?php
class News_model extends CI_Model {

    public function __construct()
    {
        $this->load->database();
    }

public function get_news($slug = FALSE)
{
    if ($slug === FALSE)
    {
        $this->db->order_by("id", "desc");
        $query = $this->db->get('news');


        return $query->result_array();
    }

    $query = $this->db->get_where('news', array('slug' => $slug));
    return $query->row_array();
}
public function set_news()
{
    $this->load->helper('url');

    $slug = url_title($this->input->post('title'), 'dash', TRUE);

    $data = array(
        'title' => $this->input->post('title'),
        'slug' => $slug,
        'text' => $this->input->post('text')
    );

    return $this->db->insert('news', $data);
}
}

news.php-控制器

<?php
class News extends CI_Controller {

    public function __construct()
    {
        parent::__construct();
        $this->load->model('news_model');
    }

    public function index(){
        $data['news'] = $this->news_model->get_news();
        $data['title'] = 'News archive';
        $this->load->view('templates/header', $data);
        $this->load->view('templates/rightpane', $data);
        $this->load->view('news/index', $data);
        $this->load->view('templates/footer');
    }


public function view($slug)
{
    $data['news_item'] = $this->news_model->get_news($slug);        

    if (empty($data['news_item']))
    {
        show_404();
    }

    $data['title'] = $data['news_item']['title'];

    $this->load->view('templates/header', $data);
    $this->load->view('templates/rightpane', $data);
    $this->load->view('news/view', $data);
    $this->load->view('templates/footer');
}
public function create()
{
    $this->load->helper('form');
    $this->load->library('form_validation');

    $data['title'] = 'Create a news item';

    $this->form_validation->set_rules('title', 'Title', 'required');
    $this->form_validation->set_rules('text', 'text', 'required');

    if ($this->form_validation->run() === FALSE)
    {
        $this->load->view('templates/header', $data);
        $this->load->view('templates/rightpane', $data);
        $this->load->view('news/create');
        $this->load->view('templates/footer');

    }
    else
    {
        $this->news_model->set_news();
        $this->load->view('news/success');
    }
}
}

view.php

<?php
echo '<h2>'.$news_item['title'].'</h2>';
echo $news_item['text'];`

的index.php

<?php foreach ($news as $news_item): ?>
    <div style="margin-left: 18%; margin-right: 20%;">
    <h2 ><?php echo $news_item['title'] ?></h2>
    <div id="main" >
        <?php echo $news_item['text'] ?>
    </div>
    <p ><a href="news/<?php echo $news_item['slug'] ?>">View article</a></p>
    </div>
<?php endforeach ?>

看一下docs中的upload類:

http://ellislab.com/codeigniter/user-guide/libraries/file_uploading.html

提示:您將文件保存到服務器,然后將URL保存在數據庫中,然后可以在IMG標簽內顯示URL。

解決方案是: img src =“” class =“ img-sensitive”

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM