一个用户管理的ci框架的小demo--转载
一个ci框架的小demo
最近在学习ci框架,作为一个初学者,在啃完一遍官方文档并也跟着官方文档的例程(新闻发布系统)做了一遍,决定在将之前练习PHP与MySQL数据库的用户管理系统再用ci框架实现一遍。
主要由三个简单的界面构成:
看起来很简单对不对!没有关系,这不重要~
接下来我们来看代码:
ci的配置我就不用讲了哈,我的配置如下:
database.php 配置文件
'hostname' => 'localhost',
'username' => 'root',
'password' => 'root',
'database' => 'test',
'dbdriver' => 'mysqli',
'dbprefix' => '',
'pconnect' => FALSE,
'db_debug' => (ENVIRONMENT !== 'production'),
'cache_on' => FALSE,
'cachedir' => '',
'char_set' => 'utf8',
'dbcollat' => 'utf8_general_ci',
一定要配置config.php中的base_url,原因你会知道的
$config['base_url'] = 'http://localhost:81/ciDemo/Code/';
接下来是控制器的代码:
我建立了一个user.php的控制器,目录是application/controllers/user.php
<?php
/**
* 数据库的增删改查
*/
class User extends CI_controller
{ function __construct()
{
parent::__construct();
$this->load->model('user_model');
// $this->load->helper('url_helper');
$this->load->helper('url');
}
public function index()
{
// $this->load->model('user_model');
$arr = $this->user_model->getAll();
// var_dump($arr);
$data['title'] = 'Userlist'; $this->load->view('templates/header', $data);
$this->load->view('user/index',array('arr'=>$arr));
$this->load->view('templates/footer');
}
public function insert()
{
$this->load->helper('form'); $data['title'] = 'Create a new user'; // $this->load->model('user_model');
// $arr = array('uaername' => '111','password' => 'md5(222)' ); $this->load->view('templates/header', $data);
$this->load->view('user/adduser');
$this->load->view('templates/footer'); }
public function insert_ok()
{
// echo "join"; // if ($this->input->post('submit_user')) {
$arr = array(
'username' => $this->input->post('username'),
'password' => md5($this->input->post('password'))
);
$query = $this->user_model->user_insert($arr);
// var_dump($query);
if ($query) {
// echo "添加成功";
// $this->index();
redirect('user/index');
} else {
echo "添加失败";
}
// }
}
public function update()
{
$this->load->helper('form'); $data['title'] = 'Update user'; // $this->load->model('user_model');
// $arr = array('uaername' => '111','password' => 'md5(222)' );
$id = $this->uri->segment(3, 0);
// echo $id;
$arr = $this->user_model->user_select($id);
// var_dump($arr);
//怎么把指定ID的username传到视图中去
$this->load->view('templates/header', $data);
$this->load->view('user/editUser', array('get_username'=>$arr));
$this->load->view('templates/footer');
}
public function update_ok()
{
// $this->load->model('user_model');
// $arr = array('username' => 'kkk','password' => 'md5(333)' );
$arr = array(
'username' => $this->input->post('username'),
'password' => md5($this->input->post('password'))
);
// $id = $_GET['id'];
//怎么获取ID值?
$id = $this->uri->segment(3, 0);
$query = $this->user_model->user_update($id,$arr);
if ($query) {
// echo "删除成功";
// $this->index();
redirect('user/index');
} else {
echo "更新失败";
}
} public function delete()
{
$id = $this->uri->segment(3, 0);
// $this->load->model('user_model');
$query = $this->user_model->user_delete($id);
if ($query) {
// echo "删除成功";
// $this->index();
redirect('user/index');
} else {
echo "删除失败";
} }
// public function select()
// {
// // $this->load->model('user_model');
// $arr = $this->user_model->user_select();
// print_r($arr);
// echo $arr[0]->id;
// }
}
模型的代码:
目录是application/models/user_model.php
<?php
/**
* 数据库增删改查......
*/
class User_model extends CI_Model
{
//构造函数
function __construct()
{
parent::__construct();
//connect to the database
$this->load->database();
//$this->load->insert($t_name,$data)
}
//所有数据
function getAll()
{
$res = $this->db->get('user');
return $res->result_array();
}
//增加数据
function user_insert($arr)
{
return $this->db->insert('user', $arr);
}
//更新数据
function user_update($id,$arr)
{
$this->db->where('id',$id);
return $this->db->update('user',$arr);
}
//删除数据
function user_delete($id)
{
$this->db->where('id',$id);
return $this->db->delete('user');
}
//查找数据
function user_select($id)
{
$this->db->where('id',$id);
$this->db->select('*');
$query = $this->db->get('user');
return $query->result_array();
} }
接下来是视图:
用户列表的视图 application/views/user/index.php
<?php
// var_dump($arr);
?>
<h2>用户列表<a href="<?php echo site_url('user/insert');?>">添加用户</a></h2>
<table border="1" cellspacing="0" cellpadding="0" width="80%" bgcolor="#ABCDEF">
<tr>
<td>编号</td>
<td>用户名</td>
<td>操作</td>
</tr>
<?php $i=1; foreach($arr as $row):?>
<tr>
<td><?php echo $i;?></td>
<td><?php echo $row['username'];?></td>
<td><a href="<?php echo site_url().'/user/update/'.$row['id'];?>">更新</a>|<a href="<?php echo site_url().'/user/delete/'.$row['id'];?>">删除</a></td>
</tr>
<?php $i++; endforeach;?>
</table>
添加用户的视图:application/views/user/adduser.php
<!-- <h2>添加用户</h2> -->
<form action="<?php echo site_url("user/insert_ok");?>" method="post">
<?php //echo form_open('user/insert')?>
<table border="1" cellpadding="0" cellspacing="0" bgcolor="#ABCDEF" width="80%">
<tr>
<td>用户名</td>
<td><input type="text" name="username" id="username" placeholder="请输入合法用户名" required></td>
</tr>
<tr>
<td>密码</td>
<td><input type="password" name="password" id="password" placeholder="请输入密码" required></td>
</tr>
<tr>
<td colspan="2"><input type="submit" value="添加用户" name="submit_user"></td>
</tr>
</table>
</form>
更新用户的视图:application/views/user/edituser.php
<!-- <h2>更新用户</h2> -->
<form action="<?php foreach ($get_username as $row):?><?php echo site_url().'/user/update_ok/'.$row['id'];?><?php endforeach;?>" method="post">
<table border="1" cellpadding="0" cellspacing="0" bgcolor="#ABCDEF" width="80%">
<tr>
<td>用户名</td>
<td><input type="text" name="username" id="" placeholder="请输入合法用户名" required value="<?php foreach ($get_username as $row):?><?php echo $row['username'];?><?php endforeach;?>"></td>
</tr>
<tr>
<td>密码</td>
<td><input type="password" name="password" id="" placeholder="请输入密码" required></td>
</tr>
<tr>
<td colspan="2"><input type="submit" value="更新用户"></td>
</tr>
</table>
</form>
为什么我的视图都没有HTML头和尾,因为我把他们分开写在了views视图下的templates文件夹里:
application/views/templates/header.php
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title><?php echo $title; ?></title>
</head>
<body> <h1><?php echo $title; ?></h1>
application/views/templates/footer.php
<em>© 2016</em>
</body>
</html>
一个用户管理的ci框架的小demo--转载的更多相关文章
- 通过一个用户管理实例学习路由react-router-dom知识
我们通过一个用户管理实例来学习react-router-dom 这个实例包括9个小组件 App.js 引入组件 Home.js 首页组件 User.js 用户管理组件 - UserList.js 用 ...
- RPC框架学习+小Demo实例
一.什么是RPC协议? 全称:远程过程调度协议 效果:使消费者向调用本地方法一样调用远程服务方法,对使用者透明 目前常用:Dubbo.Thirft.Sofa.... 功能: 建立远程通信(socket ...
- 【Java】Jsoup爬虫,一个简单获取京东商品信息的小Demo
简单记录 - Jsoup爬虫入门实战 数据问题?数据库获取,消息队列中获取中,都可以成为数据源,爬虫! 爬取数据:(获取请求返回的页面信息,筛选出我们想要的数据就可以了!) 我们经常需要分析HTML网 ...
- 一个上传图片,预览图片的小demo
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- 模拟Hibernate框架的小demo
该程序为尚学堂马士兵老师讲解,模拟了hibernate的原理,主要应用了字符串拼接,反射知识. step1,新建数据库 use jd; create table _student( _id int(1 ...
- Spring Boot 简单小Demo 转载!!!
Spring Boot简介 接下来我们所有的Spring代码实例将会基于Spring Boot,因此我们先来了解一下Spring Boot这个大杀器. Spring早期使用XML配置的方式来配置Spr ...
- golang 文件传输小demo(转载)
转载地址:https://www.cnblogs.com/qq702368956/p/10195497.html 获取文件信息需要用到os. Stat接口,发送文件前开启接收者(服务端),启动客户端先 ...
- 使用Jquery+EasyUI进行框架项目开发案例解说之中的一个---员工管理源代码分享
使用Jquery+EasyUI 进行框架项目开发案例解说之中的一个 员工管理源代码分享 在開始解说之前,我们先来看一下什么是Jquery EasyUI?jQuery EasyUI是一组基于jQuery ...
- 在线用户管理--ESFramework 4.0 进阶(05)
无论我们采用何种通信框架来构建我们的分布式系统,在服务端进行用户管理都是非常重要的一个环节.然而用户管理是否应该隶属于通信框架了?这个并不一定,通常来说,用户管理是与具体应用紧密相关的,应该是由应用解 ...
随机推荐
- vs2013 乱码问题
单击一下代码框 然后点文件 有个高级保存选项 改成utf-8 就可以显示中文了
- Django将.csv文件(excel文件)显示到网页上
今天,我成功将项目要导入的测试数据导入并呈现了,虽然还不是很完美,但我之后仍会继续改进. 1.首先在主页面上加一个超链接按钮: 其它的不需要管,其它是我的另一个项目,没什么大用的 2.之后配置URL: ...
- 灵活运用SMART原则梳理目标
1:立刻行动 执行力是老生常谈了,提高执行力不拖延,源自于对目标的充分理解和超出常人的坚持. 如何深刻理解目标?一方面要有基础的知识.能力积累,另一方面要灵活运用SMART原则从不同维度梳理目标. 2 ...
- Fiddler 抓包工具总结-bpafter
转摘https://www.cnblogs.com/shy1766IT/p/5199334.html Fiddler 抓包工具总结 名称 含义 # 抓取HTTP Request的顺序,从1开始,以 ...
- Codeforces Round #474-B(贪心)
一.题目链接 http://codeforces.com/contest/960/problem/B 二.题意 给定三个数字$N, k1, k2$,接下来给出两组数$a[]$和$b[]$,每组数$N$ ...
- php自动生成mysql的触发代码。
如果公司里有上百个表要做触发器,如果手动写代码的话.很累,所以今天写了一个小程序, <?php $dbname = 'test';//数据库 $tab1 = 'user'; //执行的表 $ta ...
- Python 使用 Postfix 发送邮件
最近在做一个监控程序,需要用邮件发送告警.以前是使用注册的免费邮来发送,但是这样不免有很多限制,而且有时还会当作恶意登录,帐号异常等,还不让登录邮箱了.利用Postfix提供邮件SMTP服务,可以很自 ...
- oracle执行sql文件
oracle执行sql文件 在PL/SQL中直接用command window执行就可以了: PL/SQL developer----->File------>New---->com ...
- Windows10 IME占用过高临时解决办法
解决方案: 在管理员模式下运行命令提示符,并输入如下命令 if exist "%SystemRoot%\System32\InputMethod\CHS\ChsIME.exe" ( ...
- localStorage,sessionStorage
h5的本地存储. 现代浏览器普遍开始支持H5本地存储,localStorage.sessionStorage.可以用来代替cookie的一部分存储功能,他比cookie存储量更大.比较实用. 两者用法 ...