using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
using System.IO;
/// <summary>
/// BoardReply : 완성형(DotNetNote) 게시판의 답변 페이지
/// </summary>
public partial class DotNetNote_BoardReply : System.Web.UI.Page
{
#region Private Member Variables
private string strNum = "";//글 번호
private string strBaseDir = null;//파일 업로드 폴더
private string strFileName = null;//파일명
private int intFileSize = 0;//파일 사이즈
#endregion
#region Event Handlers
//페이지 로드될 때 부모글 데이터로 초기화
protected void Page_Load(object sender, System.EventArgs e)
{
strNum = Request.QueryString["Num"].ToString();
if (this.IsPostBack != true)
{
SqlConnection objCon = new SqlConnection();
objCon.ConnectionString =
ConfigurationManager.ConnectionStrings[
"ConnectionString"].ConnectionString;
objCon.Open();
SqlCommand objCmd = new SqlCommand();
objCmd.Connection = objCon;
objCmd.CommandText =
"Select * From DotNetNote Where Num = " + strNum;
objCmd.CommandType = CommandType.Text;
SqlDataReader objDr = objCmd.ExecuteReader();
if (objDr.Read())
{
txtTitle.Text = "Re : " + objDr["Title"].ToString();
string strTempContent = "\n\nOn "
+ objDr["PostDate"].ToString() + ", '"
+ objDr["Name"] + "' wrote:\n";
strTempContent += "----------";
strTempContent += "\n>"
+ objDr["Content"].ToString().Replace("\n", "\n>");
strTempContent += "\n----------";
txtContent.Text = strTempContent;
ViewState["Ref"] = objDr["Ref"].ToString();
ViewState["Step"] = objDr["Step"].ToString();
ViewState["RefOrder"] = objDr["RefOrder"].ToString();
txtNum.Text = objDr["Num"].ToString();
txtRef.Text = objDr["Ref"].ToString();
txtStep.Text = objDr["Step"].ToString();
txtRefOrder.Text = objDr["RefOrder"].ToString();
}
objDr.Close();
objCon.Close();
}
}
//리스트 이동 버튼 링크
protected void btnList_Click(object sender, System.EventArgs e)
{
Response.Redirect("BoardList.aspx");
}
//글 답변 처리
protected void btnWrite_Click(object sender, System.EventArgs e)
{
int varRef = Convert.ToInt32(txtRef.Text);
int varStep = int.Parse(txtStep.Text);
int varRefOrder = int.Parse(txtRefOrder.Text);
SqlConnection objCon = new SqlConnection();
objCon.ConnectionString = ConfigurationManager.ConnectionStrings[
"ConnectionString"].ConnectionString;
objCon.Open();
string strName = txtName.Text.Replace("&", "&").Replace(
"<", "<").Replace(">", ">");
string strTitle = txtTitle.Text.Replace("&", "&").Replace(
"<", "<").Replace(">", ">");
//파일 업로드 처리 시작
strBaseDir = Server.MapPath("./MyFiles");
strFileName = "";
intFileSize = 0;
if (txtFileName.PostedFile != null)
{
if (txtFileName.PostedFile.FileName.Trim().Length > 0 &&
txtFileName.PostedFile.ContentLength > 0)
{
strFileName = // 파일명 중복처리
GetFilePath(strBaseDir,
Path.GetFileName(txtFileName.PostedFile.FileName));
intFileSize = txtFileName.PostedFile.ContentLength;
//업로드 처리 : SaveAs()
txtFileName.PostedFile.SaveAs(
Path.Combine(strBaseDir, strFileName));
}
}//파일 업로드 처리 끝
SqlCommand objCmd = new SqlCommand();
objCmd.Connection = objCon;
// 부모글의 답변 수 1 증가
objCmd.CommandText =
"Update DotNetNote Set AnswerNum = AnswerNum + 1 "
+ " Where Num = " + txtNum.Text;//
objCmd.CommandType = CommandType.Text;
objCmd.ExecuteNonQuery();
// 같은 글에 대해서 답변을 두 번 이상하면 먼저 답변한 게 위에 나타나게 한다.
string strSql =
"SELECT RefOrder, AnswerNum FROM DotNetNote WHERE ParentNum = "
+ txtNum.Text + " AND RefOrder = (SELECT MAX(RefOrder) FROM "
+ " DotNetNote WHERE ParentNum = " + txtNum.Text + ")";
objCmd.CommandText = strSql;
objCmd.CommandType = CommandType.Text;
SqlDataReader objDr = objCmd.ExecuteReader();
// 만약 위 조건에 해당하는 답변이 없다면(처음 답변일 때) :
// 어떤 부모글(상위글)에 대한 첫번재 답변이면...
int MaxRefOrder;
int MaxRefAnswerNum;
if (objDr.Read())
{
MaxRefOrder = Convert.ToInt32(objDr[0].ToString());
MaxRefAnswerNum = Convert.ToInt32(objDr[1].ToString());
}
else
{
MaxRefOrder = varRefOrder;
MaxRefAnswerNum = 0;
}
objDr.Close();
// RefOrder 값을 1증가시킨다. :
// 비집고 들어갈 자리에 해당하는 RefOrder 값을 모두 1증가...
strSql = "UPDATE DotNetNote SET RefOrder = RefOrder + 1 "
+ " WHERE Ref = " + varRef + " AND RefOrder > "
+ (MaxRefOrder + MaxRefAnswerNum);
objCmd.CommandText = strSql;
objCmd.CommandType = CommandType.Text;
objCmd.ExecuteNonQuery();
objCmd.CommandText = "ReplyDotNetNote";
objCmd.Parameters.Add("@Name", SqlDbType.VarChar, 25);
objCmd.Parameters.Add("@Email", SqlDbType.VarChar, 100);
objCmd.Parameters.Add("@Title", SqlDbType.VarChar, 150);
objCmd.Parameters.Add("@PostIP", SqlDbType.VarChar, 15);
objCmd.Parameters.Add("@Content", SqlDbType.Text);
objCmd.Parameters.Add("@Password", SqlDbType.VarChar, 20);
objCmd.Parameters.Add("@Encoding", SqlDbType.VarChar, 10);
objCmd.Parameters.Add("@Homepage", SqlDbType.VarChar, 100);
objCmd.Parameters.Add("@Ref", SqlDbType.Int);// 참조글 번호
objCmd.Parameters.Add("@Step", SqlDbType.Int);// 들여쓰기
objCmd.Parameters.Add("@RefOrder", SqlDbType.Int);// 답글 순서
objCmd.Parameters.Add("@ParentNum", SqlDbType.Int);
objCmd.Parameters.Add("@FileName", SqlDbType.VarChar, 255);
objCmd.Parameters.Add("@FileSize", SqlDbType.Int);
objCmd.Parameters["@Name"].Value = txtName.Text;
objCmd.Parameters["@Email"].Value = txtEmail.Text;
objCmd.Parameters["@Title"].Value = txtTitle.Text;
objCmd.Parameters["@PostIP"].Value = Request.UserHostAddress;
objCmd.Parameters["@Content"].Value = txtContent.Text;
objCmd.Parameters["@Password"].Value = txtPassword.Text;
objCmd.Parameters["@Encoding"].Value =
rdoEncoding.SelectedItem.Text;
objCmd.Parameters["@Homepage"].Value = txtHomepage.Text;
objCmd.Parameters["@Ref"].Value = //답변글은 부모글의 Ref를 적용
Convert.ToInt32(txtRef.Text.ToString());
objCmd.Parameters["@Step"].Value = varStep + 1;
objCmd.Parameters["@RefOrder"].Value =
(MaxRefOrder + MaxRefAnswerNum) + 1;
objCmd.Parameters["@ParentNum"].Value =
Convert.ToInt32(txtNum.Text.ToString());
objCmd.Parameters["@FileName"].Value = strFileName;
objCmd.Parameters["@FileSize"].Value = intFileSize;
objCmd.CommandType = CommandType.StoredProcedure;
objCmd.ExecuteNonQuery();
objCon.Close();
Response.Redirect("./BoardList.aspx");
}
//파일 첨부 레이어 보이기/감추기
protected void chkUpload_CheckedChanged(
object sender, System.EventArgs e)
{
if (chkUpload.Checked)
{
Panel1.Visible = true;
}
else
{
Panel1.Visible = false;
}
}
#endregion
#region Public Methods
#region 파일명 뒤에 번호 붙이는 메서드
/// <summary>
/// GetFilePath : 파일명 뒤에 번호 붙이는 메서드
/// </summary>
/// <param name="strBaseDirTemp">경로(c:\MyFiles)</param>
/// <param name="strFileNameTemp">Test.txt</param>
/// <returns>Test(1).txt</returns>
private string GetFilePath(
string strBaseDirTemp, string strFileNameTemp)
{
string strName = //순수파일명 : Test
Path.GetFileNameWithoutExtension(strFileNameTemp);
string strExt = //확장자 : .txt
Path.GetExtension(strFileNameTemp);
bool blnExists = true;
int i = 0;
while (blnExists)
{
if (File.Exists(
Path.Combine(strBaseDirTemp, strFileNameTemp)))
{//Path.Combine(경로, 파일명) = 경로+파일명
i++;
strFileNameTemp =
strName + "(" + i + ")" + strExt;//Test(3).txt
}
else
{
blnExists = false;
}
}
return strFileNameTemp;
}
#endregion
#endregion
} |