Fileupload コントロールを使用して画像をアップロードしています。[アップロード] ボタンをクリックしてファイルを読み込んだ後、ファイルはサーバーのフォルダーに保存されますが、データベースに保存する前に、画像とともに画像の説明を追加する必要があります。いくつかのエラーが発生しています。ファイルをフォルダーに保存できますが、データベースに保存すると、動的に追加されたコントロールが1つだけ見つかり、その特定のdivに複数のコントロールがあるにもかかわらず、オブジェクト参照がオブジェクトのインスタンスに設定されません。コードに入る前に、ファイルをアップロードした後に追加するコントロールを説明します。アップロードした画像ファイルごとに 1 つの画像コントロールとテキスト ボックスを追加しています。1 つのファイルのみをアップロードすると、単純に foreach に入ります。 1回目の後にもう一度ループします..私のコードはそれをもっと説明するかもしれません。
だから、これは私の .aspx コードです:
<form id="ContentPlaceHolder1" runat="server">
<div class="transbox" id="mainbk" runat="server" style="position:absolute; top:0px; left:0px; width: 100%; height: 100%;" >
<asp:FileUpload runat="server" ID="UploadImages" style="background-color:white; position:absolute; font-family:'Palatino Linotype'; font-size:medium; top: 4px; left: 350px; right: 251px;" Width="500px" AllowMultiple="true"/>
<asp:Button runat="server" ID="uploadedFile" style="position:absolute; font-family:'Palatino Linotype'; font-size:medium; top: 4px; left: 870px; width: 112px; height: 29px;" Text="Upload" OnClick="uploadFile_Click" />
<asp:Panel ID="updtpanel" runat="server" CssClass="transbox" style="width:100%;height:100%;left:0px;top:0px;position:absolute" Visible="false">
<asp:Button ID="btnsave" runat="server" UseSubmitBehavior="true" Text="Save" OnClick="btnsave_Click" Font-Bold="true" BackColor="Yellow"></asp:Button>
</asp:Panel>
</div>
</form>
これが私のバックエンドコードです。
SqlCommand com = new SqlCommand();
SqlConnection con = new SqlConnection();
SqlDataReader reader;
int id = 0;
StringBuilder sb = new StringBuilder();
string filepath = "";
string newpath = "";
int tid = 0;
int count = 0;
int cnt1 = 0;
string textid = "";
Panel dload;
Image img;
TextBox ta;
protected void Page_Load(object sender, EventArgs e)
{
con.ConnectionString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
con.Open();
com = new SqlCommand("select max(slid) from slider", con);
reader = com.ExecuteReader();
if (reader.HasRows)
{
while (reader.Read())
{
id = Convert.ToInt32(reader.GetInt32(0));
}
}
con.Close();
com.Dispose();
HtmlGenericControl dh = new HtmlGenericControl("div");
dh.Attributes.Add("class", "head");
dh.InnerText = "Write Description";
updtpanel.Controls.Add(dh);
foreach (HttpPostedFile upld in UploadImages.PostedFiles)
{
createImgPanel();
}
}
protected void uploadFile_Click(object sender, EventArgs e)
{
if (UploadImages.HasFiles)
{
string fileExt = Path.GetExtension(UploadImages.FileName).ToLower();
if (fileExt == ".jpeg" || fileExt == ".png" || fileExt == ".jpg" || fileExt == ".bmp")
{
foreach (HttpPostedFile uploadedFile in UploadImages.PostedFiles)
{
count += 1;
filepath = Server.MapPath("~/Images/Gallery/" + uploadedFile.FileName);
uploadedFile.SaveAs(filepath);
newpath = "../Images/Gallery/" + uploadedFile.FileName;
try
{
Image nimg = dload.FindControl("img" + count) as Image;
nimg.ImageUrl = newpath.ToString();
}
catch (Exception ex)
{
Response.Write(ex.Message);
}
}
}
else
{
Page.ClientScript.RegisterStartupScript(GetType(), "msgbox", "alert('Please Select only Image Files!!');", true);
}
}
else
{
Page.ClientScript.RegisterStartupScript(GetType(), "msgbox", "alert('Please Select a File First!!');", true);
}
}
public void createImgPanel()
{
tid = tid + 1;
textid = "txt" + tid;
ta = new TextBox();
img = new Image();
ta.TextMode = TextBoxMode.MultiLine;
dload = new Panel();
updtpanel.Visible = true;
dload.Attributes.Add("class", "dataload");
//dload.Attributes.Add("runat", "server");
dload.ID = "ind" + tid;
img.CssClass = "loadimg";
img.ID = "img" + tid;
//img.Attributes.Add("runat", "server");
ta.Attributes.Add("class", "txtdes");
ta.ID = textid;
//ta.Attributes.Add("runat", "server");
dload.Controls.Add(img);
dload.Controls.Add(ta);
updtpanel.Controls.Add(dload);
}
protected void btnsave_Click(object sender, EventArgs e)
{
if (Page.IsPostBack)
{
Panel pv = (this.Form.FindControl("mainbk").FindControl("updtpanel")) as Panel;
foreach (Control cd in pv.Controls)
{
cnt1 = cnt1 + 1;
TextBox txt = cd.FindControl("ind" + cnt1).FindControl("txt" + cnt1) as TextBox;****This is where I am getting the above said error****
Image img = cd.FindControl("ind" + cnt1).FindControl("img" + cnt1) as Image;
string str = "";
str = txt.Text;
string iurl = "";
iurl = img.ImageUrl;
id += 1;
string Insert = "Insert into slider (slid,slurl,slalt) values (@id,@IMAGE_PATH,@alter)";
SqlCommand cmd = new SqlCommand(Insert, con);
cmd.Parameters.AddWithValue("@IMAGE_PATH", iurl);
cmd.Parameters.AddWithValue("@id", id);
cmd.Parameters.AddWithValue("@alter", str);
try
{
con.Open();
cmd.ExecuteNonQuery();
con.Close();
}
catch (Exception e1)
{
Response.Write(e1.Message);
}
}
updtpanel.Visible = false;
}
}
*上記のコードの最後の部分、つまり保存ボタンのクリック イベントでエラーが発生しています。Textbox Find コントロールの場合、エラーが発生します。最初の画像は正常に保存されますが、他の画像はデザインに存在する場合でも制御できません。*
クリックイベントの保存で間違いを犯しているかどうか、またはコーディング自体に間違いがあるかどうかを知りたいだけです
編集
これは、実行時にコントロールがレンダリングされた後の HTML ソースです。
<div id="mainbk" class="transbox" style="position:absolute; top:0px; left:0px; width: 100%; height: 100%;">
<input type="file" multiple="multiple" name="UploadImages" id="UploadImages" style="width:500px;background-color:white; position:absolute; font-family:'Palatino Linotype'; font-size:medium; top: 4px; left: 350px; right: 251px;">
<input type="submit" name="uploadedFile" value="Upload" id="uploadedFile" style="position:absolute; font-family:'Palatino Linotype'; font-size:medium; top: 4px; left: 870px; width: 112px; height: 29px;">
<div id="updtpanel" class="transbox" style="width:100%;height:100%;left:0px;top:0px;position:absolute">
<input type="submit" name="btnsave" value="Save" id="btnsave" style="background-color:Yellow;font-weight:bold;">
<div class="head">Write Description</div><div id="ind1" class="dataload">
<img id="img1" class="loadimg" runat="server" src="../Images/Gallery/God%201.jpg">
<textarea name="txt1" rows="2" cols="20" id="txt1" class="txtdes"></textarea>
</div><div id="ind2" class="dataload">
<img id="img2" class="loadimg" runat="server" src="../Images/Gallery/God%202.jpg">
<textarea name="txt2" rows="2" cols="20" id="txt2" class="txtdes"></textarea>
</div><div id="ind3" class="dataload">
<img id="img3" class="loadimg" runat="server" src="../Images/Gallery/God%203.jpg">
<textarea name="txt3" rows="2" cols="20" id="txt3" class="txtdes"></textarea>
</div>
</div>
</div>
編集済み
KI は、私が取得している例外をさらに深く掘り下げました...そのことわざ..
'((System.Web.UI.HtmlControls.HtmlContainerControl)(dv)).InnerHtml' がタイプ 'System.Web.HttpException' の例外をスローしました
これは実際にはどういう意味ですか..コントロールはリテラルではないとも言っています..それはどういう意味ですか..追加したコントロールが見つからないのはなぜですか..助けてください..