Dedecms 织梦 报名插件
这里要说一下:这个插件是从别的地方复制来的,我已经自己试验过了,我的织梦版本是5.7.测试过了,是可以用的,
但是这个 只是提供些织梦插件的一个思路,而不是让你真正的用,如果需要的话 你完全可以用织梦的自定义表单来完成这个功能
先运行sql 然后把文件放入对应的文件夹就可以了
/templets/plus enroll.htm
/plus enroll.php
/dede adenroll.php
/dede/templets adenroll.htm
注:把涉及表的前缀都自己改掉改成自己的
下面把代码贴出来:
1:sql
CREATE TABLE IF NOT EXISTS `dede_enroll` (
`id` int(4) NOT NULL auto_increment,
`name` varchar(20) NOT NULL,
`mail` varchar(30) NOT NULL,
`tag` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;
INSERT INTO `dede_plus` (`aid`, `plusname`, `menustring`, `mainurl`, `writer`, `isshow`, `filelist`) VALUES
(30, '网上报名', '', '', 'g1000', 1, '');
2:adenroll.htm
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<head>
<title>在线报名管理</title>
<link href='img/base.css' rel='stylesheet' type='text/css' />
<style type="text/css">
th,td{ text-align:center;
border:1px #D1DDAA solid;
font-size:15px;
}
th{ background:#E6F8B7; }
table{ margin-top:20px; }
</style>
</head>
<body>
<table width="90%" border="0" cellpadding="0" cellspacing="0" align="center">
<tr>
<th>姓名</th>
<th>E-mail</th>
<th>状态</th>
<th>操作</th>
</tr>
<!-- 循环得到结果 -->
{dede:datalist}
<tr>
<td>{dede:field.name /}</td>
<td>{dede:field.mail /}</td>
<td>
{dede:if field.tag==0}
未录取
{else}
<font color="red">已录取</font>
{/dede:if}
</td>
<td> <a href="adenroll.php?action=pass&id={dede:field.id /}">[录取]</a> |
<a href="adenroll.php?action=nopass&id={dede:field.id /}">[不通过]</a> |
<a href="adenroll.php?action=delete&id={dede:field.id /}">[删除]</a>
</td>
</tr>
{/dede:datalist}
</table>
<!-- 分页标签 -->
<p style="text-align:center;font-size:15px;">{dede:pagelist listitem="info,index,end,pre,next,pageno" listsize="5"/}</p>
</body>
</html>
3:adenroll.php
<?php
require_once(dirname(__FILE__).'/config.php');//后台配置文件 检查登陆 配置信息
require_once(DEDEINC."/datalistcp.class.php");//包含分页类
if($_GET['action']&&$_GET['id']){
if($_GET['action']=='pass'){//各种操作
$db->ExecuteNoneQuery("update ntqx_enroll set `tag`=1 where id='$_GET[id]'");
ShowMsg('录取成功','adenroll.php');
}
if($_GET['action']=='nopass'){
$db->ExecuteNoneQuery("update ntqx_enroll set `tag`=0 where id='$_GET[id]'");
ShowMsg('取消录取','adenroll.php');
}
if($_GET['action']=='delete'){
$db->ExecuteNoneQuery("delete from ntqx_enroll where id='$_GET[id]'");
ShowMsg('删除成功','adenroll.php');
}
}else{
$dl = new DataListCP();
$dl->pageSize = 10;//每页显示10条
$dl->SetTemplate('./templets/adenroll.htm');//载入模板
$sql="select * from ntqx_enroll";
$dl->SetSource($sql);//执行sql 不能与$dl->SetTemplate 颠倒
$dl->Display();//显示页面
}
?>
4:enroll.htm
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<head>
<title>{dede:global.cfg_webname/}-在线报名</title>
<link href="/templets/default/style/style.css" rel="stylesheet" media="screen" type="text/css" />
</script>
</head>
<body>
{dede:include filename="../default/head.htm"/}<!-- 包含头部 -->
<blockquote style="margin:50px auto" >
<form method="post" action="">
姓 名:<input type="text" size=30 name="name" /><br /><br />
邮 箱:<input type="text" size=30 name="mail" /><br /><br />
<!--vdimgck.php 是验证码-->
验证码:<input type="text" name="validation" /><img src="../../include/vdimgck.php" /><br /><br />
<input name="encoll" type="submit" value="报名" /><br />
</form>
</blockquote>
{dede:include filename="../default/footer.htm"/}<!-- 包含尾部 -->
</body>
</html>
5:enroll.php
<?php
//*******要先包含common.inc.php 然后 session_start(); 否则取不到session的值
//*******因为common.inc.php 有关于session路径的配置
include_once dirname(__FILE__).'./../include/common.inc.php';//包含配置文件
session_start();
require_once DEDEINC."/arc.partview.class.php";//包含partiew类
//*****实例化 这个类的作用是得到头部导航栏和尾部信息 若不需要可以使用dedetemplate.class.php 这个类
$pv = new PartView();
if($_POST){
if( CheckEmail($_POST['mail'])==false){//验证邮箱 方法在common.func.php 公用函数
ShowMsg('邮箱格式错误','-1');
exit();
}
if($_POST['name']==""){
ShowMsg('用户名不能为空','-1');
exit();
}else{
$name=htmlspecialchars($_POST['name']);
}
if($_SESSION['securimage_code_value']!=strtolower($_POST['validation'])){//验证 验证码 必须转换成小写
ShowMsg('验证码错误',-1);
exit();
}
$sql="insert into `ntqx_enroll`(name,mail) values('$name','$_POST[mail]')";
//********$db可直接使用 系统自动实例化了dedesql.class.php
$affected = $db->ExecuteNoneQuery2($sql);//执行一条语句 返回影响值
if($affected){
ShowMsg('报名成功',-1);
}
}else{
$pv->SetTemplet(DEDETEMPLATE.'/plus/enroll.htm');//设置模板
$pv->Display();//显示页面
}
?>
很多朋友不知道路径怎么访问
/plus/enroll.php
转载 http://blog.csdn.net/wxincome/article/details/8143430

浙公网安备 33010602011771号