⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 addtopic.asp

📁 秘密网源代码 传闻拉了 100W风投
💻 ASP
字号:
<!-- #include file="Setup.asp" -->
<%
HtmlTop
if CookieUserName=empty then error("您还未<a href=Login.asp?ReturnUrl="&ReturnUrl&">登录</a>")


	Rs.Open "select * from [Wo_Users] where UserID="&CookieUserID&"",Conn,1,3
	UserAccountStatus=Rs("UserAccountStatus")
	ModerationLevel=Rs("ModerationLevel")
	UserRegisterTime=Rs("UserRegisterTime")
	UserPostTime=Rs("UserPostTime")
	Rs.close
	
	if UserAccountStatus<>1 then error("您的帐号未通过审核!")
	
	if SiteConfig("RegUserTimePost") > 0 then
		StopPostTime=int(DateDiff("n",UserRegisterTime,Now()))
		if StopPostTime < SiteConfig("RegUserTimePost") then error("<li>新注册窝友必须等待 "&SiteConfig("RegUserTimePost")&" 分钟后才能发表主题!<li>您必须再等待 "&SiteConfig("RegUserTimePost")-StopPostTime&" 分钟!")
	end if

	if SiteConfig("PostInterval") > 0 then
		StopPostTime=int(DateDiff("s",UserPostTime,Now()))
		if StopPostTime < SiteConfig("PostInterval") then error("群组限制一个人两次发表主题间隔必须大于 "&SiteConfig("PostInterval")&" 秒!<li>您必须再等待 "&SiteConfig("PostInterval")-StopPostTime&" 秒!")
	end if


ForumID=RequestInt("ForumID")

sql="select * from [Wo_Forums] where ForumID="&ForumID&""
Set Rs=Conn.Execute(sql)
	if Rs.Eof then error("系统不存在此群组的资料")
	ForumName=Rs("ForumName")
	Moderated=Rs("Moderated")
	ParentID=Rs("ParentID")
	GroupID=Rs("GroupID")
	TotalCategorys=Rs("TotalCategorys")
	IsModerated=Rs("IsModerated")
	ForumUrl=Rs("ForumUrl")
	IsActive=Rs("IsActive")
Rs.close

%>
<!-- #include file="Utility/ForumPermissions.asp" -->
<%
if ForumUrl<>"" then response.redirect ForumUrl
if IsActive=0 and PermissionManage=0 then error"<li>该版块已经关闭!"

if PermissionPost=0 then error("您的<a href=ShowForumPermissions.asp?ForumID="&ForumID&">权限</a>不够")
if Request.ServerVariables("Request_method") = "POST" then
	if Request.Form=Application("LastPost") and SiteConfig("AllowDuplicatePosts")=0 then error("请不要提交重复数据")
	if SiteConfig("EnableAntiSpamTextGenerateForPost")=1 then
		if Request.Form("VerifyCode")<>Session("VerifyCode") or Session("VerifyCode")="" then Message=Message&"<li>验证码错误!</li>"
	end if
	Subject=HTMLEncode(Request.Form("Subject"))
	Category=HTMLEncode(Request.Form("Category"))
	Body=BodyEncode(Request.Form("Body"))
	Tags=HTMLEncode(Request.Form("Tags"))
	ThreadEmoticonID=RequestInt("ThreadEmoticonID")

	if Request.Form("DisableYBBCode")<>1 then Body=YbbEncode(Body)
	if Len(Subject)<2 then Message=Message&"<li>文章主题不能小于 2 字符"
	if Len(Body)<2 then Message=Message&"<li>文章内容不能小于 2 字符"
	if len(Tags)>255 then Message=Message&"<li>标签不能大于255字符"

	Vote=Request.Form("Vote")
	if Vote<>"" then
		if instr(Vote,"|") > 0 then error("投票选项中不能含有“|”字符")
		pollTopic=split(Vote,chr(13)&chr(10))
		j=0
		for i = 0 to ubound(pollTopic)
			if not (pollTopic(i)="" or pollTopic(i)=" ") then
				allpollTopic=""&allpollTopic&""&pollTopic(i)&"|"
				j=j+1
			end if
		next
		if j<SiteConfig("MinVoteOptions") then error("<li>投票选项不能少于 "&SiteConfig("MinVoteOptions")&" 个")
		if j>SiteConfig("MaxVoteOptions") then error("<li>投票选项超过 "&SiteConfig("MaxVoteOptions")&" 个")
		
		for y = 1 to j
			Votenum=""&Votenum&"0|"
		next
	end if
	

	IsMultiplePoll=RequestInt("IsMultiplePoll")
	VoteItems=HTMLEncode(allpollTopic)
	VoteExpiry=now()+RequestInt("VoteExpiry")

	if Not Isdate(VoteExpiry) then error("<li>投票过期时间错误")

	if Message<>"" then error(""&Message&"")
	Conn.Execute("update [Wo_Users] set TotalPosts=TotalPosts+1,UserMoney=UserMoney+"&SiteConfig("IntegralAddThread")&",experience=experience+"&SiteConfig("IntegralAddThread")&",UserPostTime="&SqlNowString&" where UserID="&CookieUserID&"")
	Rs.Open "select * from [Wo_Threads]",Conn,1,3
	Rs.addNew
		Rs("PostAuthor")=CookieUserName
		Rs("PostTime")=now()
		Rs("lastname")=CookieUserName
		Rs("lasttime")=now()
		Rs("Topic")=Subject
		Rs("ForumID")=ForumID
		Rs("Category")=Category
		Rs("Tags")=Tags
		Rs("ThreadEmoticonID")=ThreadEmoticonID
		if Request("Vote")<>"" then Rs("IsVote")=1
		if Request("IsLocked")=1 then Rs("IsLocked")=1
		if IsModerated=1 and ModerationLevel=0 then Rs("IsApproved")=0
	Rs.update
	ThreadID=Rs("ThreadID")
	PostsTableName=Rs("PostsTableName")
	Rs.close
	
	
	if Request.Form("Vote")<>"" then
		Conn.Execute("insert into [Wo_Votes] (ThreadID,IsMultiplePoll,Items,Result,Expiry) values ('"&ThreadID&"',"&IsMultiplePoll&",'"&VoteItems&"','"&Votenum&"','"&VoteExpiry&"')")
	end if
	
	if Request.Form("UpFileID")<>"" then
		UpFileID=split(Request.Form("UpFileID"),",")
		for i = 0 to ubound(UpFileID)-1
			Conn.execute("update [Wo_PostAttachments] set Description='"&Subject&"',ThreadID='"&ThreadID&"' where UpFileID="&int(UpFileID(i))&" and UserName='"&CookieUserName&"'")
		next
	end if
	
	UpdateStatistics 0,1,1
	Conn.Execute("insert into [Wo_Posts"&PostsTableName&"] (ThreadID,PostAuthor,Subject,Body,IPAddress) values ('"&ThreadID&"','"&CookieUserName&"','"&Subject&"','"&Body&"','"&Request.ServerVariables("REMOTE_ADDR")&"')")
	Conn.execute("update [Wo_Forums] set MostRecentPostSubject='"&Subject&"',MostRecentPostAuthor='"&CookieUserName&"',MostRecentPostDate="&SqlNowString&",TodayPosts=TodayPosts+1,TotalThreads=TotalThreads+1,TotalPosts=TotalPosts+1,MostRecentThreadID="&ThreadID&" where ForumID="&ForumID&" or ForumID="&ParentID&"")


	Session("VerifyCode")=""
	Application("LastPost")=Request.Form

	if IsModerated=1 and ModerationLevel=0 then
		EnableCensorship="由于群组设有审核制度,您发表的主题需要等待激活才能显示。"
	else
		EnableCensorship="<a href=ShowPost.asp?ThreadID="&ThreadID&">返回主题</a>"
	end if

	Message="<li>新主题发表成功</li><li>"&EnableCensorship&"</li><li><a href=ShowForum.asp?ForumID="&ForumID&">返回群组</a></li>"
	succeed Message,"ShowForum.asp?ForumID="&ForumID&""

end if
%>
<table width="900" align="center" border="0" cellspacing="0" cellpadding="0">
  <tr>
    <td><div id="CommonBreadCrumbArea"><%ClubTree%> → <%ForumTree(ParentID)%><%=ForumTreeList%> <a href=ShowForum.asp?ForumID=<%=ForumID%>><%=ForumName%></a> → 发表主题</div></td>
  </tr>
</table>
<form name="form" method="post" onSubmit="return CheckForm(this);">
<input name="Body" type="hidden">
<input name="UpFileID" type="hidden">
<input type=hidden name=ForumID value=<%=ForumID%>>
<table cellspacing=1 cellpadding=0 border=0 align=center id=CommonListArea  width="900">
	<TR id=CommonListTitle3>
		<TD vAlign=Left colSpan=2>&nbsp;&nbsp;发表主题</TD>
	</TR>
	<TR id=CommonListCell>
		<TD width="180"><div align="center"><B>标题:</B></div></TD>
		<TD><INPUT type="text" maxLength="50" size="60" name="Subject"></TD>
	</TR>
	<TR id=CommonListCell>
		<TD width="180"><div align="center"><B>类别:</B></div></TD>
		<TD>
			<select name=Category size=1><OPTION value="" selected>无</OPTION>
<%
	if TotalCategorys<>empty then
		filtrate=split(TotalCategorys,"|")
		for i = 0 to ubound(filtrate)
			response.write "<OPTION value='"&filtrate(i)&"'>"&filtrate(i)&"</OPTION>"
		next
	end if
%>
			</SELECT> <a href="javascript:Wo_Modal.Open('Utility/AddCategory.htm', 500, 100);">添加类别</a></TD>
	</TR>
	<TR id=CommonListCell>
		<TD vAlign=top align=Left><div align="center"><B>表情:</B></div></TD>
		<TD><INPUT type=radio value=0 name=ThreadEmoticonID <%if ThreadEmoticonID=0 then%>checked<%end if%> >无<br>
		<script language="JavaScript">
		for(i=1;i<=30;i++) {
			document.write("<INPUT type=radio value="+i+" name=ThreadEmoticonID><IMG src=images/Emotions/emotion-"+i+".gif> ")
			if (i ==10 || i ==20){document.write("<br>")}
		}
		</script>		</TD>
	</TR>
<%if PermissionCreatePoll=1 and Request("Poll")=1 then%>
	<TR id=CommonListCell>
		<TD vAlign=top align=Left><div align="center"><FONT color=000000><B>投票</B><BR>
	      每行一个投票项目<BR>
          <INPUT type=radio CHECKED value=0 name=IsMultiplePoll id=IsMultiplePoll>
          <label for=IsMultiplePoll>单选投票</label>
          <BR>
          <INPUT type=radio value=1 name=IsMultiplePoll id=IsMultiplePoll_1>
          <label for=IsMultiplePoll_1>多选投票</label>
	      </FONT> <br>
	      过期时间 
	      <INPUT type="text" size="2" name="VoteExpiry" value="7" onkeyup=if(isNaN(this.value))this.value='7'> 
	      天后
			    
			
      </div></TD>
		<TD><TEXTAREA name=Vote rows=5 cols="80"></TEXTAREA></TD>
	</TR>
<%end if%>
	<TR id=CommonListCell>
		<TD vAlign=top>
		  <div align="center"><br>
		    <B>内容</B><BR>
		    (<a href="javascript:CheckLength();">查看内容长度</a>)<BR>
		    <BR>
		    <INPUT id=LockMyPost name=IsLocked type=checkbox value="1">
		    <label for=LockMyPost> 主题锁定</label>
		    <br>
		    <INPUT id=DisableYBBCode name=DisableYBBCode type=checkbox value=1>
		    <label for=DisableYBBCode> 禁用YBB代码</label>
		    <%if SiteConfig("UpFileOption")<>empty and PermissionAttachment=1 then%>
			<BR>
			<BR>
			<span id=UpFile></span><a href="javascript:Wo_Modal.Open('UploadAttachment.asp',500,150);" class="CommonTextButton">上传附件</a>
		    <%end if%>
		  </div></TD>
		<TD height=250><script type="text/javascript" src="Editor/Post.js"></script></TD>
	</TR>
<%if SiteConfig("DisplayPostTags")=1 then%>
	<TR id=CommonListCell>
		<TD><div align="center"><b>标签<br>
	    </b>以逗号“,”分隔</div></TD>
		<TD><input type="text" name="Tags" size="80" /></TD>
	</TR>
<%end if%>
<%if SiteConfig("EnableAntiSpamTextGenerateForPost")=1 then%>
	<tr id=CommonListCell>
		<TD><div align="center"><b>验证码</b></div></TD>
		<TD><input type="text" name="VerifyCode" MaxLength="4" size="10" onBlur="CheckVerifyCode(this.value)" onKeyUp="if (this.value.length == 4)CheckVerifyCode(this.value)"> <img src="VerifyCode.asp" title="验证码,看不清楚?请点击刷新验证码" style="cursor:pointer" onClick="this.src='VerifyCode.asp?'+Math.random()"> <span id="CheckVerifyCode" style="color:red"></span></TD>
	</tr>
<%end if%>
	<TR id=CommonListCell>
		<TD align=center colSpan=2><INPUT type=submit value=" 发表 " name=EditSubmit> <input type="Button" value=" 预览 " onClick="Preview();"> <INPUT onClick="history.back()" type="button" value=" 取消 "></TD>
	</TR>
</TABLE>
</FORM>
<div name="Preview" id="Preview"></div>
<%
HtmlBottom
%>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -