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

📄 admin_batch.asp

📁 品泡女人香XI8.NET文章管理系统的源码
💻 ASP
📖 第 1 页 / 共 2 页
字号:
<!--#include file="Conn.asp"-->
<!-- #include file="inc/const.asp" -->
<!--#include file="inc/dv_clsother.asp"-->
<%
Dvbbs.LoadTemplates("fmanage")
Dvbbs.Stats=template.Strings(1)
Dvbbs.Nav()
Dim rootid 
Dim id
Dim Lasttopic,Lastpost
Dim lastrootid,lastpostuser
Dim ip,url
Dim title,content
Dim TotalUseTable
Dim ars
Dim rs,sql,i,sucmsg,ErrCodes
ip=Dvbbs.UserTrueIP
If Dvbbs.UserID=0 Then Dvbbs.AddErrCode(6)
Dim UpdateBoardID,UpdateBoardID_1
If Dvbbs.BoardParentID = 0 Then
	UpdateBoardID=Dvbbs.BoardID
Else
	UpdateBoardID=Dvbbs.Board_Data(3,0) & "," & Dvbbs.BoardID
End If
If Request.form("announceid")="" Then Dvbbs.AddErrCode(30)
Dim CanBatchTopic
CanBatchTopic=False
Dvbbs.Head_var 1,Dvbbs.Board_Data(4,0),"",""
If (Dvbbs.master or Dvbbs.superboardmaster or Dvbbs.boardmaster) and Cint(Dvbbs.GroupSetting(45))=1 Then CanBatchTopic=true
If Dvbbs.FoundUserPer and Cint(Dvbbs.GroupSetting(45))=1 Then
	CanBatchTopic=true
ElseIf Dvbbs.FoundUserPer and Cint(Dvbbs.GroupSetting(45))=0 Then
	CanBatchTopic=false
End If
If not CanBatchTopic Then Dvbbs.AddErrCode(28)
Dvbbs.ShowErr()
Main
Dvbbs.ActiveOnline
Dvbbs.Footer()

Sub Main
	Select Case Request("action")
	Case "lock"
		Topic_Batch_Lock
	Case "dele"
		Topic_Batch_Delete
	Case "move"
		Topic_Batch_Move
	Case "istop"
		'Topic_Batch_Istop
	Case "isbest"
		Topic_Batch_Isbest
	Case "topicmode"
		Topic_SetTopicMode
	Case Else
		Dvbbs.AddErrCode(35)
	End Select
	If ErrCodes<>"" Then Response.redirect "showerr.asp?BoardID="&Dvbbs.BoardID&"ErrCodes="&ErrCodes&"&action=OtherErr"
	Dvbbs.ShowErr
End Sub

'批量专辑操作
Function Topic_SetTopicMode
Dim TopModeID
If Request.form("mode")<>"" and IsNumeric(Request.form("mode")) Then
	TopModeID=Cint(Request.form("mode"))
Else
	ErrCodes=ErrCodes+"<li>"+template.Strings(2)
	Exit Function
End If
Dim ID
For I=1 To Request.Form("Announceid").Count
	ID=Replace(Request.Form("Announceid")(I),"'","")
	ID=CLng(ID)
	Dvbbs.Execute("Update Dv_Topic Set Mode="&TopModeID&" Where BoardID="&Dvbbs.BoardID&" And TopicID=" & ID)
Next
	SQL="insert into Dv_Log (L_AnnounceID,L_BoardID,L_ToUser,L_UserName,L_Content,L_IP,l_type) Values ("&Id&","&Dvbbs.BoardID&",'More','"&Dvbbs.Membername&"','批量专辑操作','"&Ip&"',3)"
	Dvbbs.Execute(SQL)
	sucmsg="<li>批量专辑操作成功。<li>您的操作信息已经记录在案。"
	Dvbbs.Dvbbs_suc(sucmsg)
End Function

'批量锁定
Function Topic_Batch_Lock
	Dim ID
	For I=1 To Request.Form("Announceid").Count
		ID=Replace(Request.Form("Announceid")(I),"'","")
		ID=CLng(ID)
		Dvbbs.Execute("update dv_Topic Set LockTopic=1 Where BoardID="&Dvbbs.BoardID&" And TopicID=" & ID)
	Next
	SQL="insert into Dv_Log (L_AnnounceID,L_BoardID,L_ToUser,L_UserName,L_Content,L_IP,l_type) Values ("&Id&","&Dvbbs.BoardID&",'More','"&Dvbbs.Membername&"','批量锁定','"&Ip&"',3)"
	Dvbbs.Execute(SQL)
	sucmsg="<li>帖子批量锁定成功。<li>您的操作信息已经记录在案。"
	Dvbbs.Dvbbs_suc(sucmsg)
End Function

'批量删除
Function Topic_Batch_Delete
	Dim ID,toprs,iBoardTopStr
	Dim ChildNum,istop,Forum_AllTopNum,j,AllTopNum,Board_TopNum,TopNum,BoardTopStr
	ChildNum=0
	AllTopNum = Dvbbs.CacheData(28,0)
	Board_TopNum= Dvbbs.Board_Data(20,0)
	For I=1 To Request.Form("Announceid").Count
		ID=Replace(Request.Form("Announceid")(I),"'","")
		ID=CLng(ID)
		'更新发贴用户数据
		Set Rs=Dvbbs.Execute("Select PostTable,Child,istop from dv_Topic Where BoardID="&Dvbbs.BoardID&" And TopicID="&ID)
		If Not Rs.Eof Then
		TotalUseTable=Rs(0)
		ChildNum=ChildNum+Rs(1)
		istop=Rs(2)
		Dvbbs.Execute("Update [dv_User] Set Userwealth=Userwealth-"&Dvbbs.Forum_user(3)&",Usercp=Usercp-"&Dvbbs.Forum_user(13)&",Userep=Userep-"&Dvbbs.Forum_user(8)&" Where Userid In (Select PostUserID From "&TotalUseTable&" Where BoardID="&Dvbbs.BoardID&" And Rootid="&ID&")")

		'更新帖子数据
		Dvbbs.Execute("Update "&TotalUseTable&" Set Locktopic=BoardID,BoardID=444,isbest=0 Where BoardID="&Dvbbs.BoardID&" And RootID=" & ID)
		Dvbbs.Execute("update dv_Topic Set Locktopic=BoardID,BoardID=444,isbest=0 Where BoardID="&Dvbbs.BoardID&" And TopicID="&ID)
		'更新上传附件数据
		Dvbbs.Execute("update Dv_Upfile Set F_flag=4 Where F_BoardID="&Dvbbs.BoardID&" And F_AnnounceID LIKE  '"&ID&"|"&"%' ")
		Dvbbs.Execute("delete from dv_besttopic where rootid="&ID)
		End If
		'判断是否为固顶贴,是则更新固顶数据
		If istop=3 Then
			'将总固顶ID从总设置表去除
			Forum_AllTopNum=Split(AllTopNum,",")
			TopNum=""
			For j=0 to UBound(Forum_AllTopNum)
				If CStr(ID)<> CStr(Trim(Forum_AllTopNum(j))) Then
					If TopNum="" Then
						TopNum=Trim(Forum_AllTopNum(j))
					Else
						TopNum=TopNum&","&Trim(Forum_AllTopNum(j))
					End If
				End If
			Next
			AllTopNum=TopNum
		ElseIf istop=1 Then
			'固顶贴去除版面固顶ID
			Forum_AllTopNum=Split(Board_TopNum,",")
			TopNum=""
			For j=0 to UBound(Forum_AllTopNum)
				If CStr(ID)<> CStr(Trim(Forum_AllTopNum(j))) Then
					If TopNum="" Then
						TopNum=Trim(Forum_AllTopNum(j))
					Else
						TopNum=TopNum&","&Trim(Forum_AllTopNum(j))
					End If
				End If
			Next
			Board_TopNum=TopNum
		ElseIf istop=2 Then
			'查询此贴区固顶的所有版面ID
			Set toprs=Dvbbs.Execute("Select BoardID,BoardTopStr From Dv_Board Where BoardTopStr Like '%"&ID&"%'")
			Do While Not TopRs.Eof
			If TopRs(1)="" Or IsNull(TopRs(1)) Then
				iBoardTopStr = ""
			Else
				If InStr(","&TopRs(1)&",",","&ID&",")>0 Then
					BoardTopStr = "," & topRs(1) & ","
					BoardTopStr = Split(BoardTopStr,",")
					For j = 1 To Ubound(BoardTopStr)-1
						If Cstr(Trim(BoardTopStr(j)))<>Cstr(ID) Then
							If iBoardTopStr="" Then
								iBoardTopStr = BoardTopStr(j)
							Else
								iBoardTopStr = iBoardTopStr & "," & BoardTopStr(j)
							End If
						End If
															
					Next
				Else
					iBoardTopStr = topRs(1)
				End If
			End If
			Dvbbs.Execute("Update Dv_Board Set BoardTopStr='"&iBoardTopStr&"' Where BoardID="&TopRs(0))
			Dvbbs.ReloadBoardInfo(TopRs(0))
			BoardTopStr = ""
			iBoardTopStr = ""
			topRs.Movenext
			Loop
		End If
	Next
	'总固顶数据发生变化,则更新数据
	If AllTopNum <> Dvbbs.CacheData(28,0) Then
		Dvbbs.Execute("Update Dv_Setup Set Forum_AllTopNum='"&AllTopNum&"'")
		Dvbbs.Name="setup"
		Dvbbs.ReloadSetup
	End If
	'固顶数据发生变化,则更新数据
	If Board_TopNum <> Dvbbs.Board_Data(20,0) Then
		Dvbbs.Execute("Update Dv_Board Set BoardTopStr='"&Board_TopNum&"' Where BoardID="&Dvbbs.boardid)	
		Dvbbs.ReloadBoardInfo(Dvbbs.BoardID)
	End If
	'更新版面和总数据
	Set Rs=Dvbbs.Execute("Select ParentStr,ParentID from dv_Board Where BoardID="&Dvbbs.BoardID)
	If Rs(1)=0 Then
		UpdateBoardID=Dvbbs.BoardID
	Else
		UpdateBoardID=Rs(0) & "," & Dvbbs.BoardID
	End If
	Del_Math_Forum_Count ChildNum,i-1
	Math_Forum_Today(Dvbbs.BoardID)
	LastCount(Dvbbs.BoardID)
	SQL="insert into Dv_Log (L_AnnounceID,L_BoardID,L_ToUser,L_UserName,L_Content,L_IP,l_type) Values ("&ID&","&Dvbbs.BoardID&",'More','"&Dvbbs.Membername&"','批量删除','"&IP&"',3)"
	Dvbbs.Execute(SQL)
	sucmsg="<li>帖子批量删除成功。<li>您的操作信息已经记录在案。"

	UpdateBoardID = Split(UpdateBoardID,",")
	For i = 0 To Ubound(UpdateBoardID)
		Dvbbs.ReloadBoardInfo(UpdateBoardID(i))
	Next
	Dvbbs.Name="setup"
	Dvbbs.ReloadSetup
	Dvbbs.Dvbbs_suc(sucmsg)
	Set Rs=Nothing
End Function

Function Topic_Batch_Move
	Dim ID,Newboard,Trs,ChildNum
	Dim F_announceID,SplitUpBoardID
	ChildNum=0
	If Request.form("newboard")="" or isnull(Request.form("newboard")) or not isnumeric(Request.form("newboard")) Then
		Response.redirect "showerr.asp?ErrCodes=<li>如果您是批量转移帖子请选择相关论坛。&action=OtherErr"
		Exit Function
	ElseIf Cint(Request.form("newboard"))=Cint(Dvbbs.BoardID) Then
		Response.redirect "showerr.asp?ErrCodes=<li>请不要选择相同的论坛进行转移操作。&action=OtherErr"
		Exit Function
	Else
		newboard=Request.form("newboard")
	End If

⌨️ 快捷键说明

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