📄 admin_batch.asp
字号:
<!--#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 + -