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
 
posted @ 2016-04-14 15:12  沙漠孤狼  阅读(266)  评论(0)    收藏  举报